MD5加密C#和js代码加密结果不同
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MD5加密C#和js代码加密结果不同相关的知识,希望对你有一定的参考价值。
MD5加密C#和js代码加密常规字符串是正确的,但是加密"c4Î>˧ÅÃз4?ú\n"引号里边的字符串,加密结果不同
编码挨个试过了,都不行,应该不是编码的问题。
你先看看MD5的加密方式吧,我是先转码在加密的,不同转码加密的结果是不同的,浏览器显示的时候我监测过,没有转。
追答你只看编码格式不一定正确有的时候你去md5加密中文~c#显示都是按照ut8的格式去加密但是结果还是和js加密不一样~以前做vb.net去加密中文的时候加密同一个中文字符串总是和php加密的结果不一样~后来发现php utf8转码中文字符串的结果都和vb.net不一样~加密以后结果自然不一样~我之前说的表达点问题~我的意思是让你去看看你要加密的密文转码后加密前的utf8是不是和js的utf8是不是一样的~你这样才能确定你不是在转码的时候出了问题而不是加密的时候出了问题~~
追问首先我MD5加密C#和js代码加密常规字符串(没有特殊符号包括中文)是一致的,但是在加密"c4˜Î‹>˧ÅÃз4?ú\n"这个字符串的时候不一致了。你帮我试试你经过MD5加密后是什么?
追答刚才转成ascii以后就有点问题了~~你这些符号有的在ascii扩展码表里根本就查不到~没加密的ascii是这样的
99 52 203 156 195 142 226 128 185 62 195 139 194 167 195 133 195 131 195 144 194 183 52 63 195 186 10
那些128到160范围内的都显示不了。。。。不是js的算法针对这些是怎么处理如果他要对于这些扩展表里的那些显示不了都当成一个处理结果就肯定是不一样了。。。不敢断言我也没看见js算法的代码
MD5加密和RSA加密
1.MD5加密
MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),MD5算法的使用不需要支付任何版权费用。
MD5的功能:
①.输入任意长度的信息,经过处理,输出为128位的信息(数字指纹);
②.不同的输入得到的不同的结果(唯一性);
③.根据128位的输出结果不可能反推出输入的信息(不可逆),也就是只能加密,不能解密;
MD5的用途:
1、防止被篡改:
1)比如发送一个电子文档,发送前,我先得到MD5的输出结果a。然后在对方收到电子文档后,对方也得到一个MD5的输出结果b。如果a与b一样就代表中途未被篡改。2)比如我提供文件下载,为了防止不法分子在安装程序中添加木马,我可以在网站上公布由安装文件得到的MD5输出结果。3)SVN在检测文件是否在CheckOut后被修改过,也是用到了MD5.
2、防止直接看到明文:
现在很多网站在数据库存储用户的密码的时候都是存储用户密码的MD5值。这样就算不法分子得到数据库的用户密码的MD5值,也无法知道用户的密码(其实这样是不安全的,后面我会提到)。(比如在UNIX系统中用户的密码就是以MD5(或其它类似的算法)经加密后存储在文件系统中。当用户登录的时候,系统把用户输入的密码计算成MD5值,然后再去和保存在文件系统中的MD5值进行比较,进而确定输入的密码是否正确。通过这样的步骤,系统在并不知道用户密码的明码的情况下就可以确定用户登录系统的合法性。这不但可以避免用户的密码被具有系统管理员权限的用户知道,而且还在一定程度上增加了密码被破解的难度。)
3、防止抵赖(数字签名):
这需要一个第三方认证机构。例如A写了一个文件,认证机构对此文件用MD5算法产生摘要信息并做好记录。若以后A说这文件不是他写的,权威机构只需对此文件重新产生摘要信息,然后跟记录在册的摘要信息进行比对,相同的话,就证明是A写的了。这就是所谓的“数字签名”。
我们强大的支付宝使用MD5加密,正式因为MD5强大的用途。
2.RSA加密
①.RSA是第一个比较完善的公开密钥算法,它既能用于加密,也能用于数字签名。
②.RSA加密是可逆的,一个字符串可以经rsa加密后,经加密后的字符串传到对端如服务器上,再进行解密即可。前提是服务器知道解密的私钥,当然这个私钥最好不要再网络传输。
③.RSA以它的三个发明者Ron Rivest, Adi Shamir, Leonard Adleman的名字首字母命名,这个算法经受住了多年深入的密码分析,虽然密码分析者既不能证明也不能否定RSA的安全性,但这恰恰说明该算法有一定的可信性,目前它已经成为最流行的公开密钥算法。
④.RSA的安全基于大数分解的难度。其公钥和私钥是一对大素数(100到200位十进制数或更大)的函数。从一个公钥和密文恢复出明文的难度,等价于分解两个大素数之积(这是公认的数学难题)。
RSA的公钥、私钥的组成,以及加密、解密的公式可见于下表:
RSA的安全性:
在RSA密码应用中,公钥KU是被公开的,即e和n的数值可以被第三方窃听者得到。破解RSA密码的问题就是从已知的e和n的数值(n等于pq),想法求出d的数值,这样就可以得到私钥来破解密文。从上文中的公式:d ≡e-1 (mod((p-1)(q-1)))或de≡1 (mod((p-1)(q-1))) 我们可以看出。密码破解的实质问题是:从Pq的数值,去求出(p-1)和(q-1)。换句话说,只要求出p和q的值,我们就能求出d的值而得到私钥。
当p和q是一个大素数的时候,从它们的积pq去分解因子p和q,这是一个公认的数学难题。比如当pq大到1024位时,迄今为止还没有人能够利用任何计算工具去完成分解因子的任务。因此,RSA从提出到现在已近二十年,经历了各种攻击的考验,逐渐为人们接受,普遍认为是目前最优秀的公钥方案之一。
然而,虽然RSA的安全性依赖于大数的因子分解,但并没有从理论上证明破译RSA的难度与大数分解难度等价。即RSA的重大缺陷是无法从理论上把握它的保密性能如何。
此外,RSA的缺点还有:A)产生密钥很麻烦,受到素数产生技术的限制,因而难以做到一次一密。B)分组长度太大,为保证安全性,n 至少也要 600 bits 以上,使运算代价很高,尤其是速度较慢,较对称密码算法慢几个数量级;且随着大数分解技术的发展,这个长度还在增加,不利于数据格式的标准化。因此,使用RSA只能加密少量数据,大量的数据加密还要靠对称密码算法。
我相信这么强大的加密方式想要破解,几乎不可能吧。这也是RSA用在支付宝加密中的原因。
以上是关于MD5加密C#和js代码加密结果不同的主要内容,如果未能解决你的问题,请参考以下文章
说能说清楚C#md5和php md5加密技术的区别,以实例说明
.net(md5)加密汉字的结果与java(md5)加密汉字的结果不一样。。。