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

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

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

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

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

php think make:validate admin@SystemAdmin

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

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控制器文件中引用验证文件

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

在方法中使用验证方法

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

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

protected $message = [
    'account.require' => '用户名不能为空',
    'account.alphaDash' => '用户名只能是字母、数字和下划线_及破折号-',
];
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

  • 20
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
开发ThinkPHP微信登录接口,你需要按照以下步骤进行操作: 1. 首先,你需要在微信开放平台上注册一个开发者账号,并创建一个新的应用程序。 2. 在ThinkPHP项目中,你需要安装EasyWeChat扩展包来实现微信登录接口开发。可以使用Composer来安装,命令如下: ``` composer require overtrue/wechat ``` 3. 在ThinkPHP项目中,你需要创建一个控制器来处理微信登录请求,例如: ``` namespace app\controller; use think\Controller; use EasyWeChat\Factory; class WechatController extends Controller { public function login() { $config = [ 'app_id' => 'your-app-id', 'secret' => 'your-app-secret', 'oauth' => [ 'scopes' => ['snsapi_userinfo'], 'callback' => '/wechat/callback', ], ]; $app = Factory::officialAccount($config); $response = $app->oauth->redirect(); return $response; } public function callback() { $config = [ 'app_id' => 'your-app-id', 'secret' => 'your-app-secret', ]; $app = Factory::officialAccount($config); $user = $app->oauth->user(); // 保存用户信息到数据库等操作 return redirect('/user/profile'); } } ``` 在上面的代码中,`login()`方法用于重定向到微信授权页面,`callback()`方法用于处理授权回调并获取用户信息。 4. 在ThinkPHP项目中,你需要创建一个路由来指定微信登录请求的URL,例如: ``` Route::get('wechat/login', 'WechatController@login'); Route::get('wechat/callback', 'WechatController@callback'); ``` 5. 最后,你需要在微信开放平台上配置授权回调URL,例如: ``` http://your-domain.com/wechat/callback ``` 这样,你就可以在ThinkPHP项目中实现微信登录接口了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃瓜的程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值