网站大量收购闲置独家精品文档,联系QQ:2885784924

网络空间安全概论 实验1加密 加密解密.docx

网络空间安全概论 实验1加密 加密解密.docx

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

balala11 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档