PHP内置加密函数详解


Posted in PHP onNovember 20, 2016

Md5()加密算法

方式: 单向加密

语法: md5(string $str [, bool $raw_output = false])

$str:原始字符串

$raw_output:如果可选的raw_output被设置为true, 那么md5报文摘要将以16字节长度的原始二进制格式返回. 返回以32位字符十六进制数字形式返回散列值

md5二次加密:md5(md5($string, true))

Crypt()加密算法

方式: 单向加密

语法: string crypt(string $str[, string $salt]) , 返回一个基于标准UNIX DES算法或系统上其它可用的替代算法的三列字符串

$str: 需要加密的明文

$salt: 加密时的干扰串,是编码更安全

注意: 如果加密时没有加上这个$salt参数, 将随机生成一个干扰串, 否则刷新加密秘文不变

算法常量:

[CRYPT_SALT_LENGTH]

默认的加密长度。使用标准的 DES 加密,长度为 2

[CRYPT_STD_DES]

基于标准 DES 算法的散列使用 "./0-9A-Za-z" 字符中的两个字符作为盐值。在盐值中使用非法的字符将导致 crypt() 失败。

[CRYPT_EXT_DES]

扩展的基于 DES 算法的散列。其盐值为 9 个字符的字符串,由 1 个下划线后面跟着 4 字节循环次数和 4 字节盐值组成。它们被编码成可打印字符,每个字符 6 位,有效位最少的优先。0 到 63 被编码为 "./0-9A-Za-z"。在盐值中使用非法的字符将导致 crypt() 失败。

[CRYPT_MD5]

MD5 散列使用一个以 $1$ 开始的 12 字符的字符串盐值。

[CRYPT_BLOWFISH]

Blowfish 算法使用如下盐值:“$2a$”,一个两位 cost 参数,“$” 以及 64 位由 “./0-9A-Za-z” 中的字符组合而成的字符串。在盐值中使用此范围之外的字符将导致 crypt() 返回一个空字符串。两位 cost 参数是循环次数以 2 为底的对数,它的范围是 04-31,超出这个范围将导致 crypt() 失败。

CRYPT_SHA256

SHA-256 算法使用一个以 $5$ 开头的 16 字符字符串盐值进行散列。如果盐值字符串以 “rounds=<N>$” 开头,N 的数字值将被用来指定散列循环的执行次数,这点很像 Blowfish 算法的 cost 参数。默认的循环次数是 5000,最小是 1000,最大是 999,999,999。超出这个范围的 N 将会被转换为最接近的值。

CRYPT_SHA512

SHA-512 算法使用一个以 $6$ 开头的 16 字符字符串盐值进行散列。如果盐值字符串以 “rounds=<N>$” 开头,N 的数字值将被用来指定散列循环的执行次数,这点很像 Blowfish 算法的 cost 参数。默认的循环次数是 5000,最小是 1000,最大是 999,999,999。超出这个范围的 N 将会被转换为最接近的值。

例:

if(CRYPT_MD5){
  echo "MD5加密:".crypt('something','$1$somethin$');
}

Sha1()加密算法

方式: 单向加密

语法: string sha1(string $str [, bool $raw_output=false]) 计算字符串的sha1散列值

$str: 加密的字符串

$raw_output: 如果可选的raw_output参数被设置为TRUE, 那么sha1摘要将以20字符长度的原始格式返回, 否则返回值是一个40字符串长度的十六进制数字.

URL编码加密技术

编码URL字符串: urlencode(string $str)

解码已编码的URL字符串: urldeocde(string $str)

编码规范: 此字符串中除了-_.之外的所有非字母数字字符都将被替换成百分号(%)后跟两位十六进制数, 空格则编码为加号(+)

按照RFC1738对URL进行编码: rawurlencode(string $str) : 返回从字符串,把空格编码为%20

对已编码的字符串进行解码: rawurldecode(string $str) : 返回字符串, 此字符串中百分号%后跟两位十六进制的序列豆将被替换成原义字符

urlencode和rawurlencode的区别只在于空格.

Base64编码加密技术

使用base64对data进行编码: base64_encode(string $data)

对使用MIME base64编码的数据进行解码: base64_decode(string $data[, $strict=false]) ; $strict:如果输入的数据超出了base64的字母表,则返回false.

base64编码的图片还可以直接放在<img>标签中显示:

<img src="data:image/jpeg;base64,编码字符串" alt=""/>

<img src="data:;base64,编码字符串" alt=""/>

信息加密技术:

1 单项散列加密:

指通过不同输入的长度的信息进行散列计算, 得到固定长度的输出, 这个散列计算过程是单向的, 既不能对固定长度的输出进行计算从而活儿输出信息.

2 对称散列加密

指加密和解密的密匙是同一个密匙或者可以互相推算.

3 非对称散列加密

非对称加密和解密的密匙不是同一个密匙, 其中一个对外公开, 被称作公钥, 另一个只有所有者知道.

PHP 相关文章推荐
与数据库连接
Oct 09 PHP
php横向重复区域显示二法
Sep 25 PHP
PHP 开发环境配置(测试开发环境)
Apr 28 PHP
深入解析php之apc
May 15 PHP
PHP连接Access数据库的方法小结
Jun 20 PHP
php查看请求头信息获取远程图片大小的方法分享
Dec 25 PHP
php实现中文字符截取防乱码方法汇总
Apr 29 PHP
FleaPHP框架数据库查询条件($conditions)写法总结
Mar 19 PHP
微信公众号判断用户是否已关注php代码解析
Jun 24 PHP
PHP大文件切割上传并带进度条功能示例
Jul 01 PHP
PHP 7.4中使用预加载的方法详解
Jul 08 PHP
在laravel5.2中实现点击用户头像更改头像的方法
Oct 14 PHP
php PDO异常处理详解
Nov 20 #PHP
php.ini中date.timezone设置详解
Nov 20 #PHP
centos 7.2下搭建LNMP环境教程
Nov 20 #PHP
浅析php中array_map和array_walk的使用对比
Nov 20 #PHP
php解决DOM乱码的方法示例代码
Nov 20 #PHP
使用Yii2实现主从数据库设置
Nov 20 #PHP
php 二维数组时间排序实现代码
Nov 19 #PHP
You might like
discuz安全提问算法
2007/06/06 PHP
PHP实现手机号码中间四位用星号(*)隐藏的自定义函数分享
2014/09/27 PHP
理解Javascript_05_原型继承原理
2010/10/13 Javascript
各浏览器对link标签onload/onreadystatechange事件支持的差异分析
2011/04/27 Javascript
通过JS自动隐藏手机浏览器的地址栏实现原理与代码
2013/01/02 Javascript
js function定义函数的几种不错方法
2014/02/27 Javascript
对javascript继承的理解
2016/10/11 Javascript
JS实现本地存储信息的方法(基于localStorage与userData)
2017/02/18 Javascript
详解通过JSON数据使用VUE.JS
2017/05/26 Javascript
详解JavaScript中的六种错误类型
2017/09/21 Javascript
javascript 判断用户有没有操作页面
2017/10/17 Javascript
Mint UI 基于 Vue.js 移动端组件库
2017/11/07 Javascript
Angular17之Angular自定义指令详解
2018/01/21 Javascript
nodejs实现一个word文档解析器思路详解
2018/08/14 NodeJs
jquery实现的简单轮播图功能【适合新手】
2018/08/17 jQuery
Node.js连接Sql Server 2008及数据层封装详解
2018/08/27 Javascript
vue中的ref和$refs的使用
2018/11/22 Javascript
vue项目创建步骤及路由router
2020/01/14 Javascript
Node.js实现批量下载图片简单操作示例
2020/01/18 Javascript
vue内置组件keep-alive事件动态缓存实例
2020/10/30 Javascript
vue-axios同时请求多个接口 等所有接口全部加载完成再处理操作
2020/11/09 Javascript
Python中的作用域规则详解
2015/01/30 Python
Python中MySQLdb和torndb模块对MySQL的断连问题处理
2015/11/09 Python
利用ctypes获取numpy数组的指针方法
2019/02/12 Python
Python3实现的判断环形链表算法示例
2019/03/07 Python
Django上线部署之IIS的配置方法
2019/08/22 Python
Python绘制热力图示例
2019/09/27 Python
解决tensorflow由于未初始化变量而导致的错误问题
2020/01/06 Python
突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面通知)
2013/01/31 HTML / CSS
英智兴达软件测试笔试题
2016/10/12 面试题
应届生新闻编辑求职信
2013/11/19 职场文书
关于逃课的检讨书
2014/01/23 职场文书
冬季安全检查方案
2014/05/23 职场文书
岗位职责说明书模板
2014/07/30 职场文书
鸦片战争观后感
2015/06/09 职场文书
MySQL笔记 —SQL运算符
2022/01/18 MySQL