Heim > Backend-Entwicklung > PHP-Tutorial > java AES转成php版本 求大神看看哪里出问题

java AES转成php版本 求大神看看哪里出问题

WBOY
Freigeben: 2016-06-06 20:13:35
Original
1027 Leute haben es durchsucht

java类转成php版本,麻烦大神看一下php版本哪里问题
73C58BAFE578C59366D8C995CD0B9D6D
test

<code>import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;

import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;

public class AESUtil {
    
    
      public static void main(String[] args){
    //    System.out.println("Hello,it's:");
          String content="test";
          String password="12345678";
         String estr =  encrypt(content, password);
        System.out.println(estr);
        System.out.println(decrypt(estr, password));
    
    }

        /**将16进制转换为二进制
       * @param hexStr
       * @return
       */

     public static byte[] parseHexStr2Byte(String hexStr) {

      if (hexStr.length() </code>
Nach dem Login kopieren
Nach dem Login kopieren
<code>php版本自己写了</code>
Nach dem Login kopieren
Nach dem Login kopieren
<code><?php class Security {
    public static function encrypt($input, $key) {
        $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
        $input = Security::pkcs5_pad($input, $size);
        $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');
        $iv = mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
        mcrypt_generic_init($td, $key, $iv);
        $data = mcrypt_generic($td, $input);
        mcrypt_generic_deinit($td);
        mcrypt_module_close($td);
        $data = bin2hex($data);
        return $data;
    }
 
    private static function pkcs5_pad ($text, $blocksize) {
        $pad = $blocksize - (strlen($text) % $blocksize);
        return $text . str_repeat(chr($pad), $pad);
    }
 
    public static function decrypt($sStr, $sKey) {
            $decrypted= mcrypt_decrypt(
            MCRYPT_RIJNDAEL_128,
            $sKey,
            Security::hexToStr($sStr),
            MCRYPT_MODE_ECB
            );
     
        $dec_s = strlen($decrypted);
        $padding = ord($decrypted[$dec_s-1]);
        $decrypted = substr($decrypted, 0, -$padding);
        return $decrypted;
    }

         //16进制的转为2进制字符串      
    public static function hexToStr($hex)       
    {       
        $bin="";       
        for($i=0; $i<strlen($hex)-1; $i+=2)       
        {      
            $bin.=chr(hexdec($hex[$i].$hex[$i+1]));       
        }      
        return $bin;       
    }
 
}

 
$key = "12345678";
$data = "test";
 
$value = Security::encrypt($data , $key );
echo $value.'<br/>';
echo Security::decrypt($value, $key );
 </code>
Nach dem Login kopieren
Nach dem Login kopieren

回复内容:

java类转成php版本,麻烦大神看一下php版本哪里问题
73C58BAFE578C59366D8C995CD0B9D6D
test

<code>import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;

import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;

public class AESUtil {
    
    
      public static void main(String[] args){
    //    System.out.println("Hello,it's:");
          String content="test";
          String password="12345678";
         String estr =  encrypt(content, password);
        System.out.println(estr);
        System.out.println(decrypt(estr, password));
    
    }

        /**将16进制转换为二进制
       * @param hexStr
       * @return
       */

     public static byte[] parseHexStr2Byte(String hexStr) {

      if (hexStr.length() </code>
Nach dem Login kopieren
Nach dem Login kopieren
<code>php版本自己写了</code>
Nach dem Login kopieren
Nach dem Login kopieren
<code><?php class Security {
    public static function encrypt($input, $key) {
        $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
        $input = Security::pkcs5_pad($input, $size);
        $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');
        $iv = mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
        mcrypt_generic_init($td, $key, $iv);
        $data = mcrypt_generic($td, $input);
        mcrypt_generic_deinit($td);
        mcrypt_module_close($td);
        $data = bin2hex($data);
        return $data;
    }
 
    private static function pkcs5_pad ($text, $blocksize) {
        $pad = $blocksize - (strlen($text) % $blocksize);
        return $text . str_repeat(chr($pad), $pad);
    }
 
    public static function decrypt($sStr, $sKey) {
            $decrypted= mcrypt_decrypt(
            MCRYPT_RIJNDAEL_128,
            $sKey,
            Security::hexToStr($sStr),
            MCRYPT_MODE_ECB
            );
     
        $dec_s = strlen($decrypted);
        $padding = ord($decrypted[$dec_s-1]);
        $decrypted = substr($decrypted, 0, -$padding);
        return $decrypted;
    }

         //16进制的转为2进制字符串      
    public static function hexToStr($hex)       
    {       
        $bin="";       
        for($i=0; $i<strlen($hex)-1; $i+=2)       
        {      
            $bin.=chr(hexdec($hex[$i].$hex[$i+1]));       
        }      
        return $bin;       
    }
 
}

 
$key = "12345678";
$data = "test";
 
$value = Security::encrypt($data , $key );
echo $value.'<br/>';
echo Security::decrypt($value, $key );
 </code>
Nach dem Login kopieren
Nach dem Login kopieren
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage