幼儿饰品瑜伽美体用品微软
投稿投诉
微软创意
爱情通信
用品婚姻
爱好看病
美体软件
影音星座
瑜伽周边
星座办公
饰品塑形
搞笑减肥
幼儿两性
智家潮品

关于加解密加签验签的那些事得物技术

  1前言
  面对MD5、SHA、DES、AES、RSA等等这些名词你是否有很多问号?这些名词都是什么?还有什么公钥加密、私钥解密、私钥加签、公钥验签。这些都什么鬼?或许在你日常工作没有听说过这些名词,但是一旦你要设计一个对外访问的接口,或者安全性要求高的系统,那么必然会接触到这些名词。所以加解密、加签验签对于一个合格的程序员来说是必须要掌握的一个概念。接下来我们就一文彻底搞懂这些概念。2没有硝烟的战场浅谈密码技术
  没有根基也许可以建一座小屋,但绝对不能造一座坚固的大厦。
  密码这个词有很多种的解释,在现代社会如果不接触编程的话,那么普遍的认为是我们设置的登录密码、或者是去银行取钱时输入的数字。都是我们在注册时实现给提供服务的一方存储一组数字,以后我们登录的时候就用这组数字相当于就证明了我们的身份。这个数字通常来说就是叫做密码。
  而我们需要了解的不是上面说的密码,而是一种密码术,就是对于要传递的信息按照某种规则进行转换,从而隐藏信息的内容。这种方法可以使机密信息得以在公开的渠道传递而不泄密。使用这种方法,要经过加密过程。在加密过程中我们需要知道下面的这些概念:
  原文:或者叫明文,就是被隐藏的文字
  加密法:指隐藏原文的法则
  密文:或者叫伪文,指对原文按照加密法处理过后生成的可公开传递的文字
  密钥:在加密法中起决定性的因素,可能是数字、词汇,也可能是一些字母,或者这些东西的组合
  加密的结果生成了密文,要想让接受者能够读懂这些密文,那么就要把加密法以及密钥告诉接受者,否者接受者无法对密文解密,也就无法读懂原文。
  从历史的角度来看,密码学大概可以分为古典密码学和近现代密码学两个阶段。两者以现代信息技术的诞生为分界点,现在所讨论的密码学多指的是后者,建立在信息论和数学成果基础之上的。2。1古典密码学
  古典密码学源自于数千年前,最早在公元前1900年左右的古埃及,就出现了通过使用特殊字符和简单替换式密码来保护信息。美索不达米亚平原上曾经出土一个公元前1500年左右的泥板,其上记录了加密描述的陶瓷器上釉的工艺配方。古希腊时期(公元前800前146年)还发明了通过物理手段来隐藏信息的隐写术,例如使用牛奶书写、用蜡覆盖文字等。后来在古罗马时期还出现了基于替换加密的凯撒密码,据称凯撒曾用此方法与其部下通信而得以命名。这些手段多数是采用简单的机械工具来保护秘密,在今天看来毫无疑问是十分简陋,很容易猜出来的。严格来看,可能都很难称为密码科学。
  凯撒密码是当偏移量是3的时候,所有的字母都A都将被替换成D,B变成E,以此类推。
  2。2近代密码学
  近代密码学的研究来自于第一、二次世界大战中对于军事通信进行保护和猜出来的需求。1901年12月,意大利的工程师GuglielmoMarconi(奎里亚摩马可尼)成功完成了跨越大西洋的无线电通信的实验,在全球范围内引发轰动,推动了无线电通信时代的到来。无线电大大提高了远程通信的能力,但是它有一个天然的缺陷很难限制接收方,这就意味着你所传的信息有可能被拦截,因此就催生了加密技术的发展。
  对于无线电信息进行加密和解密也直接促进了近现代密码学和计算机技术的出现。反过来这些科技进步也影响了时代的发展。一战时期德国外交部长ArthurZimmermann(阿瑟齐默尔曼)拉拢墨西哥构成抗美军事同盟的电报(1917年1月16日)被英国情报机构40号办公室破译,直接导致了美国的参战;二战时期德国使用的恩尼格玛(Enigma)密码机(当时最先进的加密设备)被盟军成功破译(1939年到1941年),导致大西洋战役德国失败。据称,二战时期光英国从事密码学研究的人员就达到7000人,而他们的成果使二战结束的时间至少提前了一到两年时间。
  接下来就是可以称之为是密码学发展史上里程碑的事件了。1945年9月1日,ClaudeElwoodShannon(克劳德艾尔伍德香农)完成了划时代的内部报告《AMathematicalTheoryofCryptography(密码术的一个数学理论)》,1949年10月,该报告以《CommunicationTheoryofSecrecySystems(保密系统的通信理论)》为题在BellSystemTechnicalJournal(贝尔系统技术期刊)上正式发表。这篇论文首次将密码学和信息论联系到一起,为对称密码技术提供了数学基础。这也标志着近现代密码学的正式建立。这也是密码学发展史上的第一座里程碑性事件。
  密码学发展史上的第二个里程碑性事件是DES的出现。DES全称为DataEncryptionStandard,即数据加密标准,是一种使用密钥加密的分组密码算法,1977年被美国联邦政府的国家标准局确定为联邦资料处理标准(FIPS),并授权在非密级政府通信中使用,随后该算法在国际上广泛流传开来。
  密码学发展史上的第三个里程碑性事件就是我们区块链中广泛应用的公钥密码,也就是非对称密码算法的出现。1976年11月,WhitfieldDiffie和MartinE。Hellman在IEEETransactionsonInformationTheory上发表了论文《NewDirectionsinCryptography(密码学的新方向)》,探讨了无需传输密钥的保密通信和签名认证体系问题,正式开创了现代公钥密码学体系的研究。在公钥密码发现以前,如果需要保密通信,通信双方事先要对加解密的算法以及要使用的密钥进行事先协商,包括送鸡毛信,实际上是在传送密钥。但自从有了公钥密码,需要进行秘密通信的双方不再需要进行事前的密钥协商了。公钥密码在理论上是不保密的,在实际上是保密的。也就是说,公钥密码是可以猜出来的,但需要极长的时间,等到猜出来了,这个秘密也没有保密的必要了。
  上面我们说到了关于近现代的密码学相关的东西,基本上总结下来我们现在常用的就两个,一个是对称加密算法,一个是非对称加密算法。那么接下来我们就以介绍这两个概念为主线引出开题中我们提到的概念。3程序实现3。1对称加密算法
  对称加密指的就是加密和解密使用同一个秘钥,所以叫做对称加密。对称加密只有一个秘钥,作为私钥。具体的算法有:DES、3DES、TDEA、Blowfish,RC5,IDEA。但是我们常见的有:DES、AES等等。
  那么对称加密的优点是什么呢?算法公开、计算量小、加密速度快、加密效率高。缺点就是秘钥的管理和分发是非常困难的,不够安全。在数据传送前,发送方和接收方必须商定好秘钥,然后双方都必须要保存好秘钥,如果一方的秘钥被泄露了,那么加密的信息也就不安全了。另外,每对用户每次使用对称加密算法时,都需要使用其他人不知道的唯一秘钥,这会使得收、发双方所拥有的的钥匙数量巨大,秘钥管理也会成为双方的负担。
  加密的过程我们可以理解为如下:加密:原文秘钥密文解密:密文秘钥原文
  可以看到两次过程使用的都是一个秘钥。用图简单表示如下:
  3。2实战演练
  既然我们知道关于对称加密算法的相关知识,那么我们日常用Java如何实现对称加密的加密和解密动作呢?常见的对称加密算法有:DES、AES等。3。2。1DES
  DES加密算法是一种分组密码,以64位为分组对数据加密,它的密钥长度是56位,加密解密用同一算法。DES加密算法是对密钥进行保密,而公开算法,包括加密和解密算法。这样,只有掌握了和发送方相同密钥的人才能解读由DES加密算法加密的密文数据。因此,破译DES加密算法实际上就是搜索密钥的编码。对于56位长度的密钥来说,如果用穷举法来进行搜索的话,其运算次数为2的56次方。
  接下来用Java实现DES加密publicstaticvoidmain(String〔〕args)throwsException{Stringdata123456;Stringkeywang!34;;System。err。println(encrypt(data,key));System。err。println(decrypt(encrypt(data,key),key));}Description根据键值进行加密paramdataparamkey加密键byte数组returnthrowsExceptionpublicstaticStringencrypt(Stringdata,Stringkey)throwsException{byte〔〕btencrypt(data。getBytes(),key。getBytes());StringstrsnewBASE64Encoder()。encode(bt);returnstrs;}Description根据键值进行解密paramdataparamkey加密键byte数组returnthrowsIOExceptionthrowsExceptionpublicstaticStringdecrypt(Stringdata,Stringkey)throwsIOException,Exception{if(datanull)returnnull;BASE64DecoderdecodernewBASE64Decoder();byte〔〕bufdecoder。decodeBuffer(data);byte〔〕btdecrypt(buf,key。getBytes());returnnewString(bt);}Description根据键值进行加密paramdataparamkey加密键byte数组returnthrowsExceptionprivatestaticbyte〔〕encrypt(byte〔〕data,byte〔〕key)throwsException{生成一个可信任的随机数源SecureRandomsrnewSecureRandom();从原始密钥数据创建DESKeySpec对象DESKeySpecdksnewDESKeySpec(key);创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象SecretKeyFactorykeyFactorySecretKeyFactory。getInstance(DES);SecretKeysecurekeykeyFactory。generateSecret(dks);Cipher对象实际完成加密操作CiphercipherCipher。getInstance(DES);用密钥初始化Cipher对象cipher。init(Cipher。ENCRYPTMODE,securekey,sr);returncipher。doFinal(data);}Description根据键值进行解密paramdataparamkey加密键byte数组returnthrowsExceptionprivatestaticbyte〔〕decrypt(byte〔〕data,byte〔〕key)throwsException{生成一个可信任的随机数源SecureRandomsrnewSecureRandom();从原始密钥数据创建DESKeySpec对象DESKeySpecdksnewDESKeySpec(key);创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象SecretKeyFactorykeyFactorySecretKeyFactory。getInstance(DES);SecretKeysecurekeykeyFactory。generateSecret(dks);Cipher对象实际完成解密操作CiphercipherCipher。getInstance(DES);用密钥初始化Cipher对象cipher。init(Cipher。DECRYPTMODE,securekey,sr);returncipher。doFinal(data);}
  输出以后可以看到数据被加密了5fiwXhRJ0E123456
  在Java中用DES加密有一个特殊的地方
  (1)秘钥设置的长度必须大于等于8
  (2)秘钥设置的长度如果大于8的话,那么只会取前8个字节作为秘钥
  为什么呢,我们可以看到在初始化DESKeySpec类的时候有下面一段,其中var1是我们传的秘钥。可以看到他进行了截取。只截取前八个字节。publicDESKeySpec(byte〔〕var1,intvar2)throwsInvalidKeyException{if(var1。lengthvar28){thrownewInvalidKeyException(Wrongkeysize);}else{this。keynewbyte〔8〕;System。arraycopy(var1,var2,this。key,0,8);}}3。2。2AES
  AES加密算法是密码学中的高级加密标准,该加密算法采用对称分组密码体制,密钥长度的最少支持为128、192、256,分组长度128位,算法应易于各种硬件和软件实现。这种加密算法是美国联邦政府采用的区块加密标准,AES标准用来替代原先的DES,已经被多方分析且广为全世界所使用。
  JCE,JavaCryptographyExtension,在早期JDK版本中,由于受美国的密码出口条例约束,Java中涉及加解密功能的API被限制出口,所以Java中安全组件被分成了两部分:不含加密功能的JCA(JavaCryptographyArchitecture)和含加密功能的JCE(JavaCryptographyExtension)。
  JCE的API都在javax。crypto包下,核心功能包括:加解密、密钥生成(对称)、MAC生成、密钥协商。
  加解密功能由Cipher组件提供,其也是JCE中最核心的组件。
  在设置Cipher类的时候有几个注意点:
  (1)Cipher在使用时需以参数方式指定transformation
  (2)transformation的格式为algorithmmodepadding,其中algorithm为必输项,如:AESDESCBCPKCS5Padding,具体有哪些可看下表
  (3)缺省的mode为ECB,缺省的padding为PKCS5Padding
  (4)在block算法与流加密模式组合时,需在mode后面指定每次处理的bit数,如DESCFB8NoPadding,如未指定则使用缺省值,SunJCE缺省值为64bits
  (5)Cipher有4种操作模式:ENCRYPTMODE(加密),DECRYPTMODE(解密),WRAPMODE(导出Key),UNWRAPMODE(导入Key),初始化时需指定某种操作模式
  秘钥的可以由我们自己定义,也可以是由AES自己生成,当自己定义是需要是要注意:
  (1)根据AES规范,可以是16字节、24字节和32字节长,分别对应128位、192位和256位;
  (2)为便于传输,一般对加密后的数据进行base64编码:此处使用AES128ECB加密模式,key需要为16位。StringcKey1234567890123456;需要加密的字串StringcSrcbuxuewushu;System。out。println(cSrc);加密StringenStringEncrypt(cSrc,cKey);System。out。println(加密后的字串是:enString);解密StringDeStringDecrypt(enString,cKey);System。out。println(解密后的字串是:DeString);}加密publicstaticStringEncrypt(StringsSrc,StringsKey)throwsException{if(sKeynull){System。out。print(Key为空null);returnnull;}判断Key是否为16位if(sKey。length()!16){System。out。print(Key长度不是16位);returnnull;}byte〔〕rawsKey。getBytes(utf8);SecretKeySpecskeySpecnewSecretKeySpec(raw,AES);CiphercipherCipher。getInstance(AESECBPKCS5Padding);算法模式补码方式cipher。init(Cipher。ENCRYPTMODE,skeySpec);byte〔〕encryptedcipher。doFinal(sSrc。getBytes(utf8));returnnewBase64()。encodeToString(encrypted);此处使用BASE64做转码功能,同时能起到2次加密的作用。}解密publicstaticStringDecrypt(StringsSrc,StringsKey)throwsException{try{判断Key是否正确if(sKeynull){System。out。print(Key为空null);returnnull;}判断Key是否为16位if(sKey。length()!16){System。out。print(Key长度不是16位);returnnull;}byte〔〕rawsKey。getBytes(utf8);SecretKeySpecskeySpecnewSecretKeySpec(raw,AES);CiphercipherCipher。getInstance(AESECBPKCS5Padding);cipher。init(Cipher。DECRYPTMODE,skeySpec);byte〔〕encrypted1newBase64()。decode(sSrc);先用base64解密try{byte〔〕originalcipher。doFinal(encrypted1);StringoriginalStringnewString(original,utf8);returnoriginalString;}catch(Exceptione){System。out。println(e。toString());returnnull;}}catch(Exceptionex){System。out。println(ex。toString());returnnull;}}3。3非对称加密算法
  非对称加密算法中加密和解密用的不是同一个秘钥,所以叫作非对称加密算法。在非对称加密算法每个用户都有两把钥匙,一把公钥一把私钥。公钥是对外发布的,所有人都看的到所有人的公钥,私钥是自己保存,每个人都只知道自己的私钥而不知道别人的。而也正是在非对称加密算法中有加密和解密、加签和验签的概念。接下来我们解释一下这几个概念是什么意思。3。3。1加密和解密
  用该用户的公钥加密后只能该用户的私钥才能解密。这种情况下,公钥是用来加密信息的,确保只有特定的人(用谁的公钥就是谁)才能解密该信息。所以这种我们称之为加密和解密。
  下面我拿A银行和小明来举例子吧。假设这2者之间是用不对称的加密算法来保证信息传输的安全性(不被第三人知道信息的含义及篡改信息)。大致流程如下:首先小明发了一条信息给A银行我要存500元。这条信息小明会根据A银行的对外发布的公钥把这条信息加密了,加密之后,变成XXXXXXX发给A银行。中间被第三者截获,由于没有A银行的私钥无法解密,不能知道信息的含义,也无法按正确的方式篡改。所以拿这条加密信息是没办法的。最后被A银行接受,A银行用自己的私钥去解密这条信息,解密成功,读取内容,执行操作。然后得知消息是小明发来的,便去拿小明的公钥,把操作成功(或失败)这条信息用小明的公钥加密,发给小明。同理最后小明用自己的私钥解开,得知知乎发来的信息内容。其他人截获因为没有小明的私钥所以也没有用。3。3。2加签和验签
  还有第二种情况,公钥是用来解密信息的,确保让别人知道这条信息是真的由我发布的,是完整正确的。接收者由此可知这条信息确实来自于拥有私钥的某人,这被称作数字签名,公钥的形式就是数字证书。所以这种我们称之为加签和验签。
  继续拿小明和银行A举例子。银行A发布了一个银行客户端的补丁供所有用户更新,那为了确保人家下载的是正确完整的客户端,银行A会为这个程序打上一个数字签名(就是用银行A的私钥对这个程序加密然后发布),你需要在你的电脑里装上银行A的数字证书(就是银行对外发布的公钥),然后下载好这个程序,数字证书会去解密这个程序的数字签名,解密成功,补丁得以使用。同时你能知道这个补丁确实是来自这个银行A,是由他发布的,而不是其他人发布的。3。3。3实战演练
  我们在开发过程中经常使用的非对称加密算法之一就是RSA算法。接下来我们使用Java实现RSA算法。
  生成密钥
  首先是生成key的部分,生成key有好多种做法,这里我介绍三种
  (1)命令行:可以使用openssl进行生成公钥和私钥opensslgenrsaoutkey。pem1024out指定生成文件,此文件包含公钥和私钥两部分,所以即可以加密,也可以解密1024生成密钥的长度
  (2)使用网站:生成密钥的网站
  (3)使用代码:可以指定生成密钥的长度,最低是512publicstaticKeyPairbuildKeyPair()throwsNoSuchAlgorithmException{finalintkeySize2048;KeyPairGeneratorkeyPairGeneratorKeyPairGenerator。getInstance(RSAALGORITHM);keyPairGenerator。initialize(keySize);returnkeyPairGenerator。genKeyPair();}
  加密
  有了密钥,就可以进行加密的操作了,接下来就介绍关于RSA的加密操作,非常简单只要传进来公钥和需要加密的数据即可。publicstaticbyte〔〕encrypt(PublicKeypublicKey,Stringmessage)throwsException{CiphercipherCipher。getInstance(RSAALGORITHM);cipher。init(Cipher。ENCRYPTMODE,publicKey);returncipher。doFinal(message。getBytes(UTF8));}
  解密解密publicstaticbyte〔〕decrypt(PrivateKeyprivateKey,byte〔〕encrypted)throwsException{CiphercipherCipher。getInstance(RSAALGORITHM);cipher。init(Cipher。DECRYPTMODE,privateKey);returncipher。doFinal(encrypted);}
  加签使用RSA签名privatestaticStringsignWithRSA(Stringcontent,PrivateKeyprivateKey)throwsException{SignaturesignatureSignature。getInstance(SHA1WithRSA);signature。initSign(privateKey);signature。update(content。getBytes(utf8));byte〔〕signedsignature。sign();returnbase64Encode(signed);}
  验签使用RSA验签privatestaticbooleancheckSignWithRSA(Stringcontent,PublicKeypublicKey,Stringsign)throwsException{SignaturesignatureSignature。getInstance(SHA1WithRSA);signature。initVerify(publicKey);signature。update(content。getBytes(utf8));returnsignature。verify(base64Decode(sign));}
  在加签验签的时候需要传入一个数字签名标准,我们这里填的是SHA1WithRSA,它的意思是用SHA算法进行签名,用RSA算法进行加密。
  算法说明:在对进行SHA1算法进行摘要计算后,要求对计算出的摘要进行处理,而不是直接进行RSA算法进行加密。要求把SHA1摘要的数据进行压缩到20个字节。在前面插入15个字节标示数据。所以结构如下
  最后进行RSA加密。所以我们填写的XXXWithRSA,这个XXX代表的就是使用什么摘要算法进行加签,至于摘要算法是什么,随后会有详细的说明。
  调用实验一下KeyPairkeyPairbuildKeyPair();byte〔〕encryptDataencrypt(keyPair。getPublic(),不学无数);System。out。println(String。format(加密后的数据:s,base64Encode(encryptData)));System。out。println(String。format(解密后的数据:s,newString(decrypt(keyPair。getPrivate(),encryptData),UTF8)));Stringcontext加签的字符串;StringsignsignWithRSA(context,keyPair。getPrivate());System。out。println(String。format(生成的签名:s,sign));BooleancheckSignWithRSAcheckSignWithRSA(context,keyPair。getPublic(),sign);System。out。println(String。format(校验的结果:s,checkSignWithRSA。toString()));}
  输出为6YrYqd7fdastm443qQreRLxdQFScwvCvj9g1YnPzbU2QjIwqAPopTyPHNNngBmFkiR6V4DYtHA5gniaUMYzynHdDWx8ZYmwiuuS637wXqL36aLKe0H50wELOpSn45Gvni8u5zPIoHV7PBiztrCnQvne5LxFKDprrS3td176qyupFdUl3hsdgjbAyN2MlXcAFMrGVaRkopWwc9hP1BsPvS52q8jOVdbeyU9BziVhViz1V0TtGW8bfbEnIStc3Q解密后的数据:不学无数生成的签名:wvUXtr2UI0tUXmyMTTUBft8oc1dhvtXSBrFFetI5ZoxMm91TbXRWD31Pgqkg72ADxx9TEOAM3Bm1kyzfBCZZpoq6Y9SM4jdJ4sMTVtw0wACPglnPDAGs8sG7nnLhXWNQ1Y4pl4ziY6uLxF1TzQLFTxuNAS7nyljbG69wrb9R3Sv5t8r1I54rYCVGSVFmTrGfdSCjxABZv6mH8nygVif7zN1vU1nSDKcONVtrpv0xCQHVBqnHPA6OiDm5GzBQxjD5aQt8mfgv8JJrB52TEa4JPYoC5Zw4JHlLOvPwMpJgnuGyg5vnWhxE2ncTzMpZCnXF2DqvJMQOfX6tA校验的结果:true4摘要算法
  数据摘要算法是密码学算法中非常重要的一个分支,它通过对所有数据提取指纹信息以实现数据签名、数据完整性校验等功能,由于其不可逆性,有时候会被用做敏感信息的加密。数据摘要算法也被称为哈希(Hash)算法或散列算法。
  消息摘要算法的主要特征是加密过程不需要密钥,并且经过加密的数据无法被解密,只有输入相同的明文数据经过相同的消息摘要算法才能得到相同的密文。(摘要可以比方为指纹,消息摘要算法就是要得到文件的唯一职位)4。1特点
  无论输入的消息有多长,计算出来的消息摘要的长度总是固定的。一般地,只要输入的消息不同,对其进行摘要以后产生的摘要消息也必不相同;但相同的输入必会产生相同的输出。只能进行正向的信息摘要,而无法从摘要中恢复出任何的消息,甚至根本就找不到任何与原信息相关的信息(不可逆性)。
  好的摘要算法,没有人能从中找到碰撞或者说极度难找到,虽然碰撞是肯定存在的(碰撞即不同的内容产生相同的摘要)。4。2应用
  一般地,把对一个信息的摘要称为该消息的指纹或数字签名。数字签名是保证信息的完整性和不可否认性的方法。数据的完整性是指信宿接收到的消息一定是信源发送的信息,而中间绝无任何更改;信息的不可否认性是指信源不能否认曾经发送过的信息。其实,通过数字签名还能实现对信源的身份识别(认证),即确定信源是否是信宿意定的通信伙伴。数字签名应该具有唯一性,即不同的消息的签名是不一样的;同时还应具有不可伪造性,即不可能找到另一个消息,使其签名与已有的消息的签名一样;还应具有不可逆性,即无法根据签名还原被签名的消息的任何信息。这些特征恰恰都是消息摘要算法的特征,所以消息摘要算法适合作为数字签名算法。
  有哪些具体的消息摘要算法?
  CRC8、CRC16、CRC32:CRC(CyclicRedundancyCheck,循环冗余校验)算法出现时间较长,应用也十分广泛,尤其是通讯领域,现在应用最多的就是CRC32算法,它产生一个4字节(32位)的校验值,一般是以8位十六进制数,如FA12CD45等。CRC算法的优点在于简便、速度快,严格的来说,CRC更应该被称为数据校验算法,但其功能与数据摘要算法类似,因此也作为测试的可选算法。
  MD2、MD4、MD5:这是应用非常广泛的一个算法家族,尤其是MD5(MessageDigestAlgorithm5,消息摘要算法版本5),它由MD2、MD3、MD4发展而来,由RonRivest(RSA公司)在1992年提出,目前被广泛应用于数据完整性校验、数据(消息)摘要、数据加密等。MD2、MD4、MD5都产生16字节(128位)的校验值,一般用32位十六进制数表示。MD2的算法较慢但相对安全,MD4速度很快,但安全性下降,MD5比MD4更安全、速度更快。
  SHA1、SHA256、SHA384、SHA512:SHA(SecureHashAlgorithm)是由美国专门制定密码算法的标准机构美国国家标准技术研究院(NIST)制定的,SHA系列算法的摘要长度分别为:SHA为20字节(160位)、SHA256为32字节(256位)、SHA384为48字节(384位)、SHA512为64字节(512位),由于它产生的数据摘要的长度更长,因此更难以发生碰撞,因此也更为安全,它是未来数据摘要算法的发展方向。由于SHA系列算法的数据摘要长度较长,因此其运算速度与MD5相比,也相对较慢。
  RIPEMD、PANAMA、TIGER、ADLER32等:RIPEMD是HansDobbertin等3人在对MD4,MD5缺陷分析基础上,于1996年提出来的,有4个标准128、160、256和320,其对应输出长度分别为16字节、20字节、32字节和40字节。TIGER由Ross在1995年提出。Tiger号称是最快的Hash算法,专门为64位机器做了优化。4。3实战演练
  在单独的使用摘要算法时我们通常使用的MD5算法,所以我们这里就单独说明使用Java实现MD5算法。try{生成一个MD5加密计算摘要MessageDigestmdMessageDigest。getInstance(MD5);计算md5函数md。update(str。getBytes());digest()最后确定返回md5hash值,返回值为8为字符串。因为md5hash值是16位的hex值,实际上就是8位的字符BigInteger函数则将8位的字符串转换成16位hex值,用字符串来表示;得到字符串形式的hash值returnnewBigInteger(1,md。digest())。toString(16);}catch(Exceptione){thrownewException(MD5加密出现错误,e。toString());}}5参考文章
  https:zhuanlan。zhihu。comp20064358
  https:time。geekbang。orgcolumnarticle224701
  https:my。oschina。netOutOfMemoryblog3131916
  https:www。zznews。comcomzhongshanfengyunewsitemid67474。。。
  https:www。hbhncj。comarticle5334431。html
  https:www。zhihu。comquestion33645891

巨幕电视给你的视觉大餐,不得不说TCL98寸真香我们家之所以选择原木风的装修,是因为我喜欢安静,人多时候不爱说话喜欢宅在家里,看看自己想看的节目。因此在装修这个房子的时候,我希望未来自己有一个大而舒适的空间,在这个空间里有绿……卡塔尔世界杯32强巡礼突尼斯队小组鱼腩渴望突围新华社北京11月8日电(记者许仕豪)对已经参加过五届世界杯正赛、却从未涉足过淘汰赛阶段的突尼斯队来说,本届卡塔尔世界杯似乎又将是一次充满荆棘的旅程。2018年6月28日,……新十条后的首个小长假开启,今晚你在哪儿跨年?2023年元旦假期开启,作为新十条发布后的首个小长假,人们会去哪里旅行?新京报贝壳财经记者从多家在线旅行平台获悉,这个元旦假期,虽然多数游客仍将出行目光集中在本地及周边,但长线……男性事后腰痛,难道是用力过度了?这5点诱因才是主谋生活中有部分男性腰部有疼痛感,多发生在夫妻生活结束后,有这种情况可要找出原因。大多数人都会觉得是用力过猛,在同房时没有注意姿势,动作恰当,太过用力时伤害到腰椎,因此才会疼痛。虽……二手路虎揽胜运动新能源,四年贬值50万,图便宜能买么?想开路虎,还想省油更想省钱?说真的,路虎和后面两项基本上不沾边,但在它推出了插混车型之后,开始能稍微对油耗做出一些改善了,但距离省钱还是有一定距离。或许我们能从二手车市场……战战兢兢逛岘港岘港掠影我的航海日志这样记载:现在,船已经驶离中国东海,穿越巴士海峡,从台湾宝岛的东面进入祖国的南海。路过东沙群岛,从南海的西沙群岛、中沙群岛之间驶过,大约两天后到达第一……每天坚持喝酸奶和纯牛奶哪个对身体好?从营养角度来说,纯牛奶和酸奶都很好。不过从实际生活看,重点在你怎么选。1。纯牛奶和酸奶的营养价值在哪里?首先,咱们得搞明白乳制品到底可以带给你啥?膳食指南建议……洛阳52家A级旅游景区1月面向全国人民限量免门票中新网12月27日电据洛阳旅游公众号28日消息,2023年1月1日至1月31日,洛阳市52家A级旅游景区面向全国人民限量免门票。文章指出,洛阳市财政将筹集资金发放1000……每日邮报作妖了,伊朗官方直接出手实锤,连网友都看不下去了卡塔尔世界杯即将进入尾声,当人们都在关注阿根廷是否能够夺冠时,以《每日邮报》为代表的西方多家媒体于13日报道:伊朗球员阿米尔纳斯尔阿扎达尼因支持女性被处以死刑。外媒报道截……工业级手持式条码扫描器怎么选?这篇文章告诉你手持式条码扫描器是一种可用于读取条码中所包含信息内容的扫描设备,利用光学原理,把条码的内容经过解码后通过数据线或者无线方式传输到电脑或者其他设备中,是继键盘和鼠标之后的第三代主……冬天适合吃豆子,应该吃绿豆还是红豆?别再吃错了,早了解早受益进入冬天,各种滋补美食轮番登场。但人们容易忽略冬天空气干燥,身体循环较慢,很多看似大补的食物食用后不仅不能吸收其中的营养,还会加重身体负担,得不偿失。冬天进补有讲究,老话……腾讯再战社交,瞄准年轻人在中国互联网世界,腾讯是绕不开的一座大山,社交正是它的根基之一。最近,腾讯又上线了一款新社交产品喵更,该产品面向年轻化潮流表达社区,用户可围绕词热梗百科、句语录创作、图表情ME……
方便!昆明至罗次城际客运线开通,泡温泉走起!来源:【昆明日报掌上春城】爱泡温泉的朋友们,对禄丰罗次温泉肯定不陌生。今年1月23日,罗次温泉至昆明眠山车场新能源城际公交客运专线开通,昆明至罗次,从早上8点到晚上7点,……哥伦比亚主帅日韩的水平都非常高,韩国更具攻击性ampampa直播吧3月28日讯北京时间3月28日晚间进行的麒麟杯比赛中,哥伦比亚客场21击败日本队。赛后,哥伦比亚主帅洛伦佐出席了新闻发布会。点评比赛认为今天是一场非常精彩的高……四种能力,拥抱AI的挑战EMPATHYchatGPT的崛起,再次把人工智能的热度推到了顶点,也把未来的不确定以更直接的方式,呈现在我们眼前。但我依然相信一句话:知识因人而来。解决一个难题,固然需……记者带您看西安走进鄠邑区第三站蔡家坡2023hr记者带您看西安走进鄠邑区蔡家坡项目概况蔡家坡村是镇村改革后由原蔡家坡村、新兴村、马家河村、曲峪河村、潭峪河村5个村合并而成,位于鄠邑区石井镇……酃声逐梦她经济炎陵县开展首场女企业家联谊活动红网时刻新闻3月24日讯(通讯员潘巧妙)为进一步优化营商环境,帮助女性创新创业,切实助力女性创业者成长,3月22日,炎陵县开展酃声逐梦她经济女企业家首场联谊活动。县委常委、常务……中国因私护照为什么排名这么低?中国因私护照在全球的排名一直较低,主要是因为几个方面的原因。首先,中国因私护照的签证政策相对保守,对于持有中国护照的人员,需要办理签证才能进入许多国家。这意味着,中国因私护照持……京东百亿补贴杀敌八百,自损一千?产业快评随着京东的百亿补贴正式上线,舆论对中国电商行业可能出现的新战役又开始翘首以盼。诚然,以京东在目前中国电商领域中的江湖地位,投入百亿补贴直指另一巨头拼多多的腹地,从目的性而言,如……林心如的痛隐退5年,网友仍对她骂声一片,她到底做错了啥?林心如可谓是风波不断,她人虽然不在内娱,但内娱从来不缺她的瓜。前不久,网上突然爆出林心如今年会亮相内地某综艺,不是《中餐厅》,就是《向往的生活》,虽然消息还不确定,……(外代二线)巴黎时装周AcneStudios品牌时装秀(外代二线)巴黎时装周AcneStudios品牌时装秀3月1日,模特在法国巴黎时装周上展示AcneStudios品牌的20232024秋冬新款服装。新华社欧新3月1……今年一季度房企到期债券规模2225亿元,融资环境或将进一步改自2022年11月以来,支持房企融资的政策不断,房企能否真正走出低谷期,关键在于融资。1月23日,据克而瑞研究中心发布的报告,进入2023年,房企融资端支持政策还在不断释……唯一一支高校志愿者队伍!549名深大学子为深马护航读特客户端深圳新闻网2023年2月20日讯(深圳特区报首席记者焦子宇通讯员熊苗王进)2月19日凌晨3点,549名深大学子在校门口集合完毕,坐上了开往深马起点站市民中心的大巴,开……人工智能领域的真相中国技术被美国打败?人工智能是当前世界上最先进的科技领域之一,它涵盖了计算机视觉、自然语言处理、机器学习、深度学习等多个领域,对于人类社会和生活有着极大的影响和价值。然而,在这个领域中,中国和美国……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网