利用php的mcrypt模块加密解密(AES、DES等等)

php des加密:

$cipher_list = mcrypt_list_algorithms();//mcrypt支持的加密算法列表
$mode_list = mcrypt_list_modes();//mcrypt支持的加密模式列表

// print_r($cipher_list);
// print_r($mode_list);

function encrypt($key,$data){
    $td = mcrypt_module_open("des", "", "ecb", "");//使用MCRYPT_DES算法,ecb模式
    $size = mcrypt_enc_get_iv_size($td);       //设置初始向量的大小
    $iv = mcrypt_create_iv($size,MCRYPT_RAND); //创建初始向量

    $key_size = mcrypt_enc_get_key_size($td);       //返回所支持的最大的密钥长度(以字节计算)
    $salt = ‘‘;
    $subkey = substr(md5(md5($key).$salt), 0,$key_size);//对key复杂处理,并设置长度

    mcrypt_generic_init($td, $subkey, $iv);
    $endata = mcrypt_generic($td, $data);
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    return $endata;
}

function decrypt($key,$endata){
    $td = mcrypt_module_open("des", "", "ecb", "");//使用MCRYPT_DES算法,ecb模式
    $size = mcrypt_enc_get_iv_size($td);       //设置初始向量的大小
    $iv = mcrypt_create_iv($size,MCRYPT_RAND); //创建初始向量
    $key_size = mcrypt_enc_get_key_size($td);       //返回所支持的最大的密钥长度(以字节计算)
    $salt = ‘‘;
    $subkey = substr(md5(md5($key).$salt), 0,$key_size);//对key复杂处理,并设置长度
    mcrypt_generic_init($td, $subkey, $iv);
    $data = rtrim(mdecrypt_generic($td, $endata)).‘\n‘;
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    return $data;
}

$key = "www.tencent.com";
// $data = "返回所支持的最大的密钥长度(涉及到发件费啦";
$data = "dadfafdafd,我是一个好孩子";

$endata =  encrypt($key,$data);

$data1 = decrypt($key,$endata);

echo $endata; //直接输出,在网页上是乱码,用base64_encode处理,就变成由字符、数组、加号、斜杠等共64种字符注册
echo base64_encode($endata);
echo $data1;

php所有的加密算法和模型:

//rijndael-128,rijndael-192,rijndael-256就是AES加密,3种分别是使用不同的数据块和密钥长度进行加密。Array
(
    [0] => cast-128
    [1] => gost
    [2] => rijndael-128
    [3] => twofish
    [4] => arcfour
    [5] => cast-256
    [6] => loki97
    [7] => rijndael-192
    [8] => saferplus
    [9] => wake
    [10] => blowfish-compat
    [11] => des
    [12] => rijndael-256
    [13] => serpent
    [14] => xtea
    [15] => blowfish
    [16] => enigma
    [17] => rc2
    [18] => tripledes
)
Array
(
    [0] => cbc
    [1] => cfb
    [2] => ctr
    [3] => ecb
    [4] => ncfb
    [5] => nofb
    [6] => ofb
    [7] => stream
)

一般情况,用上面代码块即可,如果要求自己搞一个类,可以使用下面的类即可:

<?php /* * 类中,功能部分功能没有提炼,还需进一步修改*/
class Mymcrypt {

    public $key = "www.tence.com"; //必须是字符串了,如果是数字

    // 加密
    public function do_mencrypt($input)
    {
        // $key = substr(md5($this->key), 0, 24);
        // $td = mcrypt_module_open(‘des‘, ‘‘, ‘ecb‘, ‘‘);
        // $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, ‘‘, MCRYPT_MODE_ECB, ‘‘);
        $td = mcrypt_module_open(MCRYPT_RIJNDAEL_256, ‘‘, MCRYPT_MODE_ECB, ‘‘);
        $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

        //没有做key size设定
        $key_size = mcrypt_enc_get_key_size($td);       //返回所支持的最大的密钥长度(以字节计算)
        $salt = ‘‘;
        $subkey = substr(md5(md5($this->key).$salt), 0,$key_size);//对key复杂处理,并设置长度

        mcrypt_generic_init($td, $subkey, $iv);
        $encrypted_data = mcrypt_generic($td, $input);
        mcrypt_generic_deinit($td);
        mcrypt_module_close($td);
        // return trim(chop($this->base64url_encode($encrypted_data)));
        return $encrypted_data;
    }

    // 解密
    //$input - stuff to decrypt
    public function do_mdecrypt($input)
    {
        // $key = substr(md5($this->key), 0, 24);
        // $td = mcrypt_module_open(‘des‘, ‘‘, ‘ecb‘, ‘‘);
        // $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, ‘‘, MCRYPT_MODE_ECB, ‘‘);
        $td = mcrypt_module_open(MCRYPT_RIJNDAEL_256, ‘‘, MCRYPT_MODE_ECB, ‘‘);
        $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

        //没有做key size设定
        $key_size = mcrypt_enc_get_key_size($td); //返回支持的最大的密钥长度(以字节计)也可自己设定比如24
        $salt = ‘‘;
        $subkey = substr(md5(md5($this->key).$salt), 0,$key_size);////对key复杂处理,并设置长度

        mcrypt_generic_init($td, $subkey, $iv);
        $decrypted_data = mdecrypt_generic($td, $input);
        mcrypt_generic_deinit($td);
        mcrypt_module_close($td);
        // return trim(chop($decrypted_data));
        return $decrypted_data;
    }

