PHP实现数据加密的方法概念

编程

  • 目录
  • 1. 前言
  • 2. PHP常用的加密算法
  • 2.1 md5()加密(单项加密,无法解密)
  • 2.2 crypt()加密(单项加密,无法解密)
  • 2.3 sha1加密(单向加密,无法解密)
  • 2.4 URL编码加密(双向加密,可以解密
  • 2.5 base64编码加密(双向加密,可以解密)
  • 3.信息加密技术
  • 3.1 单项散列加密(MD5加密,crypt()加密,sha1加密)
  • 3.2 对称散列加密
  • 3.3 非对称散列加密

1. 前言

关于PHP的加密技术,主要使用到的技术有md5()加密,crypt()加密,sha1加密,URL编码加密以及base64编码加密;而加密技术又区分为单项散列加密(MD5加密,crypt()加密,sha1加密)、对称散列加密、非对称散列加密。

代码分享:https://github.com/mtdgclub/libraryClass

详见文件Encrypt.class.php

2. PHP常用的加密算法

2.1 md5()加密(单项加密,无法解密)

  • md5(string $str[,bool $raw_output=false]);

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

为了使加密更难破解,可以连续两次加密,如:md5(md5($str))

2.2 crypt()加密(单项加密,无法解密)

  • crypt(string $str[, string $salt]); //返回一个基于UNIX DES算法或系统上其他可用的替代算法的散列字符串。

$slt:加密时的干扰串,使编码更安全。  //如果没有$salt,将随机生成一个干扰串,否则刷新加密密文不变。 当为md5时,以$1$开头,后面接不超过8位的随机字符。

2.3 sha1加密(单向加密,无法解密)

  • sha1(string $str[, bool $raw_output = false]);  //计算字符的sha1散列值

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

2.4 URL编码加密(双向加密,可以解密

  • urlencode(string $str):编码url字符串。 
  • urldecode(string $str):解码已编码的url字符串。

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

  • ? => %3F
  • =  => %3D
  • 空格  => +
  • %  => %25
  • &  => %26
  •  => %5C
  • +  => %2B

2.5 base64编码加密(双向加密,可以解密)

  • base64_encode(string $data):使用base64对data进行编码。
  • base64_decode(string $data[, bool $strict = false]):对使用MIME base64编码的数据进行解码。

//strict:如果输入的数据超除了base64字母表,则返回false。

3.信息加密技术

3.1 单项散列加密(MD5加密,crypt()加密,sha1加密)

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

明文->单向散列算法(salt)->密文

3.2 对称散列加密

对称加密指的是加密和解密使用同一个密钥或者可以相互推算.

明文->加密算法(salt)->密文->解密算法(密钥)->明文

3.3 非对称散列加密

非对称加密和解密使用的不是通风一个密钥,其中一个对外公开被称为公钥,另一个只有所有者知道(一个钥匙一把锁).

明文->加密算法(加密密钥)->密文->解密算法(解密密钥)->明文

以上是 PHP实现数据加密的方法概念 的全部内容, 来源链接: utcz.com/z/515417.html

回到顶部