《使用ThinkPHP6开发项目》 - 登录接口一-CSDN博客
说到登录,这就涉及到数据验证和数据库
这里要创建数据库以及登录要用到的用户表
1)创建管理员表
CREATE TABLE `vanus_system_admin` (`id` smallint(5) unsigned NOT NULL AUTO_INCREMENT COMMENT '管理员表ID',`account` varchar(32) NOT NULL DEFAULT '' COMMENT '管理员账号',`password` varchar(100) NOT NULL DEFAULT '' COMMENT '管理员密码',`avatar` varchar(255) NOT NULL DEFAULT '' COMMENT '管理员头像',`real_name` varchar(16) NOT NULL DEFAULT '' COMMENT '管理员姓名',`role_id` varchar(128) NOT NULL DEFAULT '' COMMENT '管理员权限(menus_id)',`last_ip` varchar(16) NOT NULL DEFAULT '' COMMENT '管理员最后一次登录ip',`last_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '管理员最后一次登录时间',`create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',`login_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '登录次数',`level` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '管理员级别',`status` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '管理员状态:1.有效 0.无效',`is_del` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否删除',PRIMARY KEY (`id`) USING BTREE,KEY `account` (`account`) USING BTREE,KEY `status` (`status`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='后台管理员表';
2)查看表数据
3)配置数据库,《使用ThinkPHP6开发项目》 - 设置项目环境变量-CSDN博客
4)创建模型文件,模型文件名可与表名一致,使用驼峰式命名
php think make:model admin@SystemAdmin
<?php
declare (strict_types = 1);namespace app\admin\model;use think\Model;/*** @mixin \think\Model*/
class SystemAdmin extends Model
{//
}
如果文件名与表名不一致,则要定义表名
//文件名与表名不一致时
protected $name = 'system_admin'; // 表名// 如果表前缀与数据库配置的表前缀不一致,则要设置表全名
protected $table = 'cms_system_admin';
表主键如果为id,则默认主键为id,若不是id,则需要设置主键值
protected $pk = 'uid'; // uid为表主键
<?php
declare (strict_types = 1);namespace app\admin\model;use think\Model;/*** @mixin \think\Model*/
class SystemAdmin extends Model
{protected $table = 'cms_system_admin';protected $pk = 'uid';
}
这里可以使用service去处理登录方法
5)创建service文件,使用驼峰式命名
php think make:service admin@SystemAdmin
修改admin\service\SystemAdmin.php文件中,创建AdminLogin方法
app\admin\service\SystemAdmin.php
<?php
declare (strict_types = 1);namespace app\admin\service;use app\admin\model\SystemAdmin as SystemAdminModel;class SystemAdmin extends \think\Service
{// 管理员登录public static function AdminLogin(array $param){$model = new SystemAdminModel();$info = $model->where('account',$param['account'])->find();if(empty($info)) return ['status'=>500,'msg'=>'用户不存在'];$info = $info->toArray();if($param['password'] == $info['password']){return ['status'=>200,'msg'=>'登录成功'];}else{return ['status'=>500,'msg'=>'密码错误'];}}
}
app\admin\controller\Passport.php
<?php
declare (strict_types = 1);namespace app\admin\controller;use app\admin\service\SystemAdmin;class Passport extends SystemAdmin
{//登录public function login(){$param = request()->param();if(empty($param['account'])) return json(['status'=>201,'msg'=>'账号必填']);if(empty($param['password'])) return json(['status'=>201,'msg'=>'密码必填']);$result = self::AdminLogin($param);return json($result);}
}
到这登录接口就完成了