data_center/app/api/controller/LoginController.php

64 lines
1.6 KiB
PHP
Raw Normal View History

2023-09-18 09:11:13 +08:00
<?php
namespace app\api\controller;
use app\api\logic\LoginLogic;
use app\common\validate\login\LoginAccountValidate;
use app\common\validate\login\RegisterValidate;
use app\common\validate\login\TokenValidate;
use think\response\Json;
/**
* 登录注册
* Class LoginController
* @package app\api\controller
*/
class LoginController extends BaseApiController
{
// 免登录方法
2023-09-19 10:39:28 +08:00
public array $notNeedLogin = ['register', 'login', 'verify'];
2023-09-18 09:11:13 +08:00
// 注册
public function register(): Json
{
$params = (new RegisterValidate())->post()->goCheck();
$result = LoginLogic::register($params);
if (true === $result) {
return $this->success('注册成功', [], 1, 1);
}
return $this->fail(LoginLogic::getError());
}
// 登录
public function login(): Json
{
$params = (new LoginAccountValidate())->post()->goCheck();
$result = LoginLogic::login($params);
if (false === $result) {
return $this->fail(LoginLogic::getError());
}
return $this->data($result);
}
// 退出
public function logout(): Json
{
2023-09-19 10:39:28 +08:00
$result = LoginLogic::logout($this->userInfo);
if($result){
return $this->success('成功');
}else{
return $this->fail('失败');
}
2023-09-18 09:11:13 +08:00
}
// 验证token
public function verify(): Json
{
$params = (new TokenValidate())->post()->goCheck();
$result = LoginLogic::verifyToken($params);
if (false === $result) {
return $this->fail(LoginLogic::getError());
}
return $this->data($result);
}
}