PHP mcrypt_encrypt加密,使用java解密

PHP mcrypt_encrypt使用給定的 cipher 和 mode 加密的數據,沒有使用pkcs5_pad()函數填充的狀況下,若是數據長度不是n*分組大小,則在其後使用「0」補齊。php

Java 不能使用AES/ECB/PKCS5Padding,由於填充方式與php不一樣,不能正常的解密java

在java中應該使用AES/ECB/NoPadding方式,手動使用"0",填充補齊算法

1、PHP加密解密類示例:apache

<?php
/**
 * AES
 * AES加密解密算法
 * Created by PhpStorm.
 * Date: 2015/4/28
 * Time: 15:41
 */

namespace Fin\App\Library\Util;
class AES {

    /**
     * 算法,另外還有192和256兩種長度
     */
    const CIPHER = MCRYPT_RIJNDAEL_128;

    /**
     * 模式
     */
    const MODE = MCRYPT_MODE_ECB;

    /**
     * 加密
     * @param string $key 密鑰
     * @param string $str 需加密的字符串
     *
     * @return string
     */
    static public function encode($key, $str)
    {
        if(empty($key)){
            $key = "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0";
        }
        $size = mcrypt_get_iv_size(self::CIPHER, self::MODE);
        $iv = mcrypt_create_iv($size, MCRYPT_RAND);
        $string = mcrypt_encrypt(self::CIPHER, $key, $str, self::MODE, $iv);
        $string = base64_encode($string);
        return $string;
    }

    /**
     * 解密
     * @param type $key
     * @param type $str
     *
     * @return string
     */
    static public function decode($key, $str)
    {
        if(empty($key)){
            $key = "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0";
        }
        $size = mcrypt_get_iv_size(self::CIPHER, self::MODE);
        $iv = mcrypt_create_iv($size, MCRYPT_RAND);
        $string = base64_decode($str);
        $string = mcrypt_decrypt(self::CIPHER, $key, $string, self::MODE, $iv);

        /**
         * 解決下邊問題
         * the given cipher and mode. If the size of the data is not n * blocksize,
         * the data will be padded with '\0'.
         */
        $string = trim($string);

        return $string;
    }
}

2、 JAVA加密解密類示例:函數

import javax.crypto.Cipher;

import javax.crypto.spec.SecretKeySpec;

import org.apache.commons.codec.binary.Base64;
import org.apache.commons.lang3.*;

public class Security {

    public static String encrypt(String input, String key) {

        byte[] crypted = null;

        try {

            input = StringUtils.rightPad(input, 16, "\0");

            SecretKeySpec skey = new SecretKeySpec(key.getBytes(), "AES");

            Cipher cipher = Cipher.getInstance("AES/ECB/NoPadding");

            cipher.init(Cipher.ENCRYPT_MODE, skey);
            crypted = cipher.doFinal(input.getBytes());

        } catch (Exception e) {

            System.out.println(e.toString());

        }

        return new String(Base64.encodeBase64(crypted));

    }

    public static String decrypt(String input, String key) {

        byte[] output = null;

        try {

            SecretKeySpec skey = new SecretKeySpec(key.getBytes(), "AES");

            Cipher cipher = Cipher.getInstance("AES/ECB/NoPadding");

            cipher.init(Cipher.DECRYPT_MODE, skey);

            output = cipher.doFinal(Base64.decodeBase64(input));

        } catch (Exception e) {

            System.out.println(e.toString());

        }

        return new String(output);

    }

    public static void main(String[] args) {

        String key = "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0";

        String data = "412016278912497";

        System.out.println(Security.encrypt(data, key));

        System.out.println(Security.decrypt(Security.encrypt(data, key), key));

    }

}
相關文章
相關標籤/搜索