Ich möchte eine Verschlüsselungsklasse in Java mit PHP schreiben, aber ich habe diese Art, sie in Java zu schreiben, gesehen und sie bereitete mir große Kopfschmerzen. Völlig unlogisch. Ich habe eine vollständige Klasse gefunden und wollte darauf verweisen. Nach vielen Experimenten konnte ich die von mir hochgeladene Verschlüsselungsklasse nicht in PHP übersetzen. Bitte hilf mir. Danke.
/**
3Des-Hilfsklasse
*/
öffentliche Klasse ThreeDESUtil {
private static final String Algorithm = "DESede"; // 定义 加密算法,可用
// DES,DESede,Blowfish
private static byte[] keybyte = { 0x11, 0x28, 0x4F, 0x58, (byte) 0x88,
0x10, 0x40, 0x38, 0x28, 0x25, 0x79, 0x51, (byte) 0xCB, (byte) 0xDD,
0x55, 0x66, 0x77, 0x29, 0x74, (byte) 0x98, 0x30, 0x40, 0x36,
(byte) 0xE2 }; // 24字节的密钥
public static String encryptMode(String src) {
String encrypt = null;
try {
byte[] ret = encryptMode(src.getBytes("UTF-8"));
encrypt = new String(Base64.encode(ret));
encrypt = encrypt.replaceAll("=", "Q");
} catch (Exception e) {
logger.error("ThreeDES Error");
}
return encrypt;
}
/**
* 加密
*
* @param src
* @return
*/
private static byte[] encryptMode(byte[] src) {
try {
// 生成密钥
SecretKey deskey = new SecretKeySpec(keybyte, Algorithm);
// 加密
Cipher c1 = Cipher.getInstance(Algorithm);
c1.init(Cipher.ENCRYPT_MODE, deskey);
return c1.doFinal(src);
} catch (Exception e) {
logger.error("ThreeDES Error");
}
return null;
}
// for test
public static void main(String[] args) {
String szSrc = "12345678";
String encoded = encryptMode(szSrc);
System.out.println("加密后的字符串:" + encoded);
//1xZ9Hssih5z0pegyf7aUcgQQ
}
}
Das Obige ist die Java-Klasse, die ich in PHP konvertieren muss,
Im Anhang finden Sie den Referenzartikel unten
/q/10...
Das Folgende ist der PHP-Code, den ich nach Referenz geschrieben habe.
<?php
$EasyCrypt3Des = new EasyCrypt3Des();
echo $EasyCrypt3Des->encrypt('12345678');
//java 结果 '1xZ9Hssih5z0pegyf7aUcgQQ';
exit;
class EasyCrypt3Des {
private $_key = array("0x11", "0x28", "0x4F", "0x58", "0x88", "0x10", "0x40", "0x38", "0x28", "0x25", "0x79", "0x51","0xCB", "0xDD", "0x55", "0x66", "0x77", "0x29", "0x74", "0x98", "0x30", "0x40", "0x36", "0xE2");
private $keyStr = "";
public function __construct() {
foreach($this->_key as $keyItem) {
$this->keyStr .= $this->hexToStr($keyItem);
}
}
public function encrypt($str) {
$td = $this->gettd();
$ret = mcrypt_generic($td,$str);
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
$result = base64_encode($ret);
return str_replace('=','Q',$result);
}
private function getiv() {
return pack('H16','0000000000000000');
}
private function gettd() {
$iv = $this->getiv();
$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_ECB, '');
mcrypt_generic_init($td, $this->keyStr,$iv);
return $td;
}
private function hexToStr($hex){
$string='';
for ($i=0; $i < strlen($hex)-1; $i+=2){
$string .= chr(hexdec($hex[$i].$hex[$i+1]));
}
return $string;
}
}
问题已得到解决,还是参考之前的文章:
1、加密后的字符未进行字符转换,所以无法进行解密,缺少一个步骤。
2、参考我发的文章链接,PHP类完全通用。可忽略我之前发布的代码,我会再整理一份对的。
java
import java.security.Security;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
public class ThreeDES {
private static final String Algorithm = "DESede"; //定义 加密算法,可用 DES,DESede,Blowfish
}
以上代码完全取至 /q/10... 中
以下是PHP代码。
<?php
class EasyCrypt3Des {
}
$EasyCrypt3Des = new EasyCrypt3Des();
$code = $EasyCrypt3Des->encrypt('12345678');
echo $code .'<br/>';
echo $EasyCrypt3Des->decrypt($code);
exit;
主要在于字符转换这块。