SQLServer内置函数实现MD5加密
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
SQLServer内置函数实现MD5加密⼀、MD5加密
HASHBYTES ('加密⽅式', '待加密的值')
加密⽅式= MD2 | MD4 | MD5 | SHA | SHA1
返回值类型:varbinary(maximum 8000 bytes)
⼆、MD5加密⽰例
select HASHBYTES('MD5','123456')
HASHBYTES⽣成的结果为:0xE10ADC3949BA59ABBE56E057F20F883E
注意:⼀般⼯具⽣成的都是没有0x和是⼩写的,16进制的数值,去掉“0x”转换为⼩写值就完全与MD5值吻合了。
在此需要⽤另⼀个函数(sys.fn_sqlvarbasetostr)把varbinary的值转换为varchar类型的
select sys.fn_sqlvarbasetostr(HASHBYTES('MD5','123456'))
结果:0xe10adc3949ba59abbe56e057f20f883e 截取去掉0x
select substring(sys.fn_sqlvarbasetostr(HASHBYTES('MD5','123456')),3,32)
结果就是完整的MD5值:e10adc3949ba59abbe56e057f20f883e
三、SQL截取字符串substring
substring 返回字符、binary、text 或 image 表达式的⼀部分。
基本语法:SUBSTRING ( expression , start , length )
expression:字符串、⼆进制字符串、text、image、列或包含列的表达式
start:整数,指定⼦串的开始位置
注:SQL中"1"表⽰字符串中的第⼀个字符,⽽.NET中"0"表⽰第⼀个字符 length:整数,指定⼦串的长度(要返回的字符数或字节数)。