当前位置: 首页 > news >正文

家如何网站天眼

家如何网站,天眼,上海建企业网站,网上商城图片一、AES算法 AES是一种对称加密算法,算法秘钥长度可为128位(16字节)、192位(24字节)、256位(32字节)。加密模式分为ECB、CBC、CTR等,其中ECB模式最简单够用。现给出ECB模式下C和Java的实现,并且可以相互加解密验证。 二、AES_ECB实现DEMO …

一、AES算法

AES是一种对称加密算法,算法秘钥长度可为128位(16字节)、192位(24字节)、256位(32字节)。加密模式分为ECB、CBC、CTR等,其中ECB模式最简单够用。现给出ECB模式下C++和Java的实现,并且可以相互加解密验证。

二、AES_ECB实现DEMO

2.1 C++版本

#include <string>
#include <vector>
#include <openssl/evp.h>EVP_CIPHER *getAlgPoint(const int keyLen){EVP_CIPHER *pAlg = nullptr;if (keyLen <= 16) {pAlg = (EVP_CIPHER *)EVP_aes_128_ecb();}else if (keyLen >16 && keyLen <= 24) {pAlg = (EVP_CIPHER *)EVP_aes_192_ecb();}else{pAlg = (EVP_CIPHER *)EVP_aes_256_ecb();}return pAlg;
}std::vector<uint8_t> ecbEncrypt(const std::string &key, const std::string &str){if (key.empty() || str.empty()) {return {};}int encLen = 0;int outlen = 0;EVP_CIPHER_CTX* ctx = EVP_CIPHER_CTX_new();std::vector<uint8_t > encData(((str.size()/16)+1) * 16);//加密后的长度是16的整数倍,明文刚好16整数倍则密文是明文长度+16字节EVP_CipherInit_ex(ctx, getAlgPoint(key.size()), nullptr, (uint8_t*)key.data(), nullptr, 1);EVP_CipherUpdate(ctx, encData.data(), &outlen, (const uint8_t *)str.c_str(), (int)str.size());encLen = outlen;EVP_CipherFinal_ex(ctx, encData.data() + outlen, &outlen);encLen += outlen;EVP_CIPHER_CTX_free(ctx);encData.resize(encLen);return encData;
}std::string ecbDecrypt(const std::string &key, const std::vector<uint8_t> &str){if (key.empty() || str.empty()) {return "";}int decLen = 0;int outlen = 0;EVP_CIPHER_CTX* ctx = EVP_CIPHER_CTX_new();std::vector<uint8_t > decData(str.size());EVP_CipherInit_ex(ctx, getAlgPoint(key.size()), nullptr, (uint8_t*)key.data(), nullptr, 0);EVP_CipherUpdate(ctx, decData.data(), &outlen, str.data(), (int)str.size());decLen = outlen;EVP_CipherFinal(ctx, decData.data() + outlen, &outlen);decLen += outlen;EVP_CIPHER_CTX_free(ctx);decData.resize(decLen);return std::string((char*)decData.data(), decData.size());
}int main(void){std::string tKey32 = "12345678901234567890123456789012";std::string tSrcMsg = "Hello World!";auto byteEnc = ecbEncrypt(tKey32, tSrcMsg);auto b64Enc = B64::encode(byteEnc.data(), byteEnc.size());//转base64打印加密后的内容, b64转换函数自己实现std::cout<<"b64Enc:" << b64Enc <<std::endl;auto strDec = ecbDecrypt(tKey32, byteEnc);std::cout<<"decMsg:"<< strDec<<std::endl;return 0;}
  • demo运行结果
b64Enc:wC/nIjhaktigwT5VfVYXKA==
decMsg:Hello World!

2.2 Java版本

  • AESUtil.java
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;public class AESUtil {private static final String ALGORITHM = "AES";private static final String TRANSFORMATION = "AES/ECB/PKCS5Padding";public static String encrypt(String plainText, String key) throws Exception{SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), ALGORITHM);Cipher cipher = Cipher.getInstance(TRANSFORMATION);cipher.init(Cipher.ENCRYPT_MODE, secretKey);byte[] eBytes = cipher.doFinal(plainText.getBytes(StandardCharsets.UTF_8));return Base64.getEncoder().encodeToString(eBytes);}public static String decrypt(String encryptedText, String key) throws Exception{SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), ALGORITHM);Cipher cipher = Cipher.getInstance(TRANSFORMATION);cipher.init(Cipher.DECRYPT_MODE, secretKey);byte[] dBytes = cipher.doFinal(Base64.getDecoder().decode(encryptedText));return new String(dBytes, StandardCharsets.UTF_8);}
}
  • Main.java
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.security.NoSuchAlgorithmException;public class Main {public static void main(String[] args) throws Exception {String strkey = "12345678901234567890123456789012";String str = "Hello World!";String eStr = AESUtil.encrypt(str, strkey);System.out.println("aes256 eStr:" + eStr);String dStr = AESUtil.decrypt(eStr, strkey);System.out.println("aes256 dStr:" + dStr);}
}
  • demo运行结果
aes256 eStr:wC/nIjhaktigwT5VfVYXKA==
aes256 dStr:Hello World!

C++与Java的运行结果一致,如果测试128、192位秘钥,只用修改main函数中的秘钥长度,其他部分不用改动。

http://www.yayakq.cn/news/726879/

相关文章:

  • 容桂免费网站建设公司软文广告经典案例100字
  • 信宜网站建设百度广告收费标准
  • 网站备案抽查上海史特网站建设
  • 网站设计需求文档范例做网站一般多少钱
  • 网站建设软件定制开发网上房地产官方网
  • 那些网站可以做信息推广帝国cms网站搬家教程
  • 网站优化师负责干什么新增网站推广
  • 手机网站开发软件下载网站后台模板如何使用
  • 自己的网站怎么推广wordpress 改语言设置
  • 宁津县建设局网站龙岩天宫山住宿怎么订
  • 建筑行业做网站南京营销型网站
  • 在公司网站建设会议上的汇报常见网站推广方式
  • 手机访问跳转手机网站小程序免费制作平台二维码筛选
  • 权重高的博客网站移动互联网应用范围具有以下特点
  • 重庆网站建设哪家公司哪家好详情页怎么设计
  • 新余专业做淘宝网站网站建站上海
  • 济南模板网站在线制作图片拼接
  • 微信做淘宝客网站有哪些中国最新军事新闻 头条 今天
  • 凡科网站怎么样项目总结
  • 政务网站建设工作计划北京网站建设知名公司
  • seo外链工具下载seo网络优化公司
  • 公司设计一个网站需要多久纵横网站建立
  • 铜川北京网站建设温州网站设计案例
  • 域名等于网站网址吗商标交易
  • iis 浏览网站创意礼品私人定制
  • 手机版网站怎么做wordpress用户数据备份
  • 平邑县门户网站做网站搭建环境
  • 购物网站前台功能模块分析劳力士手表网站
  • 网站怎样做银联支付dede音乐网站
  • 安徽 两学一做 网站昆明网站建设方案优化