83 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			83 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | likeshop开源商城系统
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
 | |||
|  | // | 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系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
 | |||
|  | // |  likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
 | |||
|  | // | 禁止对系统程序代码以任何目的,任何形式的再发布
 | |||
|  | // | likeshop团队版权所有并拥有最终解释权
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | author: likeshop.cn.team
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | 
 | |||
|  | namespace app\api\validate; | |||
|  | 
 | |||
|  | use think\Validate; | |||
|  | use app\common\model\Session as SessionModel; | |||
|  | use app\common\model\user\User; | |||
|  | 
 | |||
|  | class TokenValidate extends Validate | |||
|  | { | |||
|  |     protected $rule = [ | |||
|  |         'token' => 'require|valid|user', | |||
|  |     ]; | |||
|  | 
 | |||
|  |     /** | |||
|  |      * User: 意象信息科技 lr | |||
|  |      * Desc: token验证 | |||
|  |      * @param $token | |||
|  |      * @param $other | |||
|  |      * @param $data | |||
|  |      * @return bool|string | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @throws \think\exception\DbException | |||
|  |      */ | |||
|  |     protected function valid($token, $other, $data) | |||
|  |     { | |||
|  |         $session = SessionModel::where(['token' => $token])->find(); | |||
|  |         if (empty($session)) { | |||
|  |             return '会话失效,请重新登录'; | |||
|  |         } | |||
|  |         if ($session['expire_time'] <= time()) { | |||
|  |             return '登录超时,请重新登录'; | |||
|  |         } | |||
|  |         return true; | |||
|  |     } | |||
|  | 
 | |||
|  |     /** | |||
|  |      * User: 意象信息科技 lr | |||
|  |      * Desc 用户验证 | |||
|  |      * @param $token | |||
|  |      * @param $other | |||
|  |      * @param $data | |||
|  |      * @return string | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      * @throws \think\exception\DbException | |||
|  |      */ | |||
|  |     protected function user($token, $other, $data) | |||
|  |     { | |||
|  |         $user_id = SessionModel::where(['token' => $token]) | |||
|  |             ->value('user_id'); | |||
|  | 
 | |||
|  |         $user_info = User::where(['id' => $user_id, 'del' => 0]) | |||
|  |             ->find(); | |||
|  |         if (empty($user_info)) { | |||
|  |             return '用户不存在'; | |||
|  |         } | |||
|  |         if ($user_info['disable'] == 1) { | |||
|  |             return '用户被禁用'; | |||
|  |         } | |||
|  |         return true; | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  | } |