微信公众号可以通过微信网页授权机制,来获取用户基本信息,可以用于微信登录功能

关于网页授权的两种scope的区别说明

1、静默授权:以snsapi_base为scope发起的网页授权,是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的。用户感知的就是直接进入了回调页(往往是业务页面)

2、显示授权:以snsapi_userinfo为scope发起的网页授权,是用来获取用户的基本信息的。但这种授权需要用户手动同意,并且由于用户同意过,所以无须关注,就可在授权后获取该用户的基本信息。

具体而言,网页授权流程分为四步:

1、引导用户进入授权页面同意授权,获取code

2、通过code换取网页授权access_token(与基础支持中的access_token不同)

3、如果需要,开发者可以刷新网页授权access_token,避免过期

4、通过网页授权access_token和openid获取用户基本信息(支持UnionID机制)

第一步:用户同意授权,获取code

1 function getCode($scope,$state = \'STATE\'){2 $method = \'https://open.weixin.qq.com/connect/oauth2/authorize?\';3 $params = array(4 \'appid\' => $this->appId,

5 \'redirect_uri\' => ($_SERVER[\'REQUEST_SCHEME\'] ? $_SERVER[\'REQUEST_SCHEME\'] : \'http\')."://".$_SERVER[\'HTTP_HOST\'].$_SERVER[\'PHP_SELF\'].$_SERVER[\'QUERY_STRING\'],

6 \'response_type\' => \'code\',

7 \'scope\' => $scope,

8 \'state\' => $state,

9 );10

11 $getCodeApi = $method.(http_build_query($params))."#wechat_redirect";12 header("Location:".$getCodeApi);13

14 }

如果是显示授权,则会出现授权界面

用户同意授权后

如果用户同意授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE。

第二步:通过code换取网页授权access_token

首先请注意,这里通过code换取的是一个特殊的网页授权access_token,与基础支持中的access_token(该access_token用于调用其他接口)不同。公众号可通过下述接口来获取网页授权access_token。如果网页授权的作用域为snsapi_base,则本步骤中获取到网页授权access_token的同时,也获取到了openid,snsapi_base式的网页授权流程即到此为止。

请求方法

获取code后,请求以下链接获取access_token:  https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

参数说明

参数是否必须说明

appid

公众号的唯一标识

secret

公众号的appsecret

code

填写第一步获取的code参数

grant_type

填写为authorization_code

返回说明

正确时返回的JSON数据包如下:

{ "access_token":"ACCESS_TOKEN",

"expires_in":7200,

"refresh_token":"REFRESH_TOKEN",

"openid":"OPENID",

"scope":"SCOPE" }

function getAccessToken($code){

$res = array();

if(!$code) return $res;

$method = \'https://api.weixin.qq.com/sns/oauth2/access_token?\';

$params = array(

\'appid\' => $this->appId,

\'secret\' => $this->appSecret,

\'code\' => $code,

\'grant_type\' => \'authorization_code\',

);

$getAccessTokenApi = $method.(http_build_query($params));

p($getAccessTokenApi);

$res = $this->http_curl($getAccessTokenApi);

$res = json_decode($res,1);p($res);

if($res[\'errcode\']) $this->showError($res);

return $res;

}

第三步:刷新access_token(如果需要)

由于access_token拥有较短的有效期,当access_token超时后,可以使用refresh_token进行刷新,refresh_token有效期为30天,当refresh_token失效之后,需要用户重新授权。

请求方法

获取第二步的refresh_token后,请求以下链接获取access_token:

https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=APPID&grant_type=refresh_token&refresh_token=REFRESH_TOKEN

参数是否必须说明

appid

公众号的唯一标识

grant_type

填写为refresh_token

refresh_token

填写通过access_token获取到的refresh_token参数

返回说明

正确时返回的JSON数据包如下:

{ "access_token":"ACCESS_TOKEN",

"expires_in":7200,

"refresh_token":"REFRESH_TOKEN",

"openid":"OPENID",

"scope":"SCOPE" }

参数描述

access_token

网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同

expires_in

access_token接口调用凭证超时时间,单位(秒)

refresh_token

用户刷新access_token

openid

用户唯一标识

scope

用户授权的作用域,使用逗号(,)分隔

错误时微信会返回JSON数据包如下(示例为code无效错误):

{"errcode":40029,"errmsg":"invalid code"}

第四步:拉取用户信息(需scope为 snsapi_userinfo)

如果网页授权作用域为snsapi_userinfo,则此时开发者可以通过access_token和openid拉取用户信息了。

请求方法

http:GET(请使用https协议) https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

参数说明

参数描述

access_token

网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同

openid

用户的唯一标识

lang

返回国家地区语言版本,zh_CN 简体,zh_TW 繁体,en 英语

返回说明

正确时返回的JSON数据包如下:

{    "openid":" OPENID",

" nickname": NICKNAME,

"sex":"1",

"province":"PROVINCE"

"city":"CITY",

"country":"COUNTRY",

"headimgurl":    "http://wx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ

4eMsv84eavHiaiceqxibJxCfHe/46",

"privilege":[ "PRIVILEGE1" "PRIVILEGE2"     ],

"unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL"

}

function getUserInfo($data = array()){

$res = array();

if(!$data) return $res;

$method = \'https://api.weixin.qq.com/sns/userinfo?\';

$params = array(

\'access_token\' => $data[\'access_token\'],

\'openid\' => $data[\'openid\'],

);

$getUserInfoApi = $method.(http_build_query($params));

$res = $this->http_curl($getUserInfoApi);

$res = json_decode($res,1);

if($res[\'errcode\']) $this->showError($res);

return $res;

}

需要完整代码可以联系 851 488 243 备注:网页授权

html微信打开网页 要求用sa,微信网页授权获取用户基本信息(示例代码)相关推荐

  1. 微信开发 网页授权获取用户基本信息

    微信公众平台最近新推出微信认证,认证后可以获得高级接口权限,其中一个是OAuth2.0网页授权,很多朋友在使用这个的时候失败了或者无法理解其内容,希望我出个教程详细讲解一下,于是便有了这篇文章. 一. ...

  2. 第八篇 :微信公众平台开发实战Java版之如何网页授权获取用户基本信息

    第一部分:微信授权获取基本信息的介绍 我们首先来看看官方的文档怎么说: 如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑. 关于网页授权回调域 ...

  3. Java微信公众平台开发(十六)--微信网页授权(OAuth2.0授权)获取用户基本信息

    转自:http://www.cuiyongzhi.com/post/78.html 好长时间没有写文章了,主要是最近的工作和生活上的事情比较多而且繁琐,其实到现在我依然还是感觉有些迷茫,最后还是决定静 ...

  4. 微信公众平台--服务号/订阅号--网页授权获取用户基本信息

    参考链接:https://www.cnblogs.com/admol/articles/4286487.html 注: 1.此为网页授权获取用户基本信息,必须为服务号,订阅号是没有权限通过网页授权来获 ...

  5. 微信公众号开发系列-网页授权获取用户基本信息

    OAuth2.0网页授权这个也是在做微信公众平台用到最多的,可以利用授权接口对自己平台内用户进行绑定,实现用户扫描码和微信分享.微信签到.微信商城购物等: 1.高级接口OAuth2.0网页授权设置 a ...

  6. 微信开发之网页授权获取用户基本信息

    微信官方文档:网页授权获取用户基本信息 具体而言,网页授权流程分为四步: 1.引导用户进入授权页面同意授权,获取code https://open.weixin.qq.com/connect/oaut ...

  7. 微信接口开发之高级篇系列【网页授权获取用户基本信息】

    PHP微信接口开发之高级篇之网页授权获取用户基本信息 二.WEB开发工具 转载于:https://www.cnblogs.com/tinywan/p/5860981.html

  8. 微信网页授权获取用户基本信息 --- 20/03/16

    ThinkPHP5实现微信网页授权获取用户基本信息 本次使用的appID与appSecret为公众号 一:准备工作 登录微信公众平台,左侧菜单下拉至开发选中基本配置 启用开发者密码(AppSecret ...

  9. PHP开发之-微信网页授权获取用户基本信息

    如何通过网页授权获取用户基本信息(国家,省,市,昵称)相关信息 必要条件: 1)公众号认证 2)有网页授权获取用户基本信息的权限接口 注意:最近有朋友说:在公众平台申请的测试号,会出现无法取到用户信息 ...

最新文章

  1. POJ 2828 Buy Tickets 线段树
  2. git教程——简单总结
  3. javascript(arguments)
  4. input python_Python input 使用
  5. Flash,EEPROM区别
  6. java地狱猫_ES6 ES6变量的声明
  7. 根据相机内参进行图像去畸变
  8. python读取sqlserver的数据_Python:使用并发未来进程P读取sqlserver数据
  9. 限流神器Sentinel,不了解一下吗?
  10. 从0开始配置Win环境下VScode (VScode For C/C++)
  11. Python求单词长度并根据长度排序
  12. [No000083]文件与文件夹操作
  13. 黑马程序员传智播客 python生成器 学习笔记
  14. python中实例是什么_Python里类和实例是什么
  15. Mybatis Generator(简称MBG)的最完整配置文件详解
  16. 安装MySQL提示cab文件损坏_安装所需的 CAB 文件“Redist.cab”已损坏处理办法
  17. 黑暗主题导致iframe透明属性失效
  18. openlayers绘制箭头线
  19. Keil MDK 2020过期问题
  20. root内核下载,免root开核下载

热门文章

  1. 诺基亚安卓手机_当初诺基亚为何”宁死“不用安卓系统?除骄傲外,还有一点很致命...
  2. 个人邮箱怎么注册申请?什么邮箱最正式?
  3. eslint -- Adjacent JSX elements must be wrapped in an enclosing tag
  4. AGV调度系统之核心内容
  5. KFC Crazy Thursday
  6. 音视频实现传输概念讲解
  7. python数据库怎么下载_哪有Python数据库视频教程下载(python导入数据库视频教程)...
  8. 分享dedecms系统被挂黑链的几个原因
  9. c语言狗追兔子,速看!可以秒杀所有猎狗追兔问题的解题方法
  10. 关于端午节,普及普及(PS:肇庆粽是很出名的噢!)