PHP 几个常用的加密函数
一、加密类型:
1.单向散列加密
就是把任意长度的信息进行散列计算,得到固定长度的输出,这个散列计算过程是单向的,即不能对固定长度的输出信息进行计算从而得到输入信息。
(1)特征:雪崩效应、定长输出和不可逆。
(2)作用是:确保数据的完整性。
(3)加密算法:md5(标准密钥长度128位)、sha1(标准密钥长度160位)、md4、CRC-32
2.对称散列加密
对称加密是指加密和解密是使用同一个密钥,或者可以互相推算。
(1)加密方和解密方使用同一个密钥。
(2)加密解密的速度比较快,适合数据比较长时的使用。
(3)密钥传输的过程不安全,且容易被破解,密钥管理也比较麻烦。
(4)加密算法:DES(Data Encryption Standard)、3DES、AES(Advanced Encryption Standard,支持128、192、256、512位密钥的加密)、Blowfish。
3.非对称散列加密
非对称加密和解密使用的不是同一个密钥,其中一个对外公开,称作公钥,另一个只有所属者知道,称作私钥。
(1)每个用户拥用一对密钥加密:公钥和私钥。
(2)公钥加密,私钥解密;私钥加密,公钥解密。
(3)公钥传输的过程不安全,易被窃取和替换。
(4)由于公钥使用的密钥长度非常长,所以公钥加密速度非常慢,一般不使用其去加密。
(5)某一个用户用其私钥加密,其他用户用其公钥解密,实现数字签名的作用。
(6)公钥加密的另一个作用是实现密钥交换。
(7)加密和签名算法:RSA、ELGamal。
(8)公钥签名算法:DSA。
注释:
(1)RSA:由 RSA 公司发明,是一个支持变长密钥的公共密钥算法,需要加密的文件块的长度也是可变的;
(2)DSA(Digital Signature Algorithm):数字签名算法,是一种标准的 DSS(数字签名标准);
(3)由于非对称加密算法的运行速度比对称加密算法的速度慢很多,当我们需要加密大量的数据时,建议采用对称加密算法,提高加解密速度。
对称加密算法不能实现签名,因此签名只能非对称算法。
(4)由于对称加密算法的密钥管理是一个复杂的过程,密钥的管理直接决定着他的安全性,因此当数据量很小时,我们可以考虑采用非对称加密算法。
(5)在实际的操作过程中,我们通常采用的方式是:采用非对称加密算法管理对称算法的密钥,然后用对称加密算法加密数据,这样我们就集成了两类加密算法的优点,既实现了加密速度快的优点,又实现了安全方便管理密钥的优点。
二、php中常用的加密函数:
1.MD5加密:
string md5 ( string $str [, bool $raw_output = false ] )
(1)md5()默认情况下以 32 字符十六进制数字形式返回散列值,它接受两个参数,第一个为要加密的字符串,第二个为raw_output的布尔值,
默认为false,如果设置为true,md5()则会返回原始的 16 位二进制格式报文摘要
(2)md5()为单向加密,没有逆向解密算法,但是还是可以对一些常见的字符串通过收集,枚举,碰撞等方法破解
2.Crypt加密:
string crypt ( string $str [, string $salt ] )
(1)crypt()接受两个参数,第一个为需要加密的字符串,第二个为盐值(就是加密干扰值,如果没有提供,则默认由PHP自动生成);
返回散列后的字符串或一个少于 13 字符的字符串,后者为了区别盐值。
(2)crypt()为单向加密,跟md5一样。
3.Sha1加密:
string sha1 ( string $str [, bool $raw_output = false ])
(1)跟md5很像,不同的是sha1()默认情况下返回40个字符的散列值,传入参数性质一样,第一个为加密的字符串,
第二个为raw_output的布尔值,默认为false,如果设置为true,sha1()则会返回原始的20 位原始格式报文摘要
(2)sha1()也是单行加密,没有逆向解密算法
4.Urlencode加密:
string urlencode ( string $str )
(1)一个参数,传入要加密的字符串(通常应用于对URL的加密)
(2)urlencode为双向加密,可以用urldecode来加密(严格意义上来说,不算真正的加密)
(3)返回字符串,此字符串中除了 -_. 之外的所有非字母数字字符都将被替换成百分号(%)后跟两位十六进制数,空格则编码为加号(+)。
(3)常见的urlencode()的转换字符
? => %3F= => %3D% => %25& => %26\ => %5C
空格 => %5C
5.base64编码加密:
string base64_decode ( string $encoded_data )
(1)base64_encode()接受一个参数,也就是要编码的数据(这里不说字符串,是因为很多时候base64用来编码图片)
(2)base64_encode()为双向加密,可用base64_decode()来解密
转载于:https://www.cnblogs.com/Uncle-liu/p/7683484.html
PHP 几个常用的加密函数相关推荐
- php 字符 hash_php常用hash加密函数
本文实例讲述了php常用hash加密函数.分享给大家供大家参考.具体分析如下: $hash_list=hash_algos(); //返回注册的hash规则列表 print_r($hash_list ...
- PHP的几个常用加密函数
在php的开发过程中,常常需要对部分数据(如用户密码)进行加密 一.加密类型: 1.单向散列加密 就是把任意长度的信息进行散列计算,得到固定长度的输出,这个散列计算过程是单向的,即不能对固定长度的输出 ...
- PHP类参数_100 个最常用的 PHP 函数
下面的列表是最常用的前100个 PHP 函数:它们是最常用的 PHP 中自带的函数. 这些函数被命名使用,并从1到100进行排序. 其他的4500个函数现在还没在排名中. 下面频率列表表示在 PHP ...
- PHP加密函数与解密函数详解
本篇文章主要为大家详细介绍了PHP中的加密函数与解密函数 Php常用的加密函数有 MD5加密(不可逆).Crypt加密(不可逆).Sha1加密(不可逆).Urlencode加密(可逆) base64编 ...
- php加密函数与解密函数
去网上找了下. Php常用的加密函数有 MD5加密(不可逆).Crypt加密(不可逆).Sha1加密(不可逆).Urlencode加密(可逆) base64编码加密(可逆) 还是见识的太少,这其中我只 ...
- 常用的几个PHP加密函数
阅读目录 1.前言 2.不可逆加密函数 3.可逆转的j加密函数 回到顶部 1.前言 PHP加密方式分为单项散列加密,对称加密,非对称加密这几类. 像常用的MD5.hash.crypt.sha1这种就是 ...
- mysql信息函数和加密函数_MYSQL 常用函数(数学、字符串、日期时间、系统信息、加密)...
一.数学函数 数学函数主要用于处理数字,包括整型.浮点数等. ABS(x) 返回x的绝对值 SELECT ABS(-1) -- 返回1 CEIL(x),CEILING(x) 返回大于或等于x的最小整数 ...
- C函数加密实现及常用字符串处理函数的使用
getpass() getpass()函数用于从控制台输入一行字符串,关闭了回显(输入时不显示输入的字符串),适用于用密码的输入. 语法 char * getpass (const char * pr ...
- MYSQL——常用运算符和函数
MYSQL的常用运算符 1 字符函数 CONCAT() 字符连接 CONCAT_WS() 使用指定的分隔符进行字符连接 FORMAT() 数字格式化 LOWER() 转换成小写 ...
最新文章
- webstorm设置git pull快捷键Ctrl+Shift+P
- 什么是软件定义数据中心
- python中统计计数的几种方法
- poj 2948 Martian Mining (dp)
- HANA Calculation View
- Confluence 6 自动添加用户到用户组
- 我的LINUX学习之路之二十一之web服务器简单搭建
- awk实战:文件里面全是数字,实现大于100的求和并打印出所在行和这些数字的总和...
- ubuntu lamp(apache+mysql+php) 环境搭建及相关扩展更新
- dbForge mysql数据库比对
- 完全采用CSS的CROSS BROWSER TABBED PAGES
- 计算两个日期之间相差的天数(带带负数) 支持格式YYYY-mm-dd和YYYY-mm-dd HH:mm:ss...
- android设置计算器页面布局,Android计算器界面布局
- c语言自学教程——博文总结
- 忘记Jenkins管理员密码的解决办法
- c语言程序设计精髓 第13周练兵题
- 未来交互设计师的5种转型方式
- Apache Zookeeper基本介绍
- 对互联网产品运营的理解
- biosrecovery什么意思_recovery是什么意思
热门文章
- Java基础知识强化53:经典排序之选择排序(SelectionSort)
- UTF-8 + BOM引起的模板空格问题(PHP使用任何模板引擎貌似都有此问题)
- CSS水平垂直居中布局方案概述
- 文献阅读 - Genome-wide consequences of deleting any single gene
- 不带parent指针的successor求解
- UESTC1608 暑假集训
- 杭电2019 数列有序!(STL解法)
- Shank的大步小步算法(Shank‘s Baby-Step-Giant-Step Algorithm)
- sql中怎么根据汉字的拼音首字母查询
- GTimeSheet正式启用官方网站