《使用ThinkPHP6开发项目》 - 登录接口三【表单验证】

《使用ThinkPHP6开发项目》 - 登录接口一-CSDN博客

https://blog.csdn.net/centaury32/article/details/134974860

在设置用户登录时,由于安全问题会对登录密码进行加密

表单验证这里也可以使用ThinkPHP6自带的验证规则,创建一个验证管理员的文件

php 复制代码
php think make:validate admin@SystemAdmin

在文件中写入我们要验证的字段

php 复制代码
app\admin\validate\SystemAdmin.php
<?php
declare (strict_types = 1);

namespace app\admin\validate;

use think\Validate;

class SystemAdmin extends Validate
{
    /**
     * 定义验证规则
     * 格式:'字段名' =>  ['规则1','规则2'...]
     *
     * @var array
     */
    protected $rule = [
        'account' => 'require|alphaDash',
        'password' => 'require|alphaDash'
    ];

    /**
     * 定义错误信息
     * 格式:'字段名.规则名' =>  '错误信息'
     *
     * @var array
     */
    protected $message = [];
}

在Passport.php控制器文件中引用验证文件

php 复制代码
use think\exception\ValidateException; 
use app\admin\validate\SystemAdmin as SystemAdminValidate;

在方法中使用验证方法

php 复制代码
try{
    validate(SystemAdminValidate::class)->check($param); // 验证表单数据 #$param表单数据
    ......
}catch(ValidateException $e){
    return json(['status'=>500, 'msg'=>$e->getError()]); // 验证不通过返回提示信息,返回格式可根据自己的代码进行调整
}
php 复制代码
<?php
declare (strict_types = 1);

namespace app\admin\controller;

use think\exception\ValidateException;
use app\admin\validate\SystemAdmin as SystemAdminValidate;
use app\admin\service\SystemAdmin as SystemAdminService;

class Passport extends SystemAdminService
{
    //登录
    public function login()
    {
        $param = request()->param();
        try{
            validate(SystemAdminValidate::class)->check($param);
            $result = self::AdminLogin($param);
            return json($result);
        }catch(ValidateException $e){
            return json(['status'=>500, 'msg'=>$e->getError()]);
        }
    }
}

验证的提示信息也可以自定义

php 复制代码
protected $message = [
    'account.require' => '用户名不能为空',
    'account.alphaDash' => '用户名只能是字母、数字和下划线_及破折号-',
];
php 复制代码
app\admin\validate\SystemAdmin.php
<?php
declare (strict_types = 1);

namespace app\admin\validate;

use think\Validate;

class SystemAdmin extends Validate
{
    /**
     * 定义验证规则
     * 格式:'字段名' =>  ['规则1','规则2'...]
     *
     * @var array
     */
    protected $rule = [
        'account' => 'require|alphaDash',
        'password' => 'require|alphaDash'
    ];

    /**
     * 定义错误信息
     * 格式:'字段名.规则名' =>  '错误信息'
     *
     * @var array
     */
    protected $message = [
        'account.require' => '用户名不能为空',
        'account.alphaDash' => '用户名只能是字母、数字和下划线_及破折号-',
    ];
}

这样验证的提示信息就变成了自定义的信息

这样,登录表单的验证就完成了

由于有些接口需要登录凭证,所以在登录成功后需要返回登录令牌Token

相关推荐
hqwest1 天前
码上通QT实战02--登录设计
开发语言·qt·登录·ui设计·qt控件·qt布局·qt登录
Tancenter1 天前
支付宝小程序的用户登录/注册流程
小程序·登录·注册·支付宝
hqwest2 天前
码上通QT实战03--登录逻辑
开发语言·qt·登录·嵌入式实时数据库·界面设计
Piri_LogicBldr6 天前
【验证技能树】UVM 源码解读06 -- Objection 的完整源码解剖
uvm·验证
阿星智力囊1 个月前
Thinkphp6+nginx环境报错信息不显示,接口直接报500和CORS跨域(错误的引导方向),真坑啊
运维·nginx·php·thinkphp6
佛祖让我来巡山1 个月前
⚠️登录认证功能的成长过程:整体概述
安全·登录·springsecurity·登录认证·认证授权
bcgbsh1 个月前
身份认证状态的存储与传递( Spring Boot篇 )
springboot·登录
Damon小智2 个月前
HarmonyOS应用开发-低代码开发登录页面(超详细)
低代码·harmonyos·鸿蒙·登录·arcts·arcui·griditem
課代表3 个月前
Acrobat DC 文本域表单验证中的 js 使用
javascript·正则表达式·表单验证·数据完整性·字段验证·事件对象·自定义验证
openHiTLS密码开源社区4 个月前
【密码学基础】加密消息语法 CMS:给数字信息装个 “安全保险箱”
cms·加密·签名·验证·加密消息语法