关于加密和解密 -- 1

在对文件进行加密处理中,主要分为两种加密方式,对称加密和公钥加密,常用的对称加密:DES, 3DES, AES128,AES256,公钥加密:RSA。

使用公钥加密能够进行身份验证以及具有不可否认性,但该加密过程相比对称加密要慢很多,而对称加密速度较快,但存在密钥分配问题,所以在通常的加密处理过程中采用的方式为: 使用对称加密对文件进行加密,使用公钥加密对对称密钥进行加密,以保证密钥安全分配。

示例:

加密:

生成AES128密钥 ---->  公钥秘钥对AES128密钥加密 ----> 转化为Base64 保存到PEM文件中;

使用AES128密钥对明文加密 ---- >  转化为Base64 保存到PEM文件中;

解密:

转化Base64编码 ----> 私钥解密AES128 密钥;

使用AES128密钥对密文解密。

(1)使用RSA加密

RSA* gRSApubKey = RSA_new();

REM_read_RSA_PUBKEY(pubKeyFile, & gRSApubKey, 0,0);  // 读取公钥

RSA_public_encrypt( src_data_len,  src_data, encrypt_Data,  gRSApubKey,  RSA_PKCS1_PADDING);  // 对src_data加密保存到encrypt_Data中;

RSA_free(gRSApubKey);

(2)使用RSA解密

RSA* gRSApriKey = RSA_new();

PEM_read_RSAPrivateKey(priKeyFile, &gRSApriKey, 0, 0) ; // 读取私钥

RSA_private_decrypt(src_data_len, src_data, decrypt_Data, gRSApriKey, RSA_PKCS1_PADDING); // 解密src_data

RSA_free(gRSApriKey);

(3)AES加密

生成随机数作为密钥 key; 生成随机数作为初始化矢量 Arr;

AES_KEY aes;

AES_set_encrypt_key( key, size, &aes); // 读取密钥, size=128或256,密钥长度(AES128或AES256加密);

AES_cbc_encrypt( srcData,desData,srcData_len, &aes, Arr, AES_ENCRYPT);//将srcData加密保存到desData中

(4)AES解密

获取key及 Arr

AES_KEY aes;

AES_set_decrypt_key(key, size, &aes);

AES_cbc_encrypt(srcData, desData, srcData_len, &aes, Arr, AES_DECRYPT); // 解密srcData中的数据到desData中。


 


java加密解密 function encrypt(str, pwd) { if(pwd == null || pwd.length <= 0) { alert("Please enter a password with which to encrypt the message."); return null; } var prand = ""; for(var i=0; i<pwd.length; i++) { prand += pwd.charCodeAt(i).toString(); } var sPos = Math.floor(prand.length / 5); var mult = parseInt(prand.charAt(sPos) + prand.charAt(sPos*2) + prand.charAt(sPos*3) + prand.charAt(sPos*4) + prand.charAt(sPos*5)); var incr = Math.ceil(pwd.length / 2); var modu = Math.pow(2, 31) - 1; if(mult 10) { prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString(); } prand = (mult * prand + incr) % modu; var enc_chr = ""; var enc_str = ""; for(var i=0; i<str.length; i++) { enc_chr = parseInt(str.charCodeAt(i) ^ Math.floor((prand / modu) * 255)); if(enc_chr < 16) { enc_str += "0" + enc_chr.toString(16); } else enc_str += enc_chr.toString(16); prand = (mult * prand + incr) % modu; } salt = salt.toString(16); while(salt.length < 8)salt = "0" + salt; enc_str += salt; return enc_str; } function decrypt(str, pwd) { if(str == null || str.length < 8) { alert("A salt value could not be extracted from the encrypted message because it's length is too short. The message cannot be decrypted."); return; } if(pwd == null || pwd.length <= 0) { alert("Please enter a password with which to decrypt the message."); return; } var prand = ""; for(var i=0; i 10) { prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString(); } prand = (mult * prand + incr) % modu; var enc_chr = ""; var enc_str = ""; for(var i=0; i<str.length; i+=2) { enc_chr = parseInt(parseInt(str.substring(i, i+2), 16) ^ Math.floor((prand / modu) * 255)); enc_str += String.fromCharCode(enc_chr); prand = (mult * prand + incr) % modu; } return enc_str; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值