1. 加密算法

    /**  * 常用对称加密算法类  * 支持密钥:64/128/256 bit(字节长度8/16/32)  * 支持算法:DES/AES(根据密钥长度自动匹配使用:DES:64bit AES:128/256bit)  * 支持模式:CBC/ECB/OFB/CFB  * 密文编码:base64字符串/十六进制字符串/二进制字符串流  * 填充方式: PKCS5Padding(DES)  *  * @author: linvo  * @version: 1.0.0  * @date: 2013/1/10  */
    class Xcrypt{    private $mcrypt;    private $key;    private $mode;    private $iv;    private $blocksize;    /**  * 构造函数  *  * @param string 密钥  * @param string 模式  * @param string 向量("off":不使用 / "auto":自动 / 其他:指定值,长度同密钥)  */   public function __construct($key, $mode = 'cbc', $iv = "off"){    switch (strlen($key)){    case 8:    $this->mcrypt = MCRYPT_DES;    break;    case 16:    $this->mcrypt = MCRYPT_RIJNDAEL_128;    break;    case 32:    $this->mcrypt = MCRYPT_RIJNDAEL_256;    break;    default:    die("Key size must be 8/16/32");    }    $this->key = $key;    switch (strtolower($mode)){    case 'ofb':    $this->mode = MCRYPT_MODE_OFB;    if ($iv == 'off') die('OFB must give a IV'); //OFB必须有向量    break;    case 'cfb':    $this->mode = MCRYPT_MODE_CFB;    if ($iv == 'off') die('CFB must give a IV'); //CFB必须有向量    break;    case 'ecb':    $this->mode = MCRYPT_MODE_ECB;    $iv = 'off'; //ECB不需要向量    break;    case 'cbc':    default:    $this->mode = MCRYPT_MODE_CBC;    }    switch (strtolower($iv)){    case "off":    $this->iv = null;    break;    case "auto":    $source = PHP_OS=='WINNT' ? MCRYPT_RAND : MCRYPT_DEV_RANDOM;    $this->iv = mcrypt_create_iv(mcrypt_get_block_size($this->mcrypt, $this->mode), $source);    break;    default:    $this->iv = $iv;    }    }    /**  * 获取向量值  * @param string 向量值编码(base64/hex/bin)  * @return string 向量值  */   public function getIV($code = 'base64'){    switch ($code){    case 'base64':    $ret = base64_encode($this->iv);    break;    case 'hex':    $ret = bin2hex($this->iv);    break;    case 'bin':    default:    $ret = $this->iv;    }    return $ret;    }    /**  * 加密  * @param string 明文  * @param string 密文编码(base64/hex/bin)  * @return string 密文  */   public function encrypt($str, $code = 'base64'){    if ($this->mcrypt == MCRYPT_DES) $str = $this->_pkcs5Pad($str);    if (isset($this->iv)) {    $result = mcrypt_encrypt($this->mcrypt, $this->key, $str, $this->mode, $this->iv);      } else {    @$result = mcrypt_encrypt($this->mcrypt, $this->key, $str, $this->mode);      }    switch ($code){    case 'base64':    $ret = base64_encode($result);    break;    case 'hex':    $ret = bin2hex($result);    break;    case 'bin':    default:    $ret = $result;    }    return $ret;    }    /**  * 解密   * @param string 密文  * @param string 密文编码(base64/hex/bin)  * @return string 明文  */   public function decrypt($str, $code = "base64"){        $ret = false;    switch ($code){    case 'base64':    $str = base64_decode($str);    break;    case 'hex':    $str = $this->_hex2bin($str);    break;    case 'bin':    default:    }    if ($str !== false){    if (isset($this->iv)) {    $ret = mcrypt_decrypt($this->mcrypt, $this->key, $str, $this->mode, $this->iv);      } else {    @$ret = mcrypt_decrypt($this->mcrypt, $this->key, $str, $this->mode);      }    if ($this->mcrypt == MCRYPT_DES) $ret = $this->_pkcs5Unpad($ret);    }    return $ret;     }     private function _pkcs5Pad($text){    $this->blocksize = mcrypt_get_block_size($this->mcrypt, $this->mode);      $pad = $this->blocksize - (strlen($text) % $this->blocksize);    return $text . str_repeat(chr($pad), $pad);    }    private function _pkcs5Unpad($text){    $pad = ord($text{strlen($text) - 1});    if ($pad > strlen($text)) return false;    if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false;    $ret = substr($text, 0, -1 * $pad);    return $ret;    }    private function _hex2bin($hex = false){    $ret = $hex !== false && preg_match('/^[0-9a-fA-F]+$/i', $hex) ? pack("H*", $hex) : false;        return $ret;    }    }    

    2.demo

    <?php
    header('Content-Type:text/html;Charset=utf-8;');    include "xcrypt.php";    echo '<pre>';
    //
    $a = isset($_GET['a']) ? $_GET['a'] : '测试123';    //密钥
    $key = '12345678123456781234567812345678'; //256 bit
    $key = '1234567812345678'; //128 bit
    $key = '12345678'; //64 bit    //设置模式和IV
    $m = new Xcrypt($key, 'cbc', 'auto');    //获取向量值
    echo '向量:';
    var_dump($m->getIV());    //加密
    $b = $m->encrypt($a, 'base64');
    //解密
    $c = $m->decrypt($b, 'base64');    echo '加密后:';
    var_dump($b);
    echo '解密后:';
    var_dump($c);    /////
    echo '</pre>';  

    转载于http://blog.csdn.net/u011650048/article/details/50715696

转载于:https://www.cnblogs.com/leilei-1/p/7426870.html

php 加密解密算法相关推荐

  1. 提供一个基于.NET的加密/解密算法

    提供一个基于.NET SymmetricAlgorithm 类的.带私钥的加密/解密算法的包装类.使用方法: symmcrypto de = new SymmCrypto(SymmCrypto.Sym ...

  2. C#的加密解密算法,包括Silverlight的MD5算法

    C#的加密解密算法,包括Silverlight的MD5算法 下面是一段加密解密工具类,其中的WinFormMD5Encrypt方法可以使得Winform和WebForm下的MD5加密结果一致,默认他们 ...

  3. php xxtea加密,PHP实现的XXTEA加密解密算法示例

    本文实例讲述了PHP实现的XXTEA加密解密算法.分享给大家供大家参考,具体如下: /** * Xxtea 加密实现类 */ class xxtea { private function long2s ...

  4. java 实现 DES加密 解密算法

    DES算法的入口参数有三个:Key.Data.Mode.其中Key为8个字节共64位,是DES算法的工作密钥:Data也为8个字节64位,是要被加密或被解密的数据:Mode为DES的工作方式,有两种: ...

  5. 【Android 安全】DEX 加密 ( Java 工具开发 | 加密解密算法 API | 编译代理 Application 依赖库 | 解压依赖库 aar 文件 )

    文章目录 一.加密解密算法 API 二.编译代理 Application 依赖库 三.解压代理 Application 依赖库 aar 文件 参考博客 : [Android 安全]DEX 加密 ( 常 ...

  6. 基于新唐M0的XXTEA加密解密算法源码

    源:基于新唐M0的XXTEA加密解密算法源码 /*--------------------------------------------------------------------------- ...

  7. AES加密解密算法Java实现

    AES加密算法是密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的DE ...

  8. DES加密解密算法Java实现

    DES 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小.这是一个迭代的分组密码,使用称为 Feistel 的技术,其中将加密的文本块分成两半.使用子密钥对其中一半应 ...

  9. 简单的加密/解密算法_/c++

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/qq_36557960/article/details/79299093 关于加密和解密问题,有的加密 ...

  10. TEA、XTEA、XXTEA加密解密算法

    参考:TEA.XTEA.XXTEA加密解密算法 地址:https://blog.csdn.net/gsls200808/article/details/48243019 其他相关博文链接:tea系列加 ...

最新文章

  1. 块存储,文件存储和对象存储
  2. 【UOJ】67 新年的毒瘤 【BZOJ】1123 BLO
  3. jzoj3738-[NOI2014模拟7.11]理想城市(city)【树,模型转换】
  4. DLL入口点函数DllMain
  5. OpenCV Using Python——基于SURF特征提取和金字塔LK光流法的单目视觉三维重建 (光流、场景流)...
  6. 前端数据库——WebSQL和IndexedDB
  7. Fiddler抓取https如何设置
  8. 通过Google分析页面加载缓慢并优化
  9. list, tuple, dict, set的用法总结
  10. 无法启用数据库中的 Service Broker,因为已存在启用的具有相同 ID 的 Service Broker。...
  11. JavaScript—从数组的indexOf方法深入——Object的Property机制。
  12. Spring MVC @JsonView使用详解
  13. 【备忘】于仕琪的libfacedetection相关
  14. 速度上车,全网无损音乐,付费内容任你免费下载
  15. RFM用户分层模型简介
  16. 好年货不用多等 拼多多30亿红包聚焦全国全球尖货好物
  17. 【STM32 .Net MF开发板学习-12】跳动的音符(PWM合成)
  18. 模式识别与机器学习(作业5)基于PCA–LDA的人脸识别
  19. git推送不能完全退出错误
  20. js和jsp的区别和联系

热门文章

  1. BAT中删除目录,如何不显示删除的文件
  2. 如何清理cmake产生的各种文件
  3. 编译OpenJDK12:LINK : warning LNK4098: 默认库“LIBCMT”与其他库的使用冲突;请使用 /NODEFAULTLIB:library
  4. 主线程中访问网络有限制?无法得到数据,必须另起线程
  5. C中error的使用
  6. 呼吁各行业实现无纸化办公
  7. 错误解决办法:zipimport.ZipImportError: can't decompress data; zlib not available
  8. 任务状态段(Task State Segment)
  9. 计算机桌面组成部分教案,三年级信息技术第五课设置个性桌面教学设计
  10. 3项目里面全局用less变量 cli vue_如何把 CSS 变量全局化