    // base64在url传递过程中需要注意的
    // 把base64加密后在url传输,会把“+“,”/”分别替换为”-”,”_”,以及会把末尾的等号“=”去掉。
    // 另外base64加密后的长度必然是4的倍数,所以可以根据这个还原“=”号
    function base64url_encode($data) {
        return rtrim(strtr(base64_encode($data), ‘+/‘, ‘-_‘), ‘=‘);
        // return $data;  //不处理会乱码
        // return base64_encode($data);
    }

    function base64url_decode($data) {
        return base64_decode(str_pad(strtr($data, ‘-_‘, ‘+/‘), strlen($data) % 4, ‘=‘, STR_PAD_RIGHT));
    }

} 

// 用法
$myMcrypt = new Mymcrypt();
$data = ‘PD867H4V9J6B‘;
$value = $myMcrypt->do_mencrypt($data);
// $value = $myMcrypt->base64url_encode($value); //可以使用特殊处理过的base64_encode

$value = base64_encode($value); //方便在网页显示
$value = trim($value);          //有时后面会带很多预定于字符串
echo "$value <br/> 长度:".strlen($value)."<br/>";

$value = base64_decode($value); //解码后解密
$value = $myMcrypt->do_mdecrypt($value);
$value = trim($value);
echo "$value <br/>长度:".strlen($value)."<br/>";

相关链接:

https://segmentfault.com/a/1190000000668272  //php常见加密函数,总结的蛮好

http://www.cnblogs.com/hongfei/archive/2012/06/19/2555504.html  //前半部分对概念的解释很好

http://blog.csdn.net/zhang_red/article/details/39890539  //实际采用的例子

http://blog.csdn.net/tsxw24/article/details/7644244  //简洁版例子

时间: 2024-12-30 03:16:06

利用php的mcrypt模块加密解密(AES、DES等等)的相关文章

C# 加密解密(DES,3DES,MD5,Base64) 类

原文:C# 加密解密(DES,3DES,MD5,Base64) 类 保存! public sealed class EncryptUtils { #region Base64加密解密 /// <summary> /// Base64加密 /// </summary> /// <param name="input">需要加密的字符串</param> /// <returns></returns> public sta

Java对称与非对称加密解密,AES与RSA

加密技术可以分为对称与非对称两种. 对称加密,解密,即加密与解密用的是同一把秘钥,常用的对称加密技术有DES,AES等 而非对称技术,加密与解密用的是不同的秘钥,常用的非对称加密技术有RSA等 为什么要有非对称加密,解密技术呢 假设这样一种场景A要发送一段消息给B,但是又不想以明文发送,所以就需要对消息进行加密.如果采用对称加密技术,那么加密与解密用的是同一把秘钥.除非B事先就知道A的秘钥,并且保存好.这样才可以解密A发来的消息. 由于对称技术只有一把秘钥,所以秘钥的管理是一个很麻烦的问题.而非

各种加密解密函数(URL加密解密、sha1加密解密、des加密解密)

普通hash函数如md5.sha1.base64等都是不可逆函数.虽然我们利用php可以利用这些函数写出可逆函数来.但是跨语言时这类可逆函数非常难搞定.所以这时尽量使用AES DES RC4 Rabbit TripleDes这些方法. 包含超时的加密解密函数 1 /** 2 * 加密 3 * @param string $string 要加密或解密的字符串 4 * @param string $operation 加密 '' 解密 DECODE 5 * @param string $key 密钥

.Net(c#)加密解密之Des

Des工具类: /// <summary> /// .Net加密解密帮助类 /// </summary> public class NetCryptoHelper { /// <summary> /// Des默认密钥向量 /// </summary> public static byte[] DesIv = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF }; /// <summary> ///

C#实现DES加密解密,AES加密解密

DES算法描述简介: DES是Data Encryption Standard(数据加密标准)的缩写.它是由IBM公司研制的一种加密算法,美国国家标准局于1977年公布把它作为非机要部门使用的数据加密标准:它是一个分组加密算法,他以64位为分组对数据加密.同时DES也是一个对称算法:加密和解密用的是同一个算法.它的密匙长度是56位(因为每个第8 位都用作奇偶校验),密匙可以是任意的56位的数,而且可以任意时候改变. /// <summary>   /// DES加密   /// </su

C#加密解密(AES)-AESHelper

原文地址:https://ken.io/note/csharp-aesencrypt using System; namespace Encrypt { public class AESHelper { /// <summary> /// 默认密钥-密钥的长度必须是32 /// </summary> private const string PublicKey = "1234567890123456"; /// <summary> /// 默认向量

C#加密解密(DES,AES,Base64,md5,SHA256,RSA,RC4)

一:异或^简单加解密(数字类型) 1:原理: 异或用于比较两个二进制数的相应位,在执行按位"异或"运算时,如果两个二进制数的相应位都为1或者都为0,则返回0;如果两个二进制数的相应位其中一个为1另一个为0,则返回1. //对数字加密 int P_int_Num, P_int_Key;//定义两个值类型变量 string Encryptstr = (P_int_Num ^ P_int_Key).ToString();//加密数值 //对数字解密 int P_int_Key, P_int_

基于AES对称加密解密的代码块

提供此代码方便自己以后直接查询用,也可以方便其他朋友直接拿来用. 1 import javax.crypto.Cipher; 2 import javax.crypto.spec.IvParameterSpec; 3 import javax.crypto.spec.SecretKeySpec; 4 import sun.misc.BASE64Decoder; 5 import sun.misc.BASE64Encoder; 6 /** 7 * <p>标题: 对称加密解密AES</p&g

AES加密解密 助手类 CBC加密模式

string str = "2018"; string result1 = AESHelper.AesEncrypt(str); string result2 = AESHelper.AesDecrypt(result1); namespace Demo { /// <summary> /// AES加密解密 助手类 /// CBC加密模式 /// </summary> public class AESHelper { /// <summary> /