PHP加密扩展库—Mcrypt扩展库

在本文开始正文开始之前,我们先来了解一下什么是PHP加密扩展库:PHP中不但几种加密函数(md5,crypt,sha1),在此之外,PHP中还有一些功能比较全面的加密扩展库!就好比php本来不支持操作某种功能 ,但在新版本想对它提供支持,就以扩展的方式来提供,这样,我们在配置php时,如果我们不用此功能,我们就可以让php不加载他.从而节省服务器资源.提供其性能。直线电机选型

在以前的三篇文章《PHP加密函数—crypt()函数加密》、《PHP加密函数—md5()函数加密》以及《PHP加密函数—sha1()函数加密》中介绍了PHP加密函数,那么接下来我们要给大家介绍PHP加密扩展库!

PHP加密扩展库有两种,Mcrypt 和 Mhash两种扩展库,这篇文章我们先介绍 Mcrypt!

1.Mcrypt库安装

mcypt是一个功能十分强大的加密算法扩展库。在标准的PHP安装过程中并没有把Mcrypt安装上,但PHP的主目录下包含了libmcrypt.dll文件,所以我们只用将PHP配置文件中的这行extension=php_mcrypt.dll前面的分号“;”去掉,然后重启服务器就可以使用这个扩展库了。

2.Mcrypt库常量

mcrypt库支持 20多种的加密算法,以及 8 种加密模式,我们可以直接使用函数mcrypt_list_algorithms() 和 mcrypt_list_modes()来查看,具体代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

<?php

$atr = mcrypt_list_algorithms();  //函数返回 Mcrypt支持的加密算法数组

echo "支持算法有:";

foreach ($atr as $atr_value){

    echo "<br>".$atr_value;

}

$arr = mcrypt_list_modes();     //函数返回 Mcrypt支持的加密模式数组

echo "<p>支持加密模式有:";

foreach ($arr as $arr_value){

    echo "<br>".$arr_value;

}

?>

输出结果为:

注意:这些算法和模式在实际应用中需要用常量来表示,写的时候分别加上前缀:MCRYPT_和MCRYPT_MODE_来表示,实例:

TWOFISH算法表示为:MCRYPT_TWOFISH。

CBC加密模式表示为: MCRYPT_MODE_CBC。

3.Mcrypt应用

使用 Mcrypt 进行加密和解密不想使用md5(),sha1()等函数,直接调用就可以了。为了让大家能清楚的了解Mcrypt的工作流程,下面我们直接用代码介绍,具体代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

<?php

header("Content-Type:text/html; charset=utf-8");

$str = "被加密的内容:PHH中文网www.php.cn"//加密文本

$key = "key:111";                               //密钥

$cipher = MCRYPT_DES;                           //密码类型

$modes = MCRYPT_MODE_ECB;                      //密码模式

$iv = mcrypt_create_iv(mcrypt_get_iv_size($cipher,$modes),MCRYPT_RAND); //初始化向量

echo "加密前:".$str."<p>";

$str_encrypt = mcrypt_encrypt($cipher,$key,$str,$modes,$iv);       //加密函数

echo "加密后:".$str_encrypt."<p>";

$str_decrypt =mcrypt_decrypt($cipher,$key,$str_encrypt,$modes,$iv);  //解密函数

echo "还原:".$str_decrypt."<p>";

?>

输出结果为:

下面我们介绍上面实例中出现的几个函数:

1.mcrypt_create_iv:

语法格式如下:


1

string mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] )

使用 Mcrypt进行数据加密。解密之前,首先要创建一个初始化向量(简称 iv)。创建初始化向量需要两个参数:size 指定了 iv 的大小,source 为 iv 的源。source 可以取如下值:

  • MCRYPT_RAND:系统随机数。
  • MCRYPT_DEV_RANDOM:读取目录/dev/random 中的数据(UNIX系统)。
  • MCRYPT_DEV_URANDOM:读取目录/dev/urandom中的数据(UNIX系统)。

2.mcrypt_get_iv_size:

语法格式:


1

int mcrypt_get_iv_size ( string $cipher , string $mode )

该函数返回的初始化向量(iv)的大小。函数中的两个参数是前面刚介绍的加密算法(cipher)和加密模式(mode)。

3.mcrypt_encrypt:

语法格式如下:


1

string mcrypt_encrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )

初始化向量后,既可以使用mcrypt_encrypt()加密函数对数据进行加密,该函数的 5 个参数的含义分别如下:

(1)cipher:加密算法。上例中为变量$cipher 这里的加密算法可以和初始化向量中的加密算法不一样。

(2)key: 密钥。上例中的变量$key。

(3)mode: 加密模式。

(4)iv: 初始化向量。

4.mcrypt_decrypt

语法格式如下:


1

string mcrypt_decrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )

解密函数 mcrypt_decrypt()和加密函数 mcrypt_encrypt()的参数几乎是一样的。唯一不一样的就是参数data,这里data 为需要解密的数据,而不是原始数据。

说明:加密函数和解密函数中的 cipher,key以及mode 参数必须要一致,否则数据不会被还原。

原文地址:https://www.cnblogs.com/furuihua/p/12108580.html

时间: 2024-10-10 10:34:30

