博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sqlserver 进行MD5加密
阅读量:6232 次
发布时间:2019-06-21

本文共 2248 字,大约阅读时间需要 7 分钟。

 

官方定义函数:

HashBytes ( '<algorithm>', { @input | 'input' }

::= MD2 | MD4 | MD5 | SHA | SHA1

参数解释:

algorithm:标识用于对输入执行哈希操作的哈希算法。这是必选参数,无默认值。需要使用单引号。

@input : 数据类型为 varchar、nvarchar 或 varbinary

'input' 字符串数据

返回值:

varbinary (最大8000字节)

备注:允许的输入值限制为 8000 个字节。输出符合算法标准:MD2、MD4 和 MD5 为 128 位(即 16 个字节);SHA 和 SHA1 为 160 位(即 20 个字节)

 

一:示例MD5加密:

一个完整的写法:

PRINT    LOWER(RIGHT(sys.fn_varbintohexstr(HASHBYTES('MD5','这个字符串需要加密')),32))   >> 8926206f9ebb0bee4bbb0724fccb4410

 

下面逐步拆分

1.先用HashBytes函数看看生成的结果

PRINT HASHBYTES('MD5','这个字符串需要加密')   >>  0x8926206F9EBB0BEE4BBB0724FCCB4410

由于该函数返回的值是二进制varbinary 数据,不是字符串不能直接使用,所以要将其转换为字符串

2.用sys.fn_varbintohexstr(@pbinin)

@pbinin : varbinary (max) 数据类型

返回:nvarchar 数据类型

PRINT sys.fn_varbintohexstr(HASHBYTES('MD5','这个字符串需要加密'))  >>  0x8926206f9ebb0bee4bbb0724fccb4410

 

3.如何得到32位的MD5值,貌似最大也就只能到32位,使用 Right 函数进行截取

PRINT RIGHT(sys.fn_varbintohexstr(HASHBYTES('MD5','这个字符串需要加密')),32) >> 8926206f9ebb0bee4bbb0724fccb4410

函数定义

RIGHT ( character_expression , integer_expression )
参数:
character_expression :可为字符或二进制数据表达式,常量,变量,列,任何能隐式转换为varchar或nvarchar的数据类型(text,ntext需要进行显示转换)
integer_expression :正整数,将返回的字符数
返回值:character_expression 若为 非Unicode 返回 varchar , 若为unicode 则返回nvarchar

 

4.如果需要统一大小写 可使用  lower(character_expression )  , upper(character_expression ) 进行转换

 

二:关于MD5加密的字符编码问题

 

先来几段对比

1. 字符 “è”

SQLServer :C05FC85230C60ED8FECB3670E77E603D

结果:与C# gb2312对应

 

2. 字符 “这是汉字”

 

SQLServer : E8C9AB48B603F81B87F4ED4F1005BB6E

结果:与C# gb2312对应

 

3. 字符 “123456”

 

SQLServer : E10ADC3949BA59ABBE56E057F20F883E

结果:与C# gb2312,utf-8 , utf-7 , ascii  对应

 

4.字符 “pxs123”

 

SQLServer : 684D95499489435C9351EFCDD68B25F2

结果:与C# gb2312,utf-8 , utf-7 , ascii  对应

 

4.字符 “pxs!@#.”

SQLServer :FC05D7826726E773E993BDCA88F6B181

结果:与C# gb2312,utf-8 , ascii  对应

 

 

5.字符 英文符号“!@#.&*)|_;“

SQLServer :4C782D772102482D09696D11BDE1A02A

结果:与C# gb2312,utf-8 , ascii  对应

 

 

 

6.字符 中文英混合符号“《!)*、“

SQLServer :1A891B7B5B3285925E2783694C2A367C

结果:与C# gb2312对应

 

6.字符 中文英混合符号“汉字hanzi“

SQLServer :49212C24BDB2FA254880119A332F86D6

结果:与C# gb2312对应

 

 

8.字符 “プログラミン“

SQLServer :045B556A9CF5F0FE92EC7A7C9B3F66CA

结果:与C# gb2312对应

 

综上对比:

sqlserver中md5加密函数,字符存在非英文字符会按照gb2312方式编码计算出加密值,那么C#,JS等计算MD5加密值是就需要转为gb2312编码,才能得出一样的结果。

若为都为英文字符时,用utf-8编辑即可

 

转载于:https://www.cnblogs.com/alan_peng/p/5882906.html

你可能感兴趣的文章
Yii用ajax实现无刷新检索更新CListView数据
查看>>
JDBC的事务
查看>>
Io流的概述
查看>>
App 卸载记录
查看>>
JavaScript变量和作用域
查看>>
开源SIP服务器加密软件NethidPro升级
查看>>
作业:实现简单的shell sed替换功能和修改haproxy配置文件
查看>>
Altium 拼板方法以及 注意的 地方
查看>>
Apache Pulsar中的地域复制,第1篇:概念和功能
查看>>
python pip install 出现 OSError: [Errno 1] Operation not permitted
查看>>
oracle12C 重做日志
查看>>
从源码分析scrollTo、scrollBy、Scroller方法的区别和作用
查看>>
ObjectOutputStream和ObjectInputStream
查看>>
nagios客户端未启动报错
查看>>
南京大学周志华教授当选欧洲科学院外籍院士
查看>>
《OpenGL ES应用开发实践指南:Android卷》—— 1.3 初始化OpenGL
查看>>
马士兵教学语录
查看>>
计算机网络与Internet应用
查看>>
MongodDB学习笔记(二)(复制)
查看>>
oracle在线迁移同步数据,数据库报错
查看>>