文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

php微信授权登录实例讲解

2024-04-02 19:55

关注

要使用微信授权登录功能需要先在微信开发平台创建应用。然后会获取微信提供给你的appIdAppSecret,然后就可以进行开发了。
当然现有很多大佬封装的微信类库非常齐全,而且还很好用,可以去试试,下面讲解一下基本实现方法。

流程

若access_token已超时,那么进行refresh_token会获取一个新的access_token,新的超时时间。若access_token未超时,那么进行refresh_token不会改变access_token,但超时时间会刷新,相当于续期access_token。
refresh_token拥有较长的有效期(30天),当refresh_token失效的后,需要用户重新授权。

获取用户信息

移动端开发由移动端获取code,网页开发用php获取就可以。下面是一个简单的移动端获取用户信息的方法,使用第二步和第四步就可以了。


publicfunction get_user_info($code){
// 通过code获取access_token
    $get_token_url ="https://api.weixin.qq.com/sns/oauth2/access_token?appid=". $this->appid ."&secret=". $this->appsecret ."&code={$code}&grant_type=authorization_code";
    $token_info = $this->https_request($get_token_url);
    $token_info = json_decode($token_info,true);
if(isset($token_info['errcode'])){
      $this->errCode = $token_info['errcode'];
      $this->errMsg = $token_info['errmsg'];
returnfalse;
}
// 通过access_token和openid获取用户信息
    $get_userinfo_url ='https://api.weixin.qq.com/sns/userinfo?access_token='. $token_info['access_token'].'&openid='. $token_info['openid'].'&lang=zh_CN';
    $userinfo = $this->https_request($get_userinfo_url);
    $userinfo = json_decode($userinfo,true);
if(isset($userinfo['errcode'])){
      $this->errCode = $userinfo['errcode'];
      $this->errMsg = $userinfo['errmsg'];
returnfalse;
}
return $userinfo;
}

封装成公共类如下


<?php

classWxOauth
{
private $appid ="";// appid
private $appsecret ="";// appsecret
public $error =[];// 错误信息
const GET_ACCESS_TOKEN_URL ='https://api.weixin.qq.com/sns/oauth2/access_token';// 获取access_token url
const GET_USER_INFO_URL ='https://api.weixin.qq.com/sns/userinfo';// 获取用户信息url
const GET_REFRESH_URL ='https://api.weixin.qq.com/sns/oauth2/refresh_token';//刷新access_token
const GET_CODE ='https://open.weixin.qq.com/connect/oauth2/authorize';// 获取code(网页授权使用)
publicfunction __construct($appid, $appsecret){
if($appid && $appsecret){
$this->appid = $appid;
$this->appsecret = $appsecret;
}
}

publicfunction wxLogin($code){
$token_info = $this->getToken($code);
if(isset($token_info['errcode'])){
$this->error = $token_info;
returnfalse;
}
$user_info = $this->getUserinfo($token_info['openid'], $token_info['access_token']);
if(isset($user_info['errcode'])){
$this->error = $user_info;
returnfalse;
}
return $user_info;
}

publicfunction getCode($redirect_uri){
$uri = $this->combineURL(self::GET_CODE,[
'appid'=> $this->appid,
'scope'=>'SCOPE',
'response_type'=>'code',
'redirect_uri'=> urlEncode($redirect_uri),
'state'=>'STATE#wechat_redirect',
]);
header('Location: '. $uri,true);
}

publicfunction getToken($code){
$get_token_url = $this->combineURL(self::GET_ACCESS_TOKEN_URL,[
'appid'=> $this->appid,
'appsecret'=> $this->appsecret,
'code'=> $code,
'grant_type'=>'authorization_code'
]);
$token_info = $this->httpsRequest($get_token_url);
return json_decode($token_info,true);
}

publicfunction refreshToken($refresh_token){
$refresh_token_url = $this->combineURL(self::GET_REFRESH_URL,[
'appid'=> $this->appid,
'refresh_token'=> $refresh_token,
'grant_type'=>'refresh_token'
]);
$refresh_info = $this->httpsRequest($refresh_token_url);
return json_decode($refresh_info,true);
}

publicfunction getUserinfo($openid, $access_token){
$get_userinfo_url = $this->combineURL(self::GET_USER_INFO_URL,[
'openid'=> $openid,
'access_token'=> $access_token,
'lang'=>'zh_CN'
]);
$user_info = $this->httpsRequest($get_userinfo_url);
return json_decode($user_info,true);
}

publicfunction combineURL($baseURL, $keysArr){
$combined = $baseURL ."?";
$valueArr = array();
foreach($keysArr as $key => $val){
$valueArr[]="$key=$val";
}
$keyStr = implode("&", $valueArr);
$combined .=($keyStr);
return $combined;
}

publicfunction httpsRequest($url){
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
curl_setopt($curl, CURLOPT_RETURNTRANSFER,1);
$output = curl_exec($curl);
curl_close($curl);
return $output;
}
}

使用方法


// 移动端使用
$WxOauth =newWxOauth(APPID, APPSECRET);// 传入appid和appsecret
//公众号登录需要先获取code,下面方法会自动跳转到微信授权页面
$WxOauth->getCode();
// 通过移动端传来的code或者微信回调返回的code获取用户信息
$user_info = $WxOauth->wxLogin($_REQUEST['code']);
if($user_info){
//获取到用户信息
}else{
// 获取错误
$WxOauth->error;
}

到此这篇关于php微信授权登录实例讲解的文章就介绍到这了,更多相关php微信授权登录内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