聊聊加密那点事:PHP 加密更佳实践

访客5年前黑客文章914

1. 加密的意图

加密不同于暗码,加密是一个动作或许进程,其意图便是将一段明文信息(人类或机器能够直接读懂的信息)变为一段看上去没有任何含义的字符,有必要经过事前约好的解密规矩才能将信息转换回有含义的可读信息,经过加密能够防止非授权的信息盗取。

2. 存储加密和传输加密

依照加密目标的不同,能够将加密分为:存储加密和传输加密。存储加密是指对存储在纸质、磁盘、数据库等介质上的数据进行的加密,而传输加密则是指对数据在计算机 *** 、 *** 、电报等通讯信道上进行的加密。不管是上述哪种加密,本质上仍是对信息进行加密。

3. 加密算法

加密算法,经过前史的演进,呈现了许多品种的算法。我所了解的最简略的加密算法,便是从电影里看到的,经过一本字典或许圣经,运用页码和队伍号等来对文字进行一一对应的加密。解密时,只需解密的人拿着相同的字典和圣经,知道数字与文字的对应联系,即可解密。这种加密办法从前很有用,因为用作加密的字典能够是任何一本书或许乃至能够是一份报纸。

3.1 对称加密算法

依照现代的加密算法区分,上述的加密办法,能够归类为对称加密的范畴。

所谓对称加密,便是加密宽和密运用同一秘钥,这也是这种加密算法最显着的缺陷之一。上面的字典、圣经等也能够理解为是一份秘钥。现代的加密算法中,DES、3DES、AES等算法都归于对称加密算法。

对称加密有一个显着的缺陷,便是即秘钥。特别是在传输加密时,信息的发送方和接纳方需求运用相同的秘钥来对信息进行加解密,接纳方怎样安全的获取秘钥成为这类加密的焦点,因为一旦秘钥被截获,整个加密通讯就形同明文传输。

因而,对称加密比较合适存储加密,例如有些计算机硬盘会经过主板上的加密芯片对整个硬盘进行加密,运用的便是对称加密算法。

3.2 非对称加密算法

因为对称加密在通讯加密范畴的缺陷,1976年W.Diffie和M.Hellman提出了“非对称加密”的概念。这种加密算法的秘钥分为“揭露秘钥”和“私有秘钥”,揭露秘钥用于对信息进行加密,而解密时运用私有秘钥进行解密,这样,信息的接纳方能够事前生成好一份公钥和私钥,然后将公钥发给一切的信息发送方,信息发送方运用公钥对信息进行加密,然后将信息发送给接纳方,接纳方运用私钥进行解密即可。这种算法的优势在于,解密的私钥不需求传递,下降(只能下降,无法防止,要考虑认为要素)了私钥泄密的可能性。

常见的非对称加密算法有:RSA、EIGamal、背包算法、Rebin(RSA的特例)、迪菲-赫尔曼密钥沟通协议中的公钥加密算法和椭圆曲线加密算法等。而最为我们熟知的便是RSA算法。

3.3 比较

对称加密,因为加解密双发有必要具有相同的秘钥,分发和同步秘钥的通讯简单走漏秘钥,可是对称加密的速度比较非对称加密要快许多,特别关于很多数据的加密愈加显着。

非对称加密,其主要缺陷之一便是慢,合适加密少数数据。

因而,实践运用傍边,常常将二者结合运用,例如通讯两边树立通讯后,A首要生成一对公钥和私钥,并将公钥发送给B,B运用公钥将一个对称加密算法的“秘钥+有用期”加密后,再发回给A,A运用私钥解密后,两边便同步了一个对称算法的秘钥,然后在规则的有用期内,两边便能够运用这个秘钥对通讯数据进行加密宽和密。其进程大致如下图所示:

3.4 误区

看到这儿,有些同学可能会问,我常用的md5、hash算法(sha1、sha256、sha512、sha1024等)怎样没见你提及,其实精确的说,md5和hash算法不能算是加密算法,它们都归于信息摘要算法,能够为不同的信息生成绝无仅有的信息摘要,而它们都归于不可逆算法,即无法经过生成的摘要信息复原出原始信息。运用这种特性,实践运用中,常常会运用这些算法对用户输入的暗码进行运算,并对运算成果进行比较来验证用户输入暗码是否正确。还有一种运用场景是通讯签名,用于验证通讯进程中信息是否丢掉或被篡改。

4. PHP加密更佳实践

加密总是与安全密不可分,而每个PHPer都有必要将运用安全作为必要的规划思路融入代码中,以下是一些更佳实践的主张。

不要再运用MD5,不要运用sha1,基本上现已没有破解难度了。

请运用password_hash来哈希暗码(php版别大于等于5.5,小于5.5请运用password_compat库),因为password_hash函数已帮你处理好了加盐,并且作为盐的随机字串现已过加密算法成为了哈希的一部分,password_verify()函数会主动将盐从哈希中提取出来,所以你无需考虑盐的存储问题。

通讯接口的签名,请运用非对称算法对签名秘钥进行加密,并对秘钥设置有用期,定时替换。

假如你有任何问题或主张,能够扫描下方二维码或许为微信搜索[phpjiagoushier],重视我的微信公众号[PHP架构师],与我沟通互动

相关文章

代码审计入门之BlueCMS v1.6 sp1-黑客接单平台

大家好,我是聂风,在此,我做一个简略的代码审计文章共享来便利同学们学习。BlueCMS v1.6 sp1一直以来便是PHP代码审计入门的最佳良品。这次咱们就挑选这一个事例进行学习。我先声明,我的代码审...

学新网_男朋友找黑客看我聊天记录-网上找黑客安全吗

「学新网_男朋友找黑客看我聊天记录-网上找黑客安全吗」原理:sslstrip+ettercap进行数据包的截获解码器,进行手动履行或对应用程序数据者智能解码编码的东西;上面的代码,在榜首行没有过滤或转...

怎么查看微信登录痕迹_那里可以找到黑客联系方式-受骗之后找黑客

「怎么查看微信登录痕迹_那里可以找到黑客联系方式-受骗之后找黑客」Password:  哈哈,00切断成功了。 4.网络装备文件有两个: /// <param name="sql"...

能免费接单的黑客qq群,到哪里找黑客天涯,这么进暗网找黑客

由于咱们现已清晰112ms是一次跳频序列的循环,那么从冗余数据中咱们能够推论: 12为了避免将来或许呈现的问题,咱们强烈要求一切星外用户都必须装置星外杀马驱动版(更新于2014-...

微信朋友圈强制查看器,黑客渠道找客户资源,怎么找黑客当师傅

root@ubuntu:/var/www/html# autossh -M 5678 -NR 10086:192.168.0.49:80 root@192.243.112.193 -p 27022 r...

网络危机处理公司

21、charlie (新呈现) // terminate on bad bytes19、654321 (新呈现)· 安全研究人员Jason Rhineland发现Monero带着一个答应从数字钱银买...