LoginController.php
1.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<?php
/**
* Created by PhpStorm.
* User: ruidiudiu
* Date: 2018/11/26
* Time: 14:49
*/
namespace app\portal\controller;
use cmf\controller\HomeBaseController;
use think\Db;
/**
* @title 登录相关接口
* @description 登录相关接口
* @group 登录相关接口
*/
class LoginController extends HomeBaseController{
private $appId="wx75855734b0730d64";
private $appSecret="4c20fc2db6e2324e4d0a85ec9a6692e7";
/**
* @title 登录凭证校验
* @description 接口说明
* @author 董瑞恩
* @url /portal/login/login
* @method post
*
* @param name:code type:String require:1 default:null desc:登录凭证
*
* @return users_id:用户id
* @return type:是否注册(0、未注册,1、已注册)
* @return openid:openid
* @return is_use:是否在使用设备(0:空闲,1:在用)
*/
public function login(){
$code=$this->request->param('code');
//登录凭证校验接口
$loginUrl="https://api.weixin.qq.com/sns/jscode2session?appid=".$this->appId."&secret=".$this->appSecret."&js_code=".$code."&grant_type=authorization_code";
$loginData=json_decode(file_get_contents($loginUrl),true);
if(isset($loginData['openid'])){
$users = Db::name('users')->where('open_id', $loginData['openid'])->find();
if (empty($users)){
$users_id=Db::name('users')->insertGetId(['open_id'=>$loginData['openid'],'create_time'=>date('Y-m-d H:i:s')]);
$this->apiResponse(200,'success',['users_id'=>$users_id,'type'=>0,'openid'=>$loginData['openid'],'is_use'=>0]);
}else{
$this->apiResponse(200,'success',['users_id'=>$users['id'],'type'=>1,'openid'=>$users['open_id'],'is_use'=>$users['is_use']]);
}
}else{
$this->apiResponse(301,'获取登录凭证失败',$loginData);
}
}
}