《使用ThinkPHP6开发项目》 - 登录接口二

《使用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='后台管理员表';

《使用ThinkPHP6开发项目》 - 登录接口二_第1张图片

2)查看表数据

3)配置数据库,《使用ThinkPHP6开发项目》 - 设置项目环境变量-CSDN博客

4)创建模型文件,模型文件名可与表名一致,使用驼峰式命名

php think make:model admin@SystemAdmin

《使用ThinkPHP6开发项目》 - 登录接口二_第2张图片

如果文件名与表名不一致,则要定义表名

//文件名与表名不一致时
protected $name = 'system_admin'; // 表名

// 如果表前缀与数据库配置的表前缀不一致,则要设置表全名
protected $table = 'cms_system_admin';

 表主键如果为id,则默认主键为id,若不是id,则需要设置主键值

protected $pk = 'uid'; // uid为表主键

这里可以使用service去处理登录方法

5)创建service文件,使用驼峰式命名

php think make:service admin@SystemAdmin

《使用ThinkPHP6开发项目》 - 登录接口二_第3张图片修改admin\service\SystemAdmin.php文件中,创建AdminLogin方法

app\admin\service\SystemAdmin.php
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
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);
    }
}

《使用ThinkPHP6开发项目》 - 登录接口二_第4张图片

到这登录接口就完成了

你可能感兴趣的:(数据库,MySQL,ThinkPHP6,登录,PHP,模型,服务)