【发布时间】:2012-12-28 11:38:40
【问题描述】:
我有一个用于将字符串转换为 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?
【问题讨论】:
-
虽然我无法回答您的问题,但我想知道您为什么要对 UFT-8 字符串进行 base64 编码?您是否尝试隐藏文本?如果您愿意,最好使用加密。
-
base64 给出的“随机文本”外观就足够了
-
@GameScripting:您不能对 nvarchar 值进行 base-64 编码,因为有超过 256 个字符代码,因此必须将文本编码为字节格式,例如使用 UTF-8。
-
MSSQL
NVarChar不是 .Netstring。 MSSQLVarBinary不是 .Netbyte[]。从NVarChar到VarBinary的TSQL 转换不是对.NetUTF8.GetBytes()函数的调用。转换为 XMLNVarChar的 TSQL 不是对 .NetConvert.ToBase64String()的调用。那么,是什么让你认为这些操作应该是等价的?您想使用来自两个平台的函数来回传值吗? -
@Jodrell:我不确定你的意思是什么?是的,我了解语言之间的数据类型不同,但由于我对 SQL 的熟练程度不如 C#,所以我想问如何让 SQL 产生与 C# 相同的输出。
标签: c# sql string utf-8 base64