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

网站建设推广费用网站开发 需求

网站建设推广费用,网站开发 需求,大学网站建设技术方案,环保网站建设公司排名1,业务需要,对方需要用java进行参数加密,双方约定使用的加密方法是 SM4,对方给的key是32位,并且给出了加解密的java代码。 import org.bouncycastle.jce.provider.BouncyCastleProvider; import java.security.Key; i…

1,业务需要,对方需要用java进行参数加密,双方约定使用的加密方法是 SM4,对方给的key是32位,并且给出了加解密的java代码。

import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.SecureRandom;
import java.security.Security;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.spec.SecretKeySpec;
import org.bouncycastle.pqc.math.linearalgebra.ByteUtils;/*** sm4加密算法工具类*/
public class SM4Util {static {Security.addProvider(new BouncyCastleProvider());}private static final String ENCODING = "UTF-8";public static final String ALGORITHM_NAME = "SM4";// 加密算法/分组加密模式/分组填充方式// PKCS5Padding-以8个字节为一组进行分组加密// 定义分组加密模式使用:PKCS5Paddingpublic static final String ALGORITHM_NAME_ECB_PADDING = "SM4/ECB/PKCS5Padding";// 128-32位16进制;256-64位16进制public static final int DEFAULT_KEY_SIZE = 128;/*** 生成ECB暗号* @explain ECB模式(电子密码本模式:Electronic codebook)* @param algorithmName*            算法名称* @param mode*            模式* @param key* @return* @throws Exception*/private static Cipher generateEcbCipher(String algorithmName, int mode, byte[] key) throws Exception {Cipher cipher = Cipher.getInstance(algorithmName, BouncyCastleProvider.PROVIDER_NAME);Key sm4Key = new SecretKeySpec(key, ALGORITHM_NAME);cipher.init(mode, sm4Key);return cipher;}/*** 自动生成密钥* @explain* @return* @throws NoSuchAlgorithmException* @throws NoSuchProviderException*/public static String generateKey() throws Exception {return generateKey(DEFAULT_KEY_SIZE);}/*** @explain* @param keySize* @return* @throws Exception*/public static String generateKey(int keySize) throws Exception {KeyGenerator kg = KeyGenerator.getInstance(ALGORITHM_NAME, BouncyCastleProvider.PROVIDER_NAME);kg.init(keySize, new SecureRandom());return ByteUtils.toHexString(kg.generateKey().getEncoded());}/*** sm4加密* @explain 加密模式:ECB*          密文长度不固定,会随着被加密字符串长度的变化而变化* @param hexKey*            16进制密钥(忽略大小写)* @param paramStr*            待加密字符串* @return 返回16进制的加密字符串* @throws Exception*/public static String encryptEcb(String hexKey, String paramStr) throws Exception {String cipherText = "";// 16进制字符串-->byte[]byte[] keyData = ByteUtils.fromHexString(hexKey);// String-->byte[]byte[] srcData = paramStr.getBytes(ENCODING);// 加密后的数组byte[] cipherArray = encryptEcbPadding(keyData, srcData);// byte[]-->hexStringcipherText = ByteUtils.toHexString(cipherArray);return cipherText;}/*** 加密模式之Ecb* @explain* @param key* @param data* @return* @throws Exception*/public static byte[] encryptEcbPadding(byte[] key, byte[] data) throws Exception {Cipher cipher = generateEcbCipher(ALGORITHM_NAME_ECB_PADDING, Cipher.ENCRYPT_MODE, key);return cipher.doFinal(data);}/*** sm4解密* @explain 解密模式:采用ECB* @param hexKey*            16进制密钥* @param cipherText*            16进制的加密字符串(忽略大小写)* @return 解密后的字符串* @throws Exception*/public static String decryptEcb(String hexKey, String cipherText) throws Exception {// 用于接收解密后的字符串String decryptStr = "";// hexString-->byte[]byte[] keyData = ByteUtils.fromHexString(hexKey);// hexString-->byte[]byte[] cipherData = ByteUtils.fromHexString(cipherText);// 解密byte[] srcData = decryptEcbPadding(keyData, cipherData);// byte[]-->StringdecryptStr = new String(srcData, ENCODING);return decryptStr;}/*** 解密* @explain* @param key* @param cipherText* @return* @throws Exception*/public static byte[] decryptEcbPadding(byte[] key, byte[] cipherText) throws Exception {Cipher cipher = generateEcbCipher(ALGORITHM_NAME_ECB_PADDING, Cipher.DECRYPT_MODE, key);return cipher.doFinal(cipherText);}public static void main(String[] args) {try {String generateKey = SM4Util.generateKey();System.out.println(generateKey);String json = "mate60 nb";// 自定义的32位16进制密钥String key = "2c1f9b9388c5fc713c5ceab2af6f0f2d";String encrypted = SM4Util.encryptEcb(key, json);System.out.println(encrypted);json = SM4Util.decryptEcb(key, encrypted);System.out.println(json);} catch (Exception e) {e.printStackTrace();}}
}

2,这边用的后台程序python+flask只能用python去解密,先使用pysm4

from pysm4 import encrypt_ecb, decrypt_ecb
plain_text = '13800138000'
key = '86C63*80C2806E*1F47B8*9DE501215*'
cipher_text = encrypt_ecb(plain_text, key)plain_text == decrypt_ecb(cipher_text, key)

报  Parameter key or iv:********* byte greater than 16的错误,应该是有个地方配置key的长度。

3,但是对方也只能支持32位的方法,所以只能换方法,测试了一下,下面python方法可以完美支持32位,并且测试和java加密,python解密后也相同。

python实现sm4,ecb模式加密_python sm4_pchaoda的博客-CSDN博客

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

相关文章:

  • 公司的网站建设与维护诸城 网站 建设
  • 有免费的微网站制作吗公司网站建设怎么做
  • 学网站开发多久营销型网站开发方案
  • 阜宁网站制作价格四个常见的网络营销方式
  • 建网站的详细案例福州网站建设找时时在网络
  • 哪些网站权重高三端互通传奇手游开服列表
  • 网站怎样快速排名苏州市建设人才网官方网站
  • 网站分为哪几种类型大型网站后台登录地址一般是如何设置的
  • 仿阿里百秀网站模板南宁网站开发培训
  • 怎么查找网站建设营销中存在的问题及对策
  • 网站设计 版权wordpress播放记时插件
  • 互助平台网站制作徐州网站设计
  • 建站公司常见提成比例商品展示类网站
  • 免费解析网站手机会员卡管理系统
  • 热门网站排名宁波建设厅网站
  • 个人的小说网站如何做如何在网站做推广
  • 物流企业网站建设特色工信部网站黑名单查询
  • 网站内部优化工具wordpress为什么感觉加载慢
  • 整合式营销长沙企业seo服务
  • 签订网站建设协议应注意事项网站建设与设计试题
  • 广东专业做网站广告设计图案
  • 网站和app的区别模板网站与定制网站的区别
  • 前端网站怎么做qq登录网页版登录入口
  • django网站开发视频qq网页登录入口
  • 全屏 网站 代码单位网站建设维护论文
  • html网页制作网站p2p金融网站建设
  • 网站里自动切换图片怎么做工程造价信息网南京
  • 网站开发js不更新亚洲电视全球运营中心
  • 做网站设计的电脑需要什么配置阿里云wordpress
  • 成都市建设领域网站咨询电话大沥网站建设公司