PHP加密扩展库—Mcrypt扩展库的相关文章

PHP加密扩展库—Mhash扩展库

什么是Mhash扩展库:Mhash是基于离散数学原理的不可逆向的php加密方式扩展库,其在默认情况下不开启.mhash的可以用于创建校验数值,消息摘要,消息认证码,以及无需原文的关键信息保存(如密码)等. 1.Mhash扩展库安装 关于Mhash库的安装跟Mcrypt扩展库安装是类似的,在这里就不做多介绍了,大家可以参考上一篇文章<PHP加密扩展库—Mcrypt扩展库>!深圳dd马达 2.Mhash扩展库常量 Mhash库支持 MD5,SHA,CRC32等多种散列算法,可以使用mhash_co

PHP基础库及扩展库安装

一.安装PHP所需的lib库(基础库): 1.yum install zlib-devel libxml2-devel libjpey-devel libjpeg-turbo-devel libiconv-devel -y 2.yum install freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel libxslt-devel libxslt-devel -y 3.安装yum源无法安装的libiconv库 mkdir

C动态库的扩展

案例背景:一般的企业信息系统都有成熟的框架,可以由C语言编写,也可以由C++编写.软件的框架一般不会发生变化,能自由地集成第三方的产品: 案例需要:在socket通信中,完成数据加密功能.有n个第三方厂商的加密产品供你选择,如何实现动态库和第三方产品的解耦和? 要求能够:1.能够支持多个第三方产品的入围:2.企业的信息系统框架不能轻易发生改变. 提醒:C++通过面向抽象类编程已经很好地解决了(C++中的多态,C++编译器通过提前布局vptr指针,虚函数表,完成动态的迟邦定).在C中有应当如何解决

PHP扩展调用C++静态库

概述 php通过扩展方式,调用c++源码,这样做的理由有很多,当你搜到这篇文章时,相信你已经有自己的考虑了. 写这篇博客的理由有二: 整理下php扩展调用c++代码的过程.嗯,对,网上有很多类似的文章,不过对于php扩展c++的方式,很多文章在关键的地方并没有说明,或者说,大部分都是扩展调用c代码的. 已经两年有余没写博客了,在这2017刚开始的时候,开个博客,开始新的旅程,也是不错的,哈哈. 大概目录 c++编译静态库 php 扩展编辑 结语 注:下面步骤的操作环境--系统macOS10.12

PHP 使用 mcrypt 扩展中的 mcrypt_encrypt() 和 mcrypt_decrypt() 对数据进行加密和解密

<?php /* 使用 mcrypt 扩展中的 mcrypt_encrypt() 和 mcrypt_decrypt() 对数据进行加密和解密 */ // 加密 $algorithm = MCRYPT_BLOWFISH; // 加密算法 $key = 'mycryptkey'; // 加密密钥 $data = '12345'; // 要加密或解密的数据 $mode = MCRYPT_MODE_CBC; // 加密或解密的模式 // 初始向量 $iv = mcrypt_create_iv(mcryp

安装和使用php的mcrypt扩展

安装和使用php的mcrypt扩展 PHP程序员们在编写代码程序时,除了要保证代码的高性能之外,还有一点是非常重要的,那就是程序的安全性保障.PHP除了自带的几种加密函数外,还有功能更全面的PHP加密扩展库Mcrypt和Mhash. 其中,Mcrypt扩展库可以实现加密解密功能,就是既能将明文加密,也可以密文还原.PHP加密扩展库Mcrypt的算法和加密模式 Mcrypt库支持20多种加密算法和8种加密模式,具体可以通过函数mcrypt_list_algorithms()和mcrypt_list

&lt;亲测好使&gt;mac os 安装mcrypt扩展

以前安装opencart的时候倒是不需要mcrypt 这个库.但是新版本需要了.加上自己的 是mac环境.当时闲麻烦,就一直没装.这次下午就寻思给装上吧! 1.首先你要先安装xcode这个工具.不然没办法编译! xcode这个可以在苹果appstore下载. 2.安装 command line tools   打开xcode .->> Preferences 然后点击command line tools   install  等下再完成安装就行了 也可以按照这个国外高人写的安装 https:/

CentOS下php安装mcrypt扩展

(以下步骤均为本人实际操作,可能与你的安装方法有所区别,但我会尽量排除疑惑) 大致步骤(1)安装mcrypt,(2)安装php对mcrypt的扩展,(3)重启apache (1).确认你的linux没有安装mcrypt库,如果已安装,跳过安装步骤 [[email protected] ~]# yum list installed|grep mcrypt libmcrypt.x86_64 2.5.8-4.el5.centos installed libmcrypt-devel.x86_64 2.5

PHP之——CentOS下php安装mcrypt扩展(插曲)

转载请注明出处:http://blog.csdn.net/l1028386804/article/details/46044935 (以下步骤均为本人实际操作,可能与你的安装方法有所区别,但我会尽量排除疑惑) 大致步骤(1)安装mcrypt,(2)安装php对mcrypt的扩展,(3)重启apache (1).确认你的linux没有安装mcrypt库,如果已安装,跳过安装步骤 [[email protected] ~]# yum list installed|grep mcrypt libmcr