sqlserver 进行MD5加密
官方定义函数:
HashBytes ( '<algorithm>', { @input | 'input' } )
<algorithm>::= 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编辑即可
sqlserver 进行MD5加密的更多相关文章
- MySql md5加密 sqlserver md5加密 C# md5加密 java md5加密
便民md5加密: 百度md5加密: MySQL 加密语法: MD5(加密字符串) -- 中文加密 SELECT MD5('你好') -- 中文加密匹配查询 SELECT * FROM 表名 WHERE ...
- 一个简单的后台与数据库交互的登录与注册[sql注入处理,以及MD5加密]
一.工具: vs2013[因为我现在用的也是2013,版本随便你自己开心] sql2008[准备过久升级] 二.用到的语言: HTML+CSS+Jquery+Ajax+sqlserver HTML[相 ...
- SQL将原始数据进行MD5加密转存
先来描述下情况吧,首先有一批用户之前批量录入后默认的密码为6个8然后进行MD5加密后进行存储的,现在需要对其更改根据用户身份证号后6位作为密码. 1.首先发现我们sqlserver05以上的版本是自带 ...
- 【信息安全】MD5加密浅析
前段时间,网传京东泄露了几G的用户数据,后面又说用户数据是MD5加密的,让大家不要担心,改个密码之类云云. 出于好奇,上网了解了一下这个MD5. 一.MD5加密方式是什么 简单讲,MD5加密是一个用到 ...
- 关于CryptoJS中md5加密以及aes加密的随笔
最近项目中用到了各种加密,其中就包括从没有接触过得aes加密,因此从网上各种查,官方的一种说法: 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学 ...
- Android数据加密之MD5加密
前言: 项目中无论是密码的存储或者说判断文件是否是同一文件,都会用到MD5算法,今天来总结一下MD5加密算法. 什么是MD5加密? MD5英文全称“Message-Digest Algorithm 5 ...
- android MD5加密
public class MD5Uutils { //MD5加密,32位 public static String MD5(String str) { MessageDige ...
- IOS 杂笔-9 (MD5 加密)
首先是一段对MD5的简介 *出自一位大牛之手* Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护 ...
- JS中使用MD5加密
下载 MD5 使用MD5加密的方法:下载md5.js文件,在网页中引用该文件: < script type="text/javascript" src="md5.j ...
随机推荐
- SRM 392(1-250pt)
DIV1 250pt 题意:给两个各含有一个*号的字符串s1和s2,可以用一个任意字符串代替*号(注意是串,不是只能用单个字符代替,也可以为用空串代替),问能否将s1和s2变为相同的字符串.如果能输出 ...
- ASP.NET MVC3 ModelState.IsValid为false的问题
模型验证通常在submit后调用Action之前进行验证,eg: public class ZhengXing { [Key] public int ZhengXin ...
- js中arguments的应用
Javascrip中的每个函数都会有一个Arguments对象实例arguments,它引用着函数的实参,可以用数组下标的方式"[]"引用arguments的元素.argument ...
- Dijkstra算法为什么权值不能为负
Dijkstra算法当中将节点分为已求得最短路径的集合(记为S)和未确定最短路径的个集合(记为U),归入S集合的节点的最短路径及其长度不再变更,如果边上的权值允许为负值,那么有可能出现当与S内某点(记 ...
- ISAP 简介
刘汝佳的蓝书上已经给出了大部分,先给上完整代码(以草地排水为例). #include<iostream> #include<algorithm> #include<cst ...
- 项目经历——EasyUI的检索和更新操作
什么事都耐不住“磨”?! 比如一个让人很头疼的问题,对于项目中所用到的EasyUI框架就是一个很明显的感受.项目使用的EasyUI框架,自身封装好的样式使得开发者不用考虑具体的div和css样式了,但 ...
- 关于lucene的IndexSearcher单实例,对于索引的实时搜索
Lucene版本:3.0 一般情况下,lucene的IndexSearcher都要写成单实例,因为每次创建IndexSearcher对象的时候,它都需要把索引文件加载进来,如果访问量比较大,而索引也比 ...
- Java 日志缓存机制的实现--转载
概述 日志技术为产品的质量和服务提供了重要的支撑.JDK 在 1.4 版本以后加入了日志机制,为 Java 开发人员提供了便利.但这种日志机制是基于静态日志级别的,也就是在程序运行前就需设定下来要打印 ...
- 从零开始学习jQuery-------jQuery元素选择器(三)
下面我们来介绍一下jQuery元素选择器,在Web开发中我们最常用的操作是获取元素,然后对获取的元素进行一系列的操作,jQuery根据获取页面元素的不同,可以将jQuery选择器分为四大类:基本选择器 ...
- 自己编写SqlHelper
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.W ...