详解php中的password_verify 和 password_hash密码验证

 更新时间:2023年08月21日 09:53:54   作者:程序员老狼  
验证密码是否和指定的散列值匹配,password_verify() 与 crypt() 兼容,因此,由 crypt() 创建的密码散列可以用于 password_verify() 一起使用,这篇文章主要介绍了php的password_verify 和 password_hash密码验证,需要的朋友可以参考下

password_hash() 使用足够强度的单向散列算法创建密码的散列(hash)。

当前支持的算法:

  • PASSWORD_DEFAULT  - 使用 bcrypt 算法 (PHP 5.5.0 默认)。 注意,该常量会随着 PHP 加入更新更高强度的算法而改变。 所以,使用此常量生成结果的长度将在未来有变化。 因此,数据库里储存结果的列可超过60个字符(最好是255个字符)。
  • PASSWORD_BCRYPT  - 使用  CRYPT_BLOWFISH  算法创建散列。 这会产生兼容使用 "$2y$" 的 crypt()。 结果将会是 60 个字符的字符串, 或者在失败时返回  false
  • PASSWORD_ARGON2I  - 使用 Argon2i 散列算法创建散列。 只有在 PHP 编译时加入 Argon2 支持时才能使用该算法。
  • PASSWORD_ARGON2ID  - 使用 Argon2id 散列算法创建散列。 只有在 PHP 编译时加入 Argon2 支持时才能使用该算法。

PASSWORD_BCRYPT  支持的选项:

  • salt (string) - 手动提供散列密码的盐值(salt)。这将避免自动生成盐值(salt)。

省略此值后,password_hash() 会为每个密码散列自动生成随机的盐值。这种操作是有意的模式。

警告

盐值(salt)选项已废弃(deprecated)。 现在最好仅选择使用默认产生的盐值。 从 PHP 8.0.0 起,明确指定的 salt 值会被忽略。

  • cost  (int) - 代表算法使用的 cost。crypt() 页面上有 cost 值的示例。

省略时,默认值是  10 。 这个 cost 是个不错的底线,但也许可以根据自己硬件的情况,加大这个值。

PASSWORD_ARGON2I  和  PASSWORD_ARGON2ID  支持的选项:

  • memory_cost  (int) - 计算 Argon2 散列时的最大内存(单位:KB)。默认值:  PASSWORD_ARGON2_DEFAULT_MEMORY_COST
  • time_cost  (int) - 计算 Argon2 散列时最多的时间。默认值:  PASSWORD_ARGON2_DEFAULT_TIME_COST
  • threads  (int) - 计算 Argon2 散列时最多的线程数。默认值:  PASSWORD_ARGON2_DEFAULT_THREADS

加密:

echo password_hash("rasmuslerdorf", PASSWORD_BCRYPT)

验证:

<?php
// 想知道以下字符从哪里来,可参见 password_hash() 示例
$hash = '$2y$07$BCryptRequires22Chrcte/VlQH0piJtjXl.0t1XkA8pw9dMXTpOq';
if (password_verify('rasmuslerdorf', $hash)) {
    echo 'Password is valid!';
} else {
    echo 'Invalid password.';
}
?>

到此这篇关于php的password_verify 和 password_hash密码验证的文章就介绍到这了,更多相关php密码验证内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • tp5实现微信小程序多图片上传到服务器功能

    tp5实现微信小程序多图片上传到服务器功能

    这最近在做一个教育类的小商城的微信小程序,用到了上传多个图片文件到服务器端。下面脚本之家小编给大家带来了tp5实现微信小程序多图片上传到服务器的方法,需要的朋友可以参考下
    2018-07-07
  • typecho插件编写教程(一):Hello World

    typecho插件编写教程(一):Hello World

    这篇文章主要介绍了typecho插件编写教程(一):Hello World,本文讲解了插件的文件结构、插件信息、插件结构、插件流程等内容,需要的朋友可以参考下
    2015-05-05
  • 如何用PHP实现插入排序?

    如何用PHP实现插入排序?

    本篇文章,小编为大家介绍一下关于如何用PHP实现插入排序的方法,有需要的朋友可以参考一下
    2013-04-04
  • thinkphp3.2实现跨控制器调用其他模块的方法

    thinkphp3.2实现跨控制器调用其他模块的方法

    这篇文章主要介绍了thinkphp3.2实现跨控制器调用其他模块的方法,结合实例形式分析了thinkPHP跨模块、跨控制器调用方法的常见操作技巧,需要的朋友可以参考下
    2017-03-03
  • 使用PHP编写发红包程序

    使用PHP编写发红包程序

    微信发红包是最近非常火的一件事情,大家或多或少的都发过或者收到过红包,那么下面来看一个我们在生活中常碰到的一个php实现微信红包的程序算法,希望这个程序对各位做微信开的朋友会带来帮助.
    2015-07-07
  • PHP处理会话函数大总结

    PHP处理会话函数大总结

    在PHP开发中,比起Cookie,Session 是存储在服务器端的会话,相对安全,并且不像 Cookie 那样有存储长度限制,PHP处理会话函数包括:session_start、session_register、session_is_registered、session_unregister、Session_destroy等等,这里详细介绍下php处理会话函数
    2015-08-08
  • Laravel5.1 框架关联模型之后操作实例分析

    Laravel5.1 框架关联模型之后操作实例分析

    这篇文章主要介绍了Laravel5.1 框架关联模型之后操作,结合实例形式分析了laravel5.1框架写入关联模型、更新关联关系等相关操作技巧与注意事项,需要的朋友可以参考下
    2020-01-01
  • laravel中Join语法以及使用Join多个条件

    laravel中Join语法以及使用Join多个条件

    这篇文章主要介绍了laravel中Join语法以及使用Join多个条件,文中不仅介绍了join用法而且讲述了多种方法很详细,有感兴趣的同学可以学习下
    2021-03-03
  • Codeigniter注册登录代码示例

    Codeigniter注册登录代码示例

    本示例Codeigniter注册登录代码源自一个codeigniter的项目,现分享下,需要的朋友可以参考下
    2014-06-06
  • 一个简单的网页密码登陆php代码

    一个简单的网页密码登陆php代码

    密码对,就可以看到指定内容, 密码不对就进不去
    2012-07-07

最新评论