90 lines
3.5 KiB
PHP
Executable File
90 lines
3.5 KiB
PHP
Executable File
<?php
|
||
// +----------------------------------------------------------------------
|
||
// | likeshop100%开源免费商用商城系统
|
||
// +----------------------------------------------------------------------
|
||
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
||
// | 开源版本可自由商用,可去除界面版权logo
|
||
// | 商业版本务必购买商业授权,以免引起法律纠纷
|
||
// | 禁止对系统程序代码以任何目的,任何形式的再发布
|
||
// | gitee下载:https://gitee.com/likeshop_gitee
|
||
// | github下载:https://github.com/likeshop-github
|
||
// | 访问官网:https://www.likeshop.cn
|
||
// | 访问社区:https://home.likeshop.cn
|
||
// | 访问手册:http://doc.likeshop.cn
|
||
// | 微信公众号:likeshop技术社区
|
||
// | likeshop团队 版权所有 拥有最终解释权
|
||
// +----------------------------------------------------------------------
|
||
// | author: likeshopTeam
|
||
// +----------------------------------------------------------------------
|
||
declare (strict_types=1);
|
||
|
||
namespace app\shopapi\http\middleware;
|
||
|
||
|
||
use app\common\cache\ShopUserTokenCache;
|
||
use app\common\enum\shop\ShopEnum;
|
||
use app\common\model\shop\Shop;
|
||
use app\common\service\JsonService;
|
||
use app\shopapi\service\ShopUserTokenService;
|
||
use think\facade\Config;
|
||
|
||
class LoginMiddleware
|
||
{
|
||
/**
|
||
* @notes 登录验证
|
||
* @param $request
|
||
* @param \Closure $next
|
||
* @return mixed|\think\response\Json
|
||
* @author 令狐冲
|
||
* @date 2021/7/1 17:33
|
||
*/
|
||
public function handle($request, \Closure $next)
|
||
{
|
||
$token = $request->header('token');
|
||
//判断接口是否免登录
|
||
$isNotNeedLogin = $request->controllerObject->isNotNeedLogin();
|
||
//不直接判断$isNotNeedLogin结果,使不需要登录的接口通过,为了兼容某些接口可以登录或不登录访问
|
||
if (empty($token) && !$isNotNeedLogin) {
|
||
//没有token并且该地址需要登录才能访问, 指定show为0,前端不弹出此报错
|
||
return JsonService::fail('请求参数缺token', [], 0, 0);
|
||
}
|
||
$shopInfo = (new ShopUserTokenCache())->getShopUserInfo($token);
|
||
if (empty($shopInfo) && !$isNotNeedLogin) {
|
||
//token过期无效并且该地址需要登录才能访问
|
||
return JsonService::fail('登录超时,请重新登录', [], -1, 0);
|
||
}
|
||
|
||
//token临近过期,自动续期
|
||
if ($shopInfo) {
|
||
//获取临近过期自动续期时长
|
||
$beExpireDuration = Config::get('project.user_token.be_expire_duration');
|
||
|
||
//token续期
|
||
if (time() > ($shopInfo['expire_time'] - $beExpireDuration)) {
|
||
|
||
$result = ShopUserTokenService::overtimeToken($token);
|
||
|
||
//续期失败(数据表被删除导致)
|
||
if (empty($result)) {
|
||
return JsonService::fail('登录过期', [], -1);
|
||
}
|
||
|
||
}
|
||
}
|
||
//todo 重新查询sql,赋值,这里有优化的空间
|
||
if($shopInfo && ShopEnum::AUDIT_STATUS_WAIT == $shopInfo['audit_status']){
|
||
$shop = Shop::where(['shop_user_id'=>$shopInfo['shop_user_id']])
|
||
->order('id desc')
|
||
->field('id,audit_status')
|
||
->find();
|
||
}
|
||
$shopInfo['audit_status'] = $shop->audit_status ?? 0;
|
||
//给request赋值,用于控制器
|
||
$request->shopInfo = $shopInfo;
|
||
$request->shopId = $shop->id ?? 0;
|
||
$request->shopUserId = $shopInfo['shop_user_id'] ?? 0;
|
||
|
||
return $next($request);
|
||
}
|
||
|
||
} |