Maison > développement back-end > tutoriel php > Mini programme et ThinkPHP5 combinés pour obtenir le statut de connexion (code ci-joint)

Mini programme et ThinkPHP5 combinés pour obtenir le statut de connexion (code ci-joint)

不言
Libérer: 2023-04-03 18:20:02
original
10883 Les gens l'ont consulté

Le contenu de cet article concerne la combinaison de petits programmes et de ThinkPHP5 pour obtenir le statut de connexion (avec du code). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Les mini-programmes WeChat impliquent généralement trois méthodes de connexion :
1. Connectez-vous en utilisant le compte WeChat
2. Inscrivez-vous et connectez-vous avec votre propre compte
3. Utilisez d'autres comptes de plateforme tierce pour vous connecter

Processus de connexion au compte WeChat :

1 Le mini-programme obtient le code via wx.login et l'envoie au backend, qui l'échange. la session_key et openid ;
2. Générez aléatoirement une chaîne comme sessionid (key), session_key et openid comme valeur, et stockez-les dans redis,
Un délai d'attente doit être défini lors de la sauvegarde
3. . Le client stockera l'ID de session renvoyé dans le stockage, et lors de l'appel de services d'arrière-plan qui nécessitent une autorisation de connexion pour y accéder,
vous pouvez extraire l'ID de session enregistré dans le stockage et le conserver dans la requête, et l'obtenir dans le code d'arrière-plan après. l'identifiant de session,
recherche dans Redis si l'identifiant de session existe. S'il existe, il est confirmé que la session est valide
Continue l'exécution du code ultérieur, sinon la gestion des erreurs est effectuée.

Cet article utilise l'enregistrement et la connexion gratuits du compte. Les principales idées et processus sont les suivants :

1 Pour accéder au mini-programme, obtenez d'abord le code via wx.login et envoyez-le au backend. via l'interface backend. Le backend l'utilise pour échanger l'API WeChat session_key et openid
2. Déterminer si l'openid existe dans la base de données [identification unique, doit être liée au compte (numéro de téléphone mobile)], -- Si l'openid n'existe pas dans la base de données (cela signifie qu'il n'y a pas de tel compte) :
Déterminez si le numéro de téléphone mobile transmis est vide (le numéro de téléphone mobile sera enregistré dans une variable globale lors de la connexion ). S'il n'est pas vide, cela signifie que vous venez de vous connecter, puis liez openid et openid_time (heure actuelle),
Si le numéro de téléphone mobile est également vide, cela signifie que vous n'êtes pas connecté, alors le un message d'échec de connexion sera renvoyé, obligeant le client à accéder à la page de connexion ;
-- S'il y a l'openid dans la base de données (cela signifie qu'il y a un téléphone mobile correspondant dans la base de données),
Déterminez si openid_time est supérieur à 4 heures dans maintenant. S'il est supérieur, renvoie les informations d'échec de connexion et amène le client à accéder à la page de connexion
S'il est inférieur à, mettez à jour openid_time à l'heure actuelle, puis renvoyez les informations de réussite de connexion ; et numéro de téléphone portable.
3. Page de connexion : déterminez si le numéro de téléphone mobile existe dans la base de données. S'il existe, mettez à jour openid_time à l'heure actuelle. S'il n'existe pas, ajoutez l'utilisateur avec le numéro de téléphone mobile. Accédez ensuite à la page d'accueil et exécutez la méthode wx.login. La connexion est réussie et l'état de connexion reste.

Processus détaillé :

Étape 1 : Lorsque vous entrez dans le mini-programme, obtenez d'abord le code via wx.login et envoyez-le au backend via l'interface backend. openid avec l'API WeChat ;

var user_phone = app.globalData.user_phone;
wx.login({
    success: res => {      
    // 发送 res.code 到后台换取 openId, sessionKey, unionId
      wx.request({
        url: 'http://www.tphoutai.com/wx/index', 
        data: {
          code: res.code,
          user_phone: user_phone,
        },
        success: function (result) {
          var res = result.data;
          console.log(res);          
          if(res.sendsure == 0){
            wx.reLaunch({
              url: '../login/login',
            })
          }else if(res.sendsure == 1){
            wx.reLaunch({
              url: '../index/index',
            })
          }
        }
      })
    }
  })
Copier après la connexion
Étape 2 : Déterminer si l'openid existe dans la base de données [identifiant unique, doit être lié à un compte (numéro de téléphone portable)]

// 后台代码:
public function index(Request $request){
        $url = "https://api.weixin.qq.com/sns/jscode2session";        
        // 参数
        $params['appid']= '小程序的appid';        
        $params['secret']= '小程序的AppSecret';        
        $params['js_code']= $request -> param('code');        
        $params['grant_type']= 'authorization_code';        
        $user_phone= $request -> param('user_phone');        
        // 微信API返回的session_key 和 openid
        $arr = httpCurl($url, $params, 'POST');        
        $arr = json_decode($arr,true);        
        // 判断是否成功
        if(isset($arr['errcode']) && !empty($arr['errcode'])){            
        return json(['code'=>'2','message'=>$arr['errmsg'],"result"=>null]);
        }        
        $openid = $arr['openid'];        
        $session_key = $arr['session_key'];        
        // 从数据库中查找是否有该openid
        $is_openid = Db::table('user_info')->where('openid',$openid)->find();        
        // 如果openid存在,更新openid_time,返回登录成功信息及手机号
        if($is_openid){            
        // openid存在,先判断openid_time,与现在的时间戳相比,如果相差大于4个小时,则则返回登录失败信息,使客户端跳转登录页,如果相差在四个小时之内,则更新openid_time,然后返回登录成功信息及手机号;
            // 根据openid查询到所在条数据
            $data = Db::table('user_info')->where('openid',$openid)->find();            
            // 计算openid_time与现在时间的差值
            $time = time() - $data['openid_time'];            
            $time = $time / 3600;            
            // 如果四个小时没更新过,则登陆态消失,返回失败,重新登录
            if($time > 4){                
            return json(['sendsure'=>'0','message'=>'登录失败',]);
            }else{                
            // 根据手机号更新openid时间
                $update = Db::table('user_info')->where('openid', $openid)->update(['openid_time' => time()]);                
                // 判断是否更新成功
                if($update){                    
                return json(['sendsure'=>'1','message'=>'登录成功','user_phone' => $data['user_phone']]);
                }else{                    
                return json(['sendsure'=>'0','message'=>'登录失败']);
                }
            }        
            // openid不存在时
        }else{            
        // dump($user_phone);
            // 如果openid不存在, 判断手机号是否为空
            if(isset($user_phone) && !empty($user_phone)){                
            // 如果不为空,则说明是登录过的,就从数据库中找到手机号,然后绑定openid,+时间

                // 登录后,手机号不为空,则根据手机号更新openid和openid_time
                $update = Db::table('user_info')
                    ->where('user_phone', $user_phone)
                    ->update([                        
                    'openid'  => $openid,                        
                    'openid_time' => time(),
                    ]);                
                    if($update){                    
                    return json(['sendsure'=>'1','message'=>'登录成功',]);
                }
            }else{                
            // 如果也为空,则返回登录失败信息,使客户端跳转登录页
                return json(['sendsure'=>'0','message'=>'读取失败',]);
            }
        }
    }
Copier après la connexion
Étape 3 : Page de connexion : Après une connexion réussie, accédez à la page d'accueil et exécutez la méthode wx.login, puis connectez-vous avec succès et restez connecté.

// 前台登录
    wx.request({
      url: 'http://www.tphoutai.com/wx/login', 
      data: {
        user_phone: user_phone
      },
      success: function (result) {
        var res = result.data;        
        if (res.sendsure == 1){
          app.globalData.user_phone = that.data.user_phone;
          wx.reLaunch({
            url: '../loading/loading',
          })
        }
      }
    })
Copier après la connexion
// 后台登录方法
    public function login(Request $request){

        // 获取到前台传输的手机号
        $user_phone = $request -> param('user_phone');        
        // 判断数据库中该手机号是否存在
        $is_user_phone = Db::table('user_info')->where('user_phone',$user_phone)->find();        
        if(isset($is_user_phone) && !empty($is_user_phone)){            
        // 登录时,数据库中存在该手机号,则更新openid_time
            $update = Db::table('user_info')
                    ->where('user_phone', $user_phone)
                    ->update([                        
                    'openid_time' => time(),
                    ]);            
                    if($update){                
                    return json(['sendsure'=>'1','message'=>'登录成功',]);
            }
        }else{            
        $data = [                
        "user_phone" => $user_phone,                
        "pass" => '12345'
            ];            
            // 如果数据库中不存在该手机号,则进行添加
            Db::table('user_info')->insert($data);
        }        return json(['sendsure'=>'1','message'=>'登录成功',]);
    }
Copier après la connexion
Comment obtenir une clé de session et un openid basés sur l'API WeChat
function httpCurl($url, $params, $method = 'GET', $header = array(), $multi = false){
        date_default_timezone_set('PRC');        
        $opts = array(
            CURLOPT_TIMEOUT        => 30,
            CURLOPT_RETURNTRANSFER => 1,
            CURLOPT_SSL_VERIFYPEER => false,
            CURLOPT_SSL_VERIFYHOST => false,
            CURLOPT_HTTPHEADER     => $header,
            CURLOPT_COOKIESESSION  => true,
            CURLOPT_FOLLOWLOCATION => 1,
            CURLOPT_COOKIE         
            =>session_name().'='.session_id(),
        );        
        /* 根据请求类型设置特定参数 */
        switch(strtoupper($method)){            
        case 'GET':                
        // $opts[CURLOPT_URL] = $url . '?' . http_build_query($params);
                // 链接后拼接参数  &  非?
                $opts[CURLOPT_URL] = $url . '?' . http_build_query($params);                break;            case 'POST':                //判断是否传输文件
                $params = $multi ? $params : http_build_query($params);                $opts[CURLOPT_URL] = $url;                $opts[CURLOPT_POST] = 1;                $opts[CURLOPT_POSTFIELDS] = $params;                break;            default:                throw new Exception('不支持的请求方式!');
        }        
        /* 初始化并执行curl请求 */
        $ch = curl_init();
        curl_setopt_array($ch, $opts);        
        $data  = curl_exec($ch);        
        $error = curl_error($ch);
        curl_close($ch);        
        if($error) throw new Exception('请求发生错误:' . $error);        
        return  $data;
    }
Copier après la connexion
Résultats des tests :


Mini programme et ThinkPHP5 combinés pour obtenir le statut de connexion (code ci-joint)

Recommandations associées :

Solution au problème de nommage du nom du module appartientToMany() dans thinkphp5

Analyse détaillée du mode adaptateur en php (avec code)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal