php 密码加密(password_hash)

摘要:
password_Hash()使用了一个强大的哈希算法,password_HHash()是crypt()的一个简单封装,因此建议使用password()Hash()Array$options])验证密码是否与带有hash_Verify(string$password,if(password_Verify('rasmuslerdorf';

写这篇文章的原因:

  1. 由于快速的散列算法,所以不推荐使用md5这个函数获得密码。
  2. password_hash()使用了一个强的哈希算法,来产生足够强的盐值,并且会自动进行合适的轮次。password_hash()是crypt()的一个简单封装,并且完全与现有的密码哈希兼容。所以推荐使用password_hash()。

创建密码的哈希

string password_hash ( string $password , integer $algo [, array $options ] )

验证密码是否和哈希匹配

boolean password_verify ( string $password , string $hash )

例:

<?php
$hash = password_hash("rasmuslerdorf", PASSWORD_DEFAULT);

if (password_verify('rasmuslerdorf', $hash)) {
    echo 'Password is valid!';
} else {
    echo 'Invalid password.';
}

使用技巧说明:

创建密码时不要自己设置盐值

原因:强烈建议不要自己为这个函数生成盐值(salt)。只要不设置,它会自动创建安全的盐值。 就像以上提及的,在 PHP 7.0 提供 salt选项会导致废弃(deprecation)警告。 未来的 PHP 发行版里,手动提供盐值的功能可能会被删掉。

在自己的服务器上做基准测试,调整 cost 参数直至函数时间开销小于 100 毫秒(milliseconds)。

例:

<?php
/**
 * 这个例子对服务器做了基准测试(benchmark),检测服务器能承受多高的 cost
 * 在不明显拖慢服务器的情况下可以设置最高的值
 * 8-10 是个不错的底线,在服务器够快的情况下,越高越好。
 * 以下代码目标为  ≤ 100 毫秒(milliseconds),
 * 适合系统处理交互登录。
 */
$timeTarget = 0.1; // 100 毫秒(milliseconds) 

$cost = 8;
do {
    $cost++;
    $start = microtime(true);
    password_hash("test", PASSWORD_BCRYPT, ["cost" => $cost]);
    $end = microtime(true);
} while (($end - $start) < $timeTarget);

echo "Appropriate Cost Found: " . $cost;

结果:

Appropriate Cost Found: 10
  • 1

PASSWORD_DEFAULT - 使用 bcrypt 算法 (PHP 5.5.0 默认)。 注意,该常量会随着 PHP 加入更新更高强度的算法而改变。 所以,使用此常量生成结果的长度将在未来有变化。 因此,数据库里储存结果的列可超过60个字符(最好是255个字符)。

免责声明:文章转载自《php 密码加密(password_hash)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇GIS数据的查找,插入,删除,更新(ArcEngine)python+opencv图像投影、水平投影、垂直投影下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Java中使用Jedis连接Redis对Hash进行操作的常用命令

场景 Centos中Redis的下载编译与安装(超详细): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103967334 Redis的启动和关闭(前台启动和后台启动): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details...

Dubbo学习笔记7:Dubbo的集群容错与负载均衡策略

Dubbo的集群容错策略 正常情况下,当我们进行系统设计时候,不仅要考虑正常逻辑下代码该如何走,还要考虑异常情况下代码逻辑应该怎么走。当服务消费方调用服务提供方的服务出现错误时候,Dubbo提供了多种容错方案,缺省模式为failover,也就是失败重试。 Dubbo提供的集群容错模式 下面看下Dubbo提供的集群容错模式: Failover Cluster...

Lua入门

变量 局部变量用local定义,可以平行赋值;没有加local的都是全局变量 local a ,b = c ,d 函数定义 function foo(argv) ... end 这里我们还可以在函数内部定义匿名函数(闭包的概念) function foo(argv) ... function inner...

CVE-2020-1472相关杂谈

CVE-2020-1472是微软八月修复的一个严重的权限提升漏洞(并于昨天2020年9月15日secura发布了相关的漏洞细节,随后相关exp被构造发布),通过Netlogon 远程协议 (MS-NRPC) 建立与域控制器连接安全通道时,存在特权提升的利用点,该漏洞的CVSS分高达10分,攻击者只需要在内网中有一个立足点,就可以远程获取域控的管理员权限。...

su sudo 限制root远程登录

su命令 su用来切换用户。 su -  用户    是完全切换,就是变成另一个用户。 su 用户       是不完全切换,变量还是上一个用户。 注释:完全切换,就是在切换时加载用户的环境变量.bash_history,.bash_logout,.bash_profile 通过-c参数来不切换用户,以这个用户的身份来执行一些命令: [root@ting...

用Javascript进行HTML转义(分享)

  众所周知页面上的字符内容通常都需要进行HTML转义才能正确显示,尤其对于Input,Textarea提交的内容,更是要进行转义以防止javascript注入攻击。   通常的HTML转义主要是针对内容中的"<",">","&",以及空格、单双引号等。但其实还有很多字符也需要进行转义。具体的可以参考这篇文章。   ** 1、HTML转...