WordPress主题开发中如何进行密码验证

平时我们在开发 wordpress 主题的时候一般很少会用到自己写代码去验证用户输入的登录密码是否和数据库中的用户密码相同,但是最近我们在开发我们官网的小程序(已 WordPress 作为后端进行的小程序开发)的时候,由于我们要实现的是 PC 网站和小程序数据同步,所以在用户微信授权登录后需要已经在我们 PC 网站上注册过账号的用户在小程序端绑定我们的 PC 端的账号和密码,这样才能实现 PC 端和小程序端的用户信息的同步。

在做账号绑定的时候,我们的逻辑是,小程序获取到微信登录用户的 openid 以及头像、姓名、性别、城市等用户信息后,用户在账号绑定页面输入要绑定的用户名和密码,然后小程序将用户填写的用户名、密码、头像、性别、城市等信息发送到后端,后端接收到用户小程序提交过来的信息后,首先到数据库中查询是否有 和传过来的用户名相等的用户 ID,如果有的话,再去比较数据库中的密码和小程序传过来的密码是否一致,如果一致的话,就使用这个用户 ID 更新其他字段信息,完成绑定。
WordPress主题开发中如何进行密码验证-云模板如果看过 WordPress 数据库中用户信息的朋友应该会发现,数据库中保存的密码字段的值并不是我们可见的字符串形式,而是通过了加密的密码,但是小程序传过来的密码一般就是字符串的形式,比如“12345678”,如果直接拿着两个密码去做对比,结果肯定是不相等的。

幸好,WordPress 自带的有一个函数可以将字符串密码和加密后的密码直接做对比,返回结果为真或假,这个函数就是:wp_check_password(“字符串密码”,”加密后的密码”,”用户 ID(这个是可选的)”)。如果返回真说明密码一致,否则就是不一致。

最后给大家看一下在本项目中我们用到的账号绑定的代码:

  1. //用户账户绑定
  2. function user_bind() {
  3.    $username = $_POST["username"];
  4.    $openid = $_POST["openid"];
  5.    $nickname = $_POST["nickname"];
  6.    $gender = $_POST["gender"];
  7.    $city = $_POST["city"];
  8.    $password = $_POST["password"];
  9.    global $wpdb;
  10.    $usernamecheck = $wpdb->get_results("SELECT ID,user_pass FROM wp_users WHERE user_login='$username'");
  11.    $user_id = $usernamecheck[0]->ID;
  12.    $user_pass = $usernamecheck[0]->user_pass;
  13.    $userpassright = wp_check_password($password,$user_pass,$user_id);
  14.    if($user_id && $userpassright){
  15.        update_user_meta($user_id,'nickname',$nickname);
  16.        update_user_meta($user_id,'useropenid',$openid);
  17.        update_user_meta($user_id,'usercity',$city);
  18.        update_user_meta($user_id,'gender',$gender);
  19.        return json_encode($user_id);
  20.        die();
  21.    } else {
  22.        return json_encode(0);
  23.        die();
  24.    }
  25. }

原创文章,作者:DavidWu,如若转载,请注明出处:https://www.davidwu.net/archives/83922

WordPress安全防护插件
服务项目 服务内容 收费标准(元)
主题/插件汉化 汉化团队WordPress主题/插件,翻译率95% (以标的主题/插件的句子数量为准)
服务器环境配置 基于您现有服务器,搭建配置网站运行环境,结合我们多年来实战经验,可完美支持WordPress等PHP程序运行,并配置伪静态规则、优化目录权限等问题。服务器我们强烈推荐使用Linux系统。 100元/次
网站托管 若贵站目前尚无技术人员,无法完成服务器环境配置,可选择我们的网站托管服务,直接交付正常运行的WordPress站点,并且无需担心服务器的后续维护工作,一切都由我们来帮您完成。 标配套餐:1000元/年/站点 高配套餐:联系客服获取
网站加速优化 从服务器后端配置优化到WordPress数据库缓存、前端页面缓存、JS和CSS压缩合并,全方位优化网站加载速度,实现秒开。(此服务仅针对(云)服务器/VPS) 500元/次(仅站内优化200元/次)
主题配置 本站所有主题均支持,可快速实现,若有任何问题可以咨询客服解决,若您希望我们提供配置服务,可选购此服务。 英文主题安装 60元/次 汉化主题安装 30元/次
HTTPS配置 HTTPS已经不断普及,并且有着更高的安全性以及SEO上的优待。该服务收取的为服务费,SSL证书产生的费用请自行承担。 100元/次
网站搬家 迁移网站所有文件和数据库信息、网站相关配置的调整、以及迁移中的疑难问题故障排除。 标准收费:500元/次 若网站数据量大,需协商
网站运维 提供整站的运维服务,保证网站正常运行。包含:网站故障定位及排除、网站数据备份和恢复、网站攻击及木马等问题的处理等 标准收费:2000元/年 IP 5000以上需协商

发表评论

电子邮件地址不会被公开。 必填项已用*标注

51建站客服微信二维码
点击这里购买