2

我有一个用于将字符串转换为 base64 编码字符串的 SQL 函数。唯一的问题是没有使用 UTF8,我可以说出来,因为我有一个单独的 C# 工具可以提供不同的输出。

SQL函数:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

ALTER FUNCTION [dbo].[Base64Encode] ( @sInput NVARCHAR(max) )
RETURNS NVARCHAR(max)
BEGIN

DECLARE @vInput              VARBINARY(max)
DECLARE @sEncodedOutput      NVARCHAR(max)

set @vInput = convert(varbinary(max), @sInput)
set @sEncodedOutput = cast('' as xml).value('xs:base64Binary(sql:variable("@vInput"))', 'NVARCHAR(max)')

RETURN @sEncodedOutput

END

C#

        try
        {
            encodedValueTextbox.Text = Convert.ToBase64String(
                Encoding.UTF8.GetBytes(valueTextbox.Text));
        }
        catch (Exception ex)
        {
            encodedValueTextbox.Text = ex.Message;
        }

有没有办法让 SQL 使用 UTF8?

4

1 回答 1

0

您的@sInput 是 NVARCHAR,即 UNICODE UCS-2。因此,您正在将 UCS-2 转换为二进制文件。

您可以将输入参数更改为 varbinary 并将 UTF-8 作为二进制传递给函数。如果您输入函数的源数据也是来自 SQL 的 nvarchar,则您需要继续将二进制数据转换推回源 C#(可能存储为 varbinary,基本上我不知道您的其余部分是什么)系统看起来像)。

另一种方法是在 CLR 中编写此函数。使用 C# 将 UCS-2 转换为 UTF-8,然后也在那里进行 Base64 编码。

于 2013-01-26T06:36:39.303 回答