- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
数据加密解密与口令认证
凯撒\t/qqarticle/details/_blank加密与解密
恺撒密码的加密、解密方法还能够通过同余的数学方法进行计算。首先将字母用数字代替,A=0,B=1,…,Z=25。此时偏移量为n的加密方法即为:En(x)=(x+n)mod26;
解密就是:Dn(x)=(x-n)mod26;
对称加密:采用了对称密码编码技术,它的特点是文件加密和解密使用相同的密钥加密,也就是密钥也可以用作解密密钥,这种方法在密码学中叫做对称加密算法,对称加密算法使用起来简单快捷,密钥较短,且破译困难,除了数据加密标准(DES)。
非对称加密算法:需要两个密钥:公开密钥(publickey:简称公钥)和私有密钥(privatekey:简称私钥)。公钥与私钥是一对,如果用公钥对数据进行加密,只有用对应的私钥才能解密。、
ECB加密解密函数
importjavax.crypto.Cipher;
importjavax.crypto.spec.SecretKeySpec;
importmons.codec.binary.Base64;
/**
*
*@authorcwy
*
*/
publicclassAESUtils{
//加密
publicstaticStringEncrypt(StringsSrc,StringsKey)throwsException{
if(sKey==null){
returnnull;
}
byte[]raw=sKey.getBytes(utf-8);
SecretKeySpecskeySpec=newSecretKeySpec(raw,AES);
Ciphercipher=Cipher.getInstance(AES/ECB/PKCS5Padding);//算法/模式/补码方式cipher.init(Cipher.ENCRYPT_MODE,skeySpec);
cipher.init(Cipher.ENCRYPT_MODE,skeySpec);
byte[]encrypted=cipher.doFinal(sSrc.getBytes(utf-8));
returnnewString(Base64.encodeBase64(encrypted));//此处使用BASE64做转码功能,同时能起到2次加密的作用。
}
//解密
publicstaticStringDecrypt(StringsSrc,StringsKey)throwsException{
try{
//判断Key是否正确
if(sKey==null){
returnnull;
}
byte[]raw=sKey.getBytes(utf-8);
SecretKeySpecskeySpec=newSecretKeySpec(raw,AES);
Ciphercipher=Cipher.getInstance(AES/ECB/PKCS5Padding);
cipher.init(Cipher.DECRYPT_MODE,skeySpec);
byte[]encrypted1=Base64.decodeBase64(sSrc.getBytes());//先用base64解密
try{
byte[]original=cipher.doFinal(encrypted1);
StringoriginalString=newString(original,utf-8);returnoriginalString;
}catch(Exceptione){
System.out.println(e.toString());returnnull;
}
}catch(Exceptionex){
System.out.println(ex.toString());
returnnull;
}
}
publicstaticvoidmain(String[]args)throwsException{
/*
*此处使用AES-128-ECB加密模式,key需要为16位。
*/
StringcKey=1234567891012345;
//需要加密的字串
StringenString=AESUtils.Encrypt(HelloWorld,cKey);
System.out.println(加密后的字串是:+enString);
}
}
口令认证
口令是接枚双方预先约定的秘密数据,它用来验证用户知道什么。口令验证的安
文档评论(0)