亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何將 Java AES - CBC 與 PKCS5 填充更改為 PHP

如何將 Java AES - CBC 與 PKCS5 填充更改為 PHP

蝴蝶刀刀 2022-05-21 16:53:57
我正在嘗試將 JAVA 加密更改為 PHP 并產生完全相同的結果。我有以下準則。AES - CBC 與 PKCS5 填充對稱加密方案:加密密鑰大小為 128 位大小。初始化向量(IV):-新的隨機 IV 將在每個請求中使用。-在單個 Web 服務請求中,在加密所有加密字段時將使用相同的 IV。-此 IV 將在名稱為“IV”的 SOAP Header 中傳遞。IV 值將采用 Base64 編碼。我試過這個https://gist.github.com/thomasdarimont/fae409eaae2abcf83bd6633b961e7f00public class AESEncryptionUtil {public static final String CLASS_NAME = AESEncryptionUtil.class.getName(); private static final int KEY_SIZE = 16;private static final String ALGORITHM_AES = "AES";public final static String ALGORITHM_AES_CBC = "AES/CBC/PKCS5Padding";private static Key generateKey(String keyValue) throws Exception { Key key = null ;if (keyValue!=null && keyValue.length()==KEY_SIZE){byte[] byteKey = keyValue.substring(0, KEY_SIZE).getBytes("UTF-8");  key = new SecretKeySpec(byteKey, ALGORITHM_AES);}else{System.out.println("Not generating the Key!! "+keyValue); }return key; }/*** Return Base64 Encoded value of IV ** @param keyValue * @return* @throws Exception */public static String generateIV(String keyValue) throws Exception { String iv = null ;Key key = generateKey(keyValue); if (key!=null){Cipher cipher = Cipher.getInstance(ALGORITHM_AES_CBC); cipher.init(Cipher.ENCRYPT_MODE, key); AlgorithmParameters params =     cipher.getParameters();iv = new BASE64Encoder().encode(params.getParameterSpec(IvParameterSpec.class).getIV());  }else{System.out.println("No IV generated ...");}return iv; }/*** Method to perform encryption of given data with AES Algorithm / Key and IV. * @param encKey -*Encryption Key value * @param plainVal -*Value to be encrypted * @return - encrypted String Value * @throws   Exception*/
查看完整描述

1 回答

?
揚帆大魚

TA貢獻1799條經驗 獲得超9個贊

我設法得到一些工作


<?php

$string = "online1234";

$key = "haskingvista127$";


$iv  = base64_encode(openssl_random_pseudo_bytes(openssl_cipher_iv_length('aes-128-cbc')));


$encodedEncryptedData = base64_encode(openssl_encrypt($string, "AES-128-CBC", $key, OPENSSL_RAW_DATA, base64_decode($iv)));


$decryptedData = openssl_decrypt(base64_decode($encodedEncryptedData), "AES-128-CBC", $key, OPENSSL_RAW_DATA, base64_decode($iv));


?>

希望這可以幫助別人


查看完整回答
反對 回復 2022-05-21
  • 1 回答
  • 0 關注
  • 193 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號