PHP AES对称加密源码

//检查php环境是否支持mcrypt
$cipher_list = mcrypt_list_algorithms();//mcrypt支持的加密算法列表
$mode_list = mcrypt_list_modes();   //mcrypt支持的加密模式列表
 
echo '<xmp>';
print_r($cipher_list);
print_r($mode_list);
//rijndael-128,rijndael-192,rijndael-256就是AES加密,3种分别是使用不同的数据块和密钥长度进行加密。
 
/**
 * 利用mcrypt做AES加密解密
 */
 
abstract class AES{
    /**
     * 算法,另外还有192和256两种长度
     */
    const CIPHER = MCRYPT_RIJNDAEL_128;
    /**
     * 模式
     */
    const MODE = MCRYPT_MODE_ECB;
 
    /**
     * 加密
     * @param string $key   密钥
     * @param string $str   需加密的字符串
     * @return type
     */
    static public function encode( $key, $str ){
        $iv = mcrypt_create_iv(mcrypt_get_iv_size(self::CIPHER,self::MODE),MCRYPT_RAND);
        return mcrypt_encrypt(self::CIPHER, $key, $str, self::MODE, $iv);
    }
 
    /**
     * 解密
     * @param type $key
     * @param type $str
     * @return type
     */
    static public function decode( $key, $str ){
        $iv = mcrypt_create_iv(mcrypt_get_iv_size(self::CIPHER,self::MODE),MCRYPT_RAND);
        return mcrypt_decrypt(self::CIPHER, $key, $str, self::MODE, $iv);
    }
}
 
$str = '我是明文我是明文我是明文我是明文我是明文dsfdghgasdfasdddddddd';
$key = 'aSGJLGYEWERWRREW4567i8o';
 
$str1=AES::encode($key, $str);
$str2=AES::decode($key, $str1);
 
echo '<xmp>';
var_dump($str);
var_dump($str1);
var_dump($str2);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AES加密是一种常用的对称加密算法,Java中也提供了AES加密的实现。以下是一个简单的AES加密Java源码示例: ``` import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; public class AESUtil { // 生成AES秘钥 public static byte[] initKey() throws Exception { KeyGenerator kg = KeyGenerator.getInstance("AES"); kg.init(128); // 生成128位的AES秘钥 SecretKey secretKey = kg.generateKey(); return secretKey.getEncoded(); } // AES加密 public static byte[] encrypt(byte[] data, byte[] key) throws Exception { SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES"); Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec); return cipher.doFinal(data); } // AES解密 public static byte[] decrypt(byte[] encryptedData, byte[] key) throws Exception { SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES"); Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE, secretKeySpec); return cipher.doFinal(encryptedData); } } ``` 这段代码实现了AES秘钥的生成、加密和解密功能。其中,`initKey()`方法用于生成128位的AES秘钥,`encrypt()`方法用于对数据进行AES加密,`decrypt()`方法用于对加密后的数据进行解密。在使用时,需要先调用`initKey()`方法生成秘钥,然后使用`encrypt()`方法进行加密,再使用`decrypt()`方法进行解密。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值