在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/joshua317/p/4984289.html

PHP的几个常用加密函数相关推荐

  1. php常用加密函数总结

    $var = 123;/*** md5 加密(单项加密.不可逆)* param $var 需要加密的变量(int\float\string\bool\null),资源类型(resource)和复合类型 ...

  2. php md5 64,php加密函数md5,crypt,base64_encode的用法介绍

    介绍下php中自带的加密函数 1,不可逆的加密函数为:md5().crypt() md5() 用来计算 MD5 哈稀.语法为:string md5(string str); crypt() 将字符串用 ...

  3. php中md5加密函数怎么用,php中md5()函数的定义和用法汇总

    PHP加密函数-md5()函数加密什么是MD5()函数?MD5()函数是计算器字符串的 MD5散列值,使用MD5的算法,MD5的全称是Message-Digest Algorithm 5,它的作用是把 ...

  4. php 字符 hash_php常用hash加密函数

    本文实例讲述了php常用hash加密函数.分享给大家供大家参考.具体分析如下: $hash_list=hash_algos();  //返回注册的hash规则列表 print_r($hash_list ...

  5. PHP 几个常用的加密函数

    一.加密类型: 1.单向散列加密 就是把任意长度的信息进行散列计算,得到固定长度的输出,这个散列计算过程是单向的,即不能对固定长度的输出信息进行计算从而得到输入信息. (1)特征:雪崩效应.定长输出和 ...

  6. 常用的几个PHP加密函数

    阅读目录 1.前言 2.不可逆加密函数 3.可逆转的j加密函数 回到顶部 1.前言 PHP加密方式分为单项散列加密,对称加密,非对称加密这几类. 像常用的MD5.hash.crypt.sha1这种就是 ...

  7. mysql信息函数和加密函数_MYSQL 常用函数(数学、字符串、日期时间、系统信息、加密)...

    一.数学函数 数学函数主要用于处理数字,包括整型.浮点数等. ABS(x) 返回x的绝对值 SELECT ABS(-1) -- 返回1 CEIL(x),CEILING(x) 返回大于或等于x的最小整数 ...

  8. 加密机PKCS#11国际加密标准解读-概念和常用接口函数(1)

    PKCS#11是使用非常普遍的密码设备接口,在实际应用中,国密的密码设备应用接口规范GMT0018与之作用相同,在技术体系架构中处于类似的位置. 在密码产品的开发中,按照PKCS#11或者GMT001 ...

  9. php 加密保存mysql_PHP及MYSQL中字符串加密函数

    [IT168 服务器学院]我们在写PHP程序时经常要对用户的口令加密以确保安全,这时就要用到一些加密的函数.我总结了以下几种方法写出来供大家参考. 1.用MYSQL中的加密函数来加密:PASSWORD ...

最新文章

  1. mysql ls命令,Linux 常用 ls命令详解
  2. JFreeChart API(中文)
  3. linux源码编译rpm,Linux的RPM和源码包(CentOS)
  4. maven之build resources resource 详细介绍
  5. 在C#代码中应用Log4Net 中配置文件的解释
  6. Sublime Text 3 快捷键汇总
  7. binutils-2.22编译心得
  8. xshell6保持连接_使用Xshell6+Xftp6连接Linux云服务器(图文教程)
  9. “老师,我写着写着就 强制交卷了……”
  10. 自动编译失效的Oracle数据库对象
  11. c++多线程基础4(条件变量)
  12. CRC32(Cyclic Redundancy Check)循环冗余校验:推导
  13. java代码读写者问题_一整套Java线上故障排查技巧,爱了!
  14. MFC 盾webBrowser打开弹出的页面
  15. Linux忘记开机密码
  16. 27家金融类央企(中投+3政策性银行+5国有银行+中信+光大+4保险集团)(4大资产管理+建银+再保险+保险保障+中诚信托+中央国债+银行金融+科技证券+证券基金)
  17. 风火编程--用pillow对比展示两张图片
  18. 面向对象编写一个计算器
  19. KUKA officelite8.5 “无法建立至KRC的连接”解决办法
  20. 怎么安装打印机驱动?有没有快捷的方法?

热门文章

  1. Exynos1080处理器性能与功耗究竟怎么样?
  2. 你觉得人生最好的年龄段是哪段时间?
  3. 商业认知,新的一年开始了
  4. 穷人变富的过程中,最大的阻碍是什么?
  5. 了解普通人的心理,在销售中非常重要
  6. 建议大家都玩一下自媒体
  7. python之三元表达式嵌套三元表达式解析
  8. Qt4_子类化QTableWidget
  9. 本地Nginx+Hosts配置本地前端代码和后端代码联调
  10. easyui的下拉框combobox在包含的iframe页面里点击不能收回解决办法