要实现第三方登录的功能首先要明白oauth2.0的认证原理。

OAUTH 2.0

OAUTH是一种开放的协议,为桌面程序或者基于BS的web应用提供了一种简单的,标准的方式去访问需要用户授权的API服务。

在没有oauth服务下,如果一个用户拥有两项服务:一项服务是图片在线存储服务A,另一个是图片在线打印服务B。如下图所示。由于服务A与服务B是由两家不同的服务提供商提供的,所以用户在这两家服务提供商的网站上各自注册了两个用户,假设这两个用户名各不相同,密码也各不相同。当用户要使用服务B打印存储在服务A上的图片时,用户该如何处理?法一:用户可能先将待打印的图片从服务A上下载下来并上传到服务B上打印,这种方式安全但处理比较繁琐,效率低下;法二:用户将在服务A上注册的用户名与密码提供给服务B,服务B使用用户的帐号再去服务A处下载待打印的图片,这种方式效率是提高了,但是安全性大大降低了,服务B可以使用用户的用户名与密码去服务A上查看甚至篡改用户的资源。

这也促使OAUTH项目组的产生。OAuth是由Blaine Cook、Chris Messina、Larry Halff 及David Recordon共同发起的,目的在于为API访问授权提供一个开放的标准。OAuth规范的1.0版于2007年12月4日发布。

简单的来说,OAUTH认证授权就三个步骤,三句话可以概括:

1. 获取未授权的Request Token

2. 获取用户授权的Request Token

3. 用授权的Request Token换取Access Token

详细的一个服务流程如下【盗图】

A. 使用者(第三方软件)向OAUTH服务提供商请求未授权的Request Token。向Request Token URL(获取未授权的Request Token服务地址)发起请求,请求需要带上的参数见上图。获取未授权的Request Token,其实就是使用者的ID和其对应的密钥(appid\appkey、appsecret),OAUTH服务的直接使用者是开发者开发出来的应用。所以该参数值的获取一般是要去OAUTH服务提供商处注册一个应用,再获取该应用的oauth_consumer_key和oauth_consumer_secret。

B.OAUTH服务提供商同意使用者的请求,并向其颁发未经用户授权的oauth_token与对应的oauth_token_secret,并返回给使用者。

C.使用者向OAUTH服务提供商请求用户授权的Request Token。向User Authorization URL(获取用户授权的Request Token服务地址)发起请求,请求带上上步拿到的未授权的token与其密钥。

D.OAUTH服务提供商将引导用户授权。该过程可能会提示用户,你想将哪些受保护的资源授权给该应用。此步可能会返回授权的Request Token也可能不返回。

E.Request Token 授权后,使用者将向Access Token URL(用授权的Request

Token换取Access Token的服务地址)发起请求,将上步授权的Request Token换取成Access Token。请求的参数见上图,这个比第一步A多了一个参数就是Request Token。

F.OAUTH服务提供商同意使用者的请求,并向其颁发Access Token与对应的密钥,并返回给使用者。

G.使用者以后就可以使用上步返回的Access Token访问用户授权的资源。

微信第三方登录过程

用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,或通过app接入微信通过授权,来获取用户基本信息,进而实现业务逻辑。

基本步骤为:

1、首先我们需要以开发者的身份向第三方登陆平台申请接入应用,申请成功后,我们会获得一个appID和一个secrectID。

2、当我们的网站需接入微信登陆时,会引导用户(通过微信logo或其他图示)跳转到微信的登陆授权页面,此时把之前申请的appID带给登陆授权页面。

其实质上是引导用户打开下面的链接:

https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect

其中,redirect_uri是授权后重定向的回调链接地址, 请使用 urlEncode 对链接进行处理。scope 是应用授权作用域,取值有snsapi_base或snsapi_userinfo,前者表示不弹出授权页面,直接跳转,只能获取用户openid,后者表示弹出授权页面,可通过openid拿到昵称、性别、所在地。并且, 即使在未关注的情况下,只要用户授权,也能获取其信息 。

一个完整的示例为

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx6f3020ce6c245df0&redirect_uri=http%3A%2F%2Fw.k189.cn%2Findex.php%2FHuoDong%2FFlowhongbao%2Findex&response_type=code&scope=snsapi_base&state=123&connect_redirect=1#wechat_redirect

这需要在微信客户端打开,否则链接返回

这个操作可拉起微信并打开授权登录页(前提是你安装了微信应用并已登录,未登录的会引导你先登录)。

授权页面一般如下

3、用户确认后即得到授权,微信会返回一个临时的code给我们。code是通过微信登录的时候微信给传回来的参数,当进行微信登录的时候就会自动传回来,所以可以通过判断code来确定是否微信登录过了。另外一个参数是state,即现在回调链接地址变为 redirect_uri/?code=CODE&state=STATE。如

code作为换取access_token的票据,每次用户授权带上的code将不一样,code只能使用一次,5分钟未被使用自动过期。

值得注意的是每种应用获取code的方法不一样,如在web应用中,回调页面中我们采用如下方式获取code。

if($_GET['code']&& $_GET['state']=='STATE'){

$code = $_GET['code'];

$url = …..;

header('Location: ' . $url);    //url页中使用code

}

在app应用中,code的获取是在前端完成的,由微信的 SDK 提供支持。这就需要将微信sdk集成到我们的app中,应用中完成注册,在触发微信登录请求的时候,就会拉起微信授权登录页,在确认登录后,微信就会通过sdk返回一个code。参考见http://songyuanlin1101.lofter.com/tag/%E6%8E%88%E6%9D%83sendauth.resp。

4、我们接受到code后,并取出,再次向微信发起请求,并携带接收的code,从微信服务器获取access_token。

由于公众号的secret和获取到的access_token安全级别都非常高,必须只保存在服务器,不允许传给客户端。后续刷新access_token、通过access_token获取用户信息等步骤,最好从服务器发起。如

https://api.weixin.qq.com/sns/oauth2/access_token?appid=wx6s3020ce6c245df0&secret=ab2f96861f249fccd507d5ad603f1684&code=001SM3Mq0NSGpn1HFxOq0lxTLq0SM3ME&grant_type=authorization_code

app应用在前端获取的code,所以从前端发起。

微信处理请求后,会返回一个access_token给我们,响应内容为

{

"access_token":"20_ZFVyj4V1DEdAfP9aW5Up7flx218q9MKfUNgpQRqGgBNqFkkZLuGNa5cgwmVmztce290Z5XsXd6mNmDdfgTaIRyB2PzXvgVXtFQ0OMJhBK4c",

"expires_in": 7200,

"refresh_token":"20_JTzkWALwqatbdfO3viFbYsmNNsvtfvUtcberLYEIr_wBkKAx9Y_axkyuKYzRBHvwWkL_j8h37VvRr31drrO9aUitefg6_TUtDmMw5OZMf7E",

"openid":"ovhlKuM-dEmGd6dI_tM-Lnfpj9hA",

"scope":"snsapi_userinfo",

"unionid":"oa27Ysu74dJNVm48GIlsLyNemcOA"

}

5、我们的网站获取到access_token后就可以调用微信提供的接口了,比如获取用户信息等,如果网页授权作用域为snsapi_userinfo,则此时开发者可以通过access_token和openid拉取用户信息了。最后把该用户信息存入到我们站点的数据库,并把信息保存到session中,实现用户的第三方登陆。如

响应内容为

{

"openid":"ovhdKuM-dEmGdsxI_tM-Lnfpj9hA",

"nickname": "Nosxxne",

"sex": 1,

"language":"zh_CN",

"city": "Haidian",

"province":"Beijing",

"country": "CN",

"headimgurl":"http:\/\/thirdwx.qlogo.cn\/mmopen\/vi_32\/Q0j4TwGyfTJapNpVib3icSUgibQX9fr0XzmzkEXBibQichFfIjH3yDUWbHkSSib0RiaE2f1PFjsNXlrFr0mTuxddlj6Xg\/132",

"privilege": [],

"unionid":"oa27Ysu74kJNVmss8GIlsLyNemcOA"

}

总结一下,整个登录流程为获取Code->用Code获取AccessToken和OpenId(和UnionId)->用AccessToken获取微信用户的微信信息。

微信接口第三方php原理,微信第三方登录原理相关推荐

  1. 微信接口开发 2----接收微信接口返回的数据

    =====微信付款后----接收微信post提交过来的反馈结果 接收微信post过来的数据 使用接收$GLOBALS['HTTP_RAW_POST_DATA'] 可以接收 text/xml 或者 so ...

  2. 微信接口源码、微信定制功能源码

    微信HOOK接口,可自主选择与业务匹配的功能 功能列表 1.支持获取登录二维码 2.支持好友/群员列表/公众号列表,人员信息,头像等: 3.支持收发消息,区分接收和发送的消息 4.支持发送图片.GIF ...

  3. php微信接口怎么开发,php微信公众平台配置接口开发程序的方法实例详解

    这篇文章主要为大家详细介绍了php微信公众平台配置接口开发程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 在阅读这篇文章之前你要做以下的准备: 1.注册一个订阅号(通过微信公众平台https: ...

  4. python微信接口发送消息_Python 微信公众号发送消息

    #pip3 install requests importrequestsimportjsondefget_access_token():"""获取微信全局接口的凭证(默 ...

  5. php调取微信接口token上限,解决微信access_token上限问题

    已经关注,还提示关注. 分享不是正常文字,而是链接地址. 调取接口,最大2000次. access_token接口访问次数到达了上限,一日内无法再进行访问 如何解决access_token 访问次数到 ...

  6. 微信接口验证类php,微信公众平台消息接口校验与消息接口响应实例

    本文实例讲述了微信公众平台消息接口校验与消息接口响应的方法.分享给大家供大家参考.具体分析如下: 开发微信公众平台消息接口过程中,我们首先需要验证消息接口的有效性,验证通过后,才可以进行其他开发,首先 ...

  7. php 微信接口文档例子,微信开发之群发(示例代码)

    /* Author:yf 使用说明:微信公众号无限群发接口,使用实例: $test = new SendAllMsg("你的appId","你的appSecret&quo ...

  8. 服务器微信接口返回乱码,企业微信会话内容存档调用DecryptData返回中文出现乱码...

    企业微信会话内容存档调用DecryptData返回中文出现乱码 问题类型 API/组件名称 终端类型 微信版本 基础库版本 Bug 企业微信会话存档sdk 工具 无 无 我用c#开发会话存档功能,调用 ...

  9. php get微信接口乱码,php版本微信公众平台回复乱码问题解决方法

    微信公众平开发时碰到回复中文乱码了,这个问题小编发现是编码问题,其实只要把编码转成utf8就可以解决了,具体来看看. 很多微信公众平台的自动回复程序都是 ThinkWechat.class.php 这 ...

  10. php+微信接口开发的微信分销平台拆分讲解(一)微信oauth2接口

    本文不提供整套系统源码,只会开放部分源码,讲诉开发的经历.思路.问题解答,希望对新手有帮助,至于高手和大神一下而过或留下宝贵意见在此谢过. 废话不多说了开始进入正题. 基础篇 php当前主流WEB开发 ...

最新文章

  1. Building an MFC project for a non-Unicode character set is deprecated
  2. mysql 取交集 php_mysql 查询结果取交集的方法
  3. vim关于python的自动补全插件
  4. android 查看gpu频率_借骁龙 855 Plus,聊聊 CPU / GPU 怎样影响手机游戏性能
  5. python 复杂数据相似度计算_Opencv python图像处理-图像相似度计算
  6. 解决移动端 footer fixd 定位被键盘顶起来的方案
  7. bzoj1045题解
  8. 年度Sweb绩效考评表
  9. python定时发送qq消息
  10. 一部手机最长能用几年?
  11. python查看矩阵大小
  12. Protocol Buffer编译器安装
  13. 未来互联网+大数据时代
  14. unity隐藏鼠标光标的2种方法
  15. 【饥荒脚本】饥荒控制台代码自动输入
  16. 第4讲 | 区块链的应用类型
  17. 高德地图自定义点标记踩坑
  18. 谷氨酰胺合成酶(Glutamine synthetase,GS)试剂盒说明书
  19. 一位工作8年程序员的成长感悟,值得深思
  20. 商科转码之路 | 算法岗寒假实习面经

热门文章

  1. JavaOpencv实现答题卡扫描 银行卡号码截取
  2. 题目内容: 班级第一次列队,通常老师会让同学按身高排成一列,然后1、2报数,喊到1的同学向前一 步,就这样,队伍就变成两列了。假设现在一个班级有n个同学,并且他们已经按身高排成 了一列,同学按身高从1
  3. html圆形头像简易实现
  4. 递归例题讲解 一本通1215:迷宫 答案解析
  5. 【Cesium】添加polygon边界线
  6. TSW(Tencent Server Web)源码阅读指南
  7. Hyperledger Fabric 环境搭建报错
  8. ultraedit删除重复项_如何去除文本中的重复行?UltraEdit、Excel去重复方法分享
  9. Android Framebuffer介绍及使用
  10. Android4.0上添加截屏快捷方式