Mcrypt 简介

Mcrypt 库提供了对多种块算法的支持, 包括:DES,TripleDES,Blowfish (默认), 3-WAY,SAFER-SK64,SAFER-SK128,TWOFISH,TEA,RC2 以及 GOST,并且支持 CBC,OFB,CFB 和 ECB 密码模式

安装过程 (Linux)

PHP7 要想使用 Mcrypt, 需要安装相应依赖包以及扩展模块

libmcrpyt 下载安装

# 注意:如果不需要代理服务器 可以去掉 -e 参数

wget --no-check-certificate -e "https_proxy=$http_proxy" -c "https://downloads.sourceforge.net/project/mcrypt/Libmcrypt/2.5.8/libmcrypt-2.5.8.tar.gz?r=https%3A%2F%2Fsourceforge.net%2Fprojects%2Fmcrypt%2Ffiles%2FLibmcrypt%2F2.5.8%2Flibmcrypt-2.5.8.tar.gz%2Fdownload&ts=1524883417&use_mirror=autoselect" -O libmcrypt-2.5.8.tar.gz

tar -xvzf libmcrpyt-2.5.8.tar.gz

cd libmcrypt-2.5.8

./configure

make

sudo make install

mcrypt 下载安装

# 注意:如果不需要代理服务器 可以去掉 -e 参数

wget --no-check-certificate -e "https_proxy=${http_proxy}" -c "https://downloads.sourceforge.net/project/mcrypt/MCrypt/2.6.8/mcrypt-2.6.8.tar.gz?r=https%3A%2F%2Fsourceforge.net%2Fprojects%2Fmcrypt%2Ffiles%2FMCrypt%2F2.6.8%2Fmcrypt-2.6.8.tar.gz%2Fdownload&ts=1524884655&use_mirror=autoselect" -O mcrypt-2.6.8.tar.gz

tar -xvzf mcrypt-2.6.8.tar.gz

LD_LIBRARY_PATH=/usr/local/lib ./configure

make

sudo make install

mhash 下载安装

# 注意:如果不需要代理服务器 可以去掉 -e 参数

wget --no-check-certificate -e "https_proxy=${http_proxy}" -c "https://downloads.sourceforge.net/project/mhash/mhash/0.9.9.9/mhash-0.9.9.9.tar.gz?r=https%3A%2F%2Fsourceforge.net%2Fprojects%2Fmhash%2Ffiles%2Fmhash%2F0.9.9.9%2Fmhash-0.9.9.9.tar.gz%2Fdownload&ts=1524885158&use_mirror=autoselect" -O mhash-0.9.9.9.tar.gz

tar -xvzf mhash-0.9.9.9.tar.gz

./configure

make

sudo make install

PHP源码下载

# 注意:如果不需要代理服务器 可以去掉 -e 参数

wget -e "http_proxy=${http_proxy}" -c "http://cn2.php.net/get/php-7.0.2.tar.gz/from/this/mirror" -O php-7.0.2.tar.gz

tar -xvzf php-7.0.2.tar.gz

cd ./php-7.0.2/ext/mcrpyt

# phpize是一个shell脚本,用于生成PECL扩展的configure文件

# 默认在/path/to/php/bin

phpize

./configure

make

sudo make install

# 结果

Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20151012/

修改 php.ini

# 寻找 php.ini 文件在哪里 `php -i | grep php.ini`

vi php.ini

extension=mcrypt.so

# 检查是否安装成功

php -m | grep mcrypt

mcrypt

使用

使用案例

# --- ENCRYPTION ---

# the key should be random binary, use scrypt, bcrypt or PBKDF2 to

# convert a string into a key

# key is specified using hexadecimal

$key = pack('H*', "bcb04b7e103a0cd8b54763051cef08bc55abe029fdebae5e1d417e2ffb2a00a3");

# show key size use either 16, 24 or 32 byte keys for AES-128, 192

# and 256 respectively

$key_size = strlen($key);

echo "Key size: " . $key_size . "\n";

$plaintext = "This string was AES-256 / CBC / ZeroBytePadding encrypted.";

# create a random IV to use with CBC encoding

$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);

$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);

# creates a cipher text compatible with AES (Rijndael block size = 128)

# to keep the text confidential

# only suitable for encoded input that never ends with value 00h

# (because of default zero padding)

$ciphertext = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key,

$plaintext, MCRYPT_MODE_CBC, $iv);

# prepend the IV for it to be available for decryption

$ciphertext = $iv . $ciphertext;

# encode the resulting cipher text so it can be represented by a string

$ciphertext_base64 = base64_encode($ciphertext);

echo $ciphertext_base64 . "\n";

# === WARNING ===

# Resulting cipher text has no integrity or authenticity added

# and is not protected against padding oracle attacks.

# --- DECRYPTION ---

$ciphertext_dec = base64_decode($ciphertext_base64);

# retrieves the IV, iv_size should be created using mcrypt_get_iv_size()

$iv_dec = substr($ciphertext_dec, 0, $iv_size);

# retrieves the cipher text (everything except the $iv_size in the front)

$ciphertext_dec = substr($ciphertext_dec, $iv_size);

# may remove 00h valued characters from end of plain text

$plaintext_dec = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key,

$ciphertext_dec, MCRYPT_MODE_CBC, $iv_dec);

echo $plaintext_dec . "\n";

?>

注意: Mcrpyt 扩展从 PHP 7.1.0 开始废弃;自 PHP 7.2.0 起,会移到 PECL

mcrypt拓展_【PHP】Mcrypt 扩展模块安装及使用相关推荐

  1. mcrypt拓展_PHP添加mcrypt扩展模块

    系统环境:centOS6.3 APACHE:httpd-2.4.2 PHP:php-5.3.21 一.安装mcrypt 1.下载Libmcrypt,mhash,mcrypt安装包 libmcrypt- ...

  2. php-mcrypt 源码_源码方式安装php扩展mcrypt

    本文实际上是在CentOS下进行的,原理和在Ubuntu下源码安装一样,下图首先示例mcrypt和php的依赖关系 基本原理是:首先使mcrypt软件能够运行,然后安装php扩展模块,并在php.in ...

  3. php7 mcrypt模块_如何在php7.2/php7.3中安装mcrypt扩展?

    mcrypt 是php里面重要的加密支持扩展库,linux环境下该库在默认情况下不开启.window环境下,PHP>=5.3,默认开启mcrypt扩展.mcrypt扩展是mcrypt加密库的接口 ...

  4. mcrypt拓展_php7.2 安装mcrypt扩展

    升级 php 7.2 后,提示 call to undefined function mcrypt_module_open() :mcrypt 扩展从 php 7.1.0 开始废弃:自 php 7.2 ...

  5. [乐意黎原创]PHP抛PHP Startup:Unable to load dynamic library bcmath,Libmcrypt,mhash,mcrypt等警告及模块动态安装详解

    如下,Centos里启动 php-fpm 时,控制台总在抛若干警告. [root@aerchi] #service php-fpm startStarting php-fpm daemon is su ...

  6. centos php mcrypt,CentOS yum php mcrypt 扩展安装方法

    这篇文章主要为大家介绍了CentOS系统下通过yum安装php mcrypt扩展的方法,需要的朋友可以参考下使用 yum install php-mcrypt 安装mcrypt扩展时会提示没有安装包 ...

  7. mcrypt拓展_PHP mcrypt加密扩展使用总结

    在开发中,很多时候我们在前后端交互中需要对一些敏感数据进行一定的加密.PHP中有提供了mcrypt的这样一个加密扩展实现对数据的加密解密. 一.mcrypt扩展的安装 在低版本的PHP中需要在配置文件 ...

  8. linux php安装xsl扩展,11.32 php扩展模块安装

    - 11.32 php扩展模块安装 - 扩展 - apache rewrite教程 http://coffeelet.blog.163.com/blog/static/1351574532011584 ...

  9. php扩展模块安装-lamp

    php扩展模块安装 PECL 的全称是 The PHP Extension Community Library ,是一个开放的并通过 PEAR(PHP Extension and Applicatio ...

最新文章

  1. [2016-04-19 15:46:03 - IceHoloReader1.0] Installation error: INSTALL_FAILED_CONFLICTING_PROVIDER [20
  2. 很强的PHP图片处理类
  3. 联通和阿里云合作 试点打通全国IT系统
  4. python 函数参数类型判断(判断类型)
  5. DataList的使用,Repeater
  6. Android应用开发之使用Socket进行大文件断点上传续传
  7. Java完全自学手册,从外包到大厂,再到年薪100万都靠它
  8. android项目设计实验报告模板,Android实验报告模板_实验一.doc
  9. 智课雅思词汇---二十、前缀syn-sym-syl是什么意思
  10. 中国出海50强,华为超越阿里得亚军,第一名居然是它?
  11. 批量下载bilibili视频
  12. Python 画图加坐标,加点,加网格
  13. SQL中实用的小技巧
  14. android4.0.3 编译lichee 报错dhd-cdc-sdmmc-gpl-3.0.8问题
  15. 什么是两化融合和数字化转型?
  16. Laravel表单验证,优雅一点的写法,控制器里面不要写太多东西,
  17. Macbook Pro上装Linux的牢骚
  18. chrome和Chromium有什么区别
  19. 深入理解搜索引擎——详解query理解
  20. php调度服务,cron自动调度服务配置详解

热门文章

  1. C#LeetCode刷题之#706-设计哈希映射(Design HashMap)
  2. compat包_使用Compat Patchers,API的稳定性既便宜又容易!
  3. soap rest_这是我对REST的后续工作,是新的SOAP:让我们谈谈原始REST
  4. 从零学javascript_我刚刚问了23,000个开发人员他们对JavaScript的看法。 这是我学到的。...
  5. svn 地址中文_iGit自助迁移SVN工程解密
  6. python调试神器_python调试神器PySnooper的使用
  7. Python——迭代器的几个高级用法
  8. shell编程之进阶篇三常见命令详解
  9. Apache Flink OLAP引擎性能优化及应用
  10. MVC教程第四篇:传递表单数据