好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Laravel 集成微信用戶登錄和綁定的實現

Laravel 集成微信用戶登錄和綁定的實現

熱門標簽:青島語音外呼系統招商 百應電話機器人服務 岳陽外呼型呼叫中心系統在哪里 昭通辦理400電話 河南電銷卡外呼系統哪家強 山西回撥外呼系統 山西探意電話機器人 揚州地圖標注app 騰訊外呼管理系統

最近主要在忙活微信與支付寶平臺的對接與開發,本篇就基于后端層面來講述一下微信的登錄與綁定實現。

(一)申請微信開放平臺

最首先的話就是需要去微信開發中心https://open.weixin.qq.com,創建一個賬號,然后創建自己的移動或網站應用。

創建完成后,就會需要騰訊的審核,整個過程在1-3天,基本上1天左右就能完成,審核通過如下圖所示。

(二) 、封裝微信相關接口

微信移動應用開發文檔:https://developers.weixin.qq.com/doc/oplatform/Mobile_App/WeChat_Login/Authorized_API_call_UnionID.html

審核通過后,就需要來封裝微信授權、可信息獲取的接口。

封裝微信授權 用戶信息獲取

微信授權接口:https://api.weixin.qq.com/sns/oauth2

需要填寫的參數如下:

參數 是否必須 說明
appid 應用唯一標識,在微信開放平臺提交應用審核通過后獲得
secret 應用密鑰 AppSecret,在微信開放平臺提交應用審核通過后獲得
code 填寫第一步獲取的 code 參數
grant_type 填 authorization_code

下面通過我們的PHP代碼實現:

?php
namespace App\Helpers;

use GuzzleHttp\Client;
use Illuminate\Support\Arr;

class WechatAppUtils
{
  protected $client = null;

  protected $config = [];

  public function __construct()
  {
    $this->config = [
      'wechat_app' => [
        'appid' => env('WECHAT_APPID'),  //審核通過的APPID
        'secret' => env('WECHAT_SECRET'),  //應用APP SECRET 詳情見上圖
      ],
      'time_out'  => 5,
    ];
    $this->client = new Client([
      'time_out' => $this->config['time_out'],
    ]);
  }

  /**
   * 獲取微信用戶access_token
   *
   * @param [String] $code
   * @return Array
   */
  public function accessToken($code)
  {
    $accessTokenUrl = 'https://api.weixin.qq.com/sns/oauth2/access_token';

    $response = $this->client->request('GET', $accessTokenUrl, [
      'query' => [
        'grant_type' => 'authorization_code',
        'code'    => $code,
        'appid'   => Arr::get($this->config, 'wechat_app.appid'),
        'secret'   => Arr::get($this->config, 'wechat_app.secret'),
      ],
    ]);

    $result = $response->getbody()->getContents();

    return empty($result) ? null : json_decode($result, true);
  }

  /**
   * 微信用戶信息
   *
   * @param [String] $accessToken
   * @param [String] $openId
   * @return Array
   */
  public function userInfo($accessToken, $openId)
  {
    $userInfoUrl = 'https://api.weixin.qq.com/sns/userinfo';

    $response = $this->client->request('GET', $userInfoUrl, [
      'query' => [
        'access_token' => $accessToken,
        'openid'    => $openId,
        'lang'     => 'zh_CN',
      ],
    ]);

    $result = $response->getbody()->getContents();

    return empty($result) ? null : json_decode($result, true);
  }
}

上面的accessToken方法主要是實現用戶授權,效驗的code參數是客戶端傳遞過來的,當成功獲取收錢用戶的授權信息后,可以根據用戶的OPENID來調用userInfo方法查詢相關用戶的信息,包含了用戶的昵稱、頭像、性別等等。

具體客戶端開發文檔可以參考這篇:https://developers.weixin.qq.com/doc/oplatform/Mobile_App/WeChat_Login/Development_Guide.html。

上面的用到的Http Client是一個第三方拓展包,叫做GuzzleHttp,是一個PHP HTTP客戶端,可以輕松發送HTTP請求,并且可以輕松集成Web服務。

我們可以通過composer一鍵安裝:

composer require guzzlehttp/guzzle

(三)、完善用戶微信授權登錄

完成上述的封裝操作后,我們便開始講微信接入到我們自己的系統中與用戶進行關聯起來,下面是微信接入的一張時序圖。

如果用戶想使用微信登錄,首先會通過客戶端喚起微信,請求登錄第三方應用,然后微信會詢問用戶是否成功授權給XX應用,授權成功后,客戶端會得到一個授權碼:code,然后客戶端攜帶code請求我們的客戶端API,進行授權綁定,授權成功后,會得到授權用戶OPENID(應用下的唯一標識),反之拋出異常信息提示用戶。

建立OAuth表,用于儲存用戶的授權信息。

建立一張o_auths table 儲存用戶的授權信息,設計oauth_type字段使其成為一個多態模型,方便接入以后的微博、支付寶、QQ接入等等。

Schema::create('o_auths', function (Blueprint $table) {
  $table->increments('id');
  $table->unsignedInteger('user_id')->index()->comment('用戶ID');
  $table->morphs('o_auth');
  $table->json('data')->nullable()->comment('授權信息');
  $table->timestamps();
});

完善用戶授權綁定

建立好o_auths table,下面開始完善用戶授權綁定的邏輯:

function wechat(User $user, $code)
{
  $utils = new WechatAppUtils;

  //獲取微信token
  $accessTokens = $utils->accessToken($code);
  throw_if(!Arr::has($accessTokens, ['unionid', 'openid']), Exception::class, '授權失敗,請稍后再試!');

  //建立oauth關聯
  $oAuth = OAuth::firstOrNew(['oauth_type' => 'wechat', 'oauth_id' => $accessTokens['openid']]);
  throw_if(isset($oAuth->id),Exception::class,'該微信已綁定,請直接登錄!');
  $oAuth->user_id = $user->id;
  $oAuth->data  = Arr::only($accessTokens, ['openid', 'refresh_token']);
  $oAuth->save();

  return $oAuth;
}

首先會通過客戶端傳遞過來的Code獲取當前用戶授權,然后查詢該用戶是否已授權過,已授權過就提醒用戶直接去登錄,否則綁定授權信息,返回給客戶端。

完善微信登錄

完善好用戶授權后,登錄就顯得非常容易了,只需要簡單查詢授權記錄,存在則返回對應綁定的用戶,否則拋出異常信息提示用戶。

public function signIn($user, $code)
{
  $utils = new WechatAppUtils;
  //獲取微信token
  $accessTokens = $utils->accessToken($code);
  throw_if(!Arr::has($accessTokens, ['unionid', 'openid']), Exception::class, '授權失敗,請稍后再試!');
  $oauth = $this->getUserOauth($user, 'wechat');
  throw_if(is_null($oauth), UserException::class, '授權失敗,該賬戶未綁定!');

  return $oauth;
}

public function getUserOauth(User $user, $oAuthType)
{
  return OAuth::where(['oauth_type' => $oAuthType, 'user_id' => $user->id])->first();
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Laravel 微信小程序后端實現用戶登錄的示例代碼
  • laravel5實現微信第三方登錄功能
  • php的laravel框架快速集成微信登錄的方法

標簽:南陽 湛江 宜賓 寶雞 銅川 黃南 婁底 鎮江

巨人網絡通訊聲明:本文標題《Laravel 集成微信用戶登錄和綁定的實現》,本文關鍵詞  Laravel,集成,微信,用戶,登錄,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel 集成微信用戶登錄和綁定的實現》相關的同類信息!
  • 本頁收集關于Laravel 集成微信用戶登錄和綁定的實現的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 闺蜜的舌头伸进我的里面| 清冷学长H乖打开腿H男男| 麻豆久久婷婷综合五月国产| 色婷婷综合久久久久中文一区二区| 无码日本99久久久国产红灯区| 天天干天天添| 公和我做好爽添厨房| 免费一级婬片AA毛A片爽爽网| 中国女人内谢69ⅩXXX免费| 国产麻豆成人传媒免费观看| 赤井美月大喷水| 欧美成人一区二区三区片免费| 亚洲 日韩 中文字幕 无码| 简体-乐乐的放荡日记| 欧美人与善交大片| 一级理伦| 99精品国产成人一区二区在线 | 国产精品自产拍视频观看| 精品国产一区二区三区麻豆小说| 国产熟妇婬乱一区二区| 粉嫩尤物在线456| 狠狠色狠狠色综合久久伊人| 美女被羞羞在线观看| 黑人精品秘?一区二区三天美| 伊人久久精品午夜| 下女的诱惑| 国产精品99久久免费公侵犯玩弄| 日韩一级欧美一级一级国产| 动漫h之旅| 国产在线观看91一区二区三区| 没带罩子让他C了一节课作文| 少妇做爰奶水狂喷免费| 低头看我是怎么c哭你的细节| ????秘?同免费网站入口| 免费h福利漫画网站在线| 欧美三级一级片| 99国产精品人妻一区二区三区四| 无码做爰在线观网站直播下载| 广西女人一级毛片| 松泽和三上主演的日本电影叫什么| 一边亲一边摸一边桶的动态图|