微信登录的几种方式 以及在前后端分离如何实现
2019-11-08 16:04:47来源:博客园 阅读 ()
微信登录的几种方式 以及在前后端分离如何实现
要处理微信第三方登录,已经是很正常的需求,读微信公开的文档,感觉还是有一些坑,自己写一个随笔好记录一下。
大概两年前,初次接触微信第三方登录的需求是一个网页应用,大概就是在微信开放平台申请一个开放平台权限,然后创建一个app,在app里面配置一个回调域名,当用户点击微信登录时,把用户带到微信那边的二维码,然后用户扫码,微信那边通过之后,带着某些信息,redirect到我们的一个action,然后,我们通过读取这个action中的token拿到用户的profile,通过用户profile可以找到对应的用户userid,然后授权登录。这种方式试用与没有微信公众号的企业,仅仅把微信当做了方便用户去登录的渠道。
这次我们要说的是另外一种登录方式,就是通过微信公众号来实现第三方登录。
前期准备工作,首先需要一个公众号。以管理者的方式登录微信号之后,在左下方可以找到关于开发的菜单:
我们在公众号的首先就会有APPID和APPSecret,我们需要配置服务器,这里配置服务器时特别要注意,也是与第一种登录方式不一样的地方,这里设置的不是一个hostname,而是一个具体的request。
文档里面没有过多地做说明,但是其实这里配置的URL有两个意思。
1.微信会对这个地址调用get请求,会传入几个参数,然后你得按照他的要求返回,这样就能通过这个配置。
2.这也是文档里面没有说明的一个点,就是,当之后用户通过二维码扫描进来时,微信会对这个url发送一个post请求,这个post请求会传入scene相关信息。scene其实就是让开发者来传递的参数。
post格式文档里面有:
<xml> <ToUserName><![CDATA[toUser]]></ToUserName> <FromUserName><![CDATA[FromUser]]></FromUserName> <CreateTime>123456789</CreateTime> <MsgType><![CDATA[event]]></MsgType> <Event><![CDATA[subscribe]]></Event> </xml>
你还需要对这个post请求做相应的响应,给你的直观感受就是当你扫描二维码进入微信的提示。一般会是欢迎 XXX 登录什么系统。
在微信的说明文档上,没有说明这个返回值。其实返回值是
<xml>
<ToUserName>xxxxxxxx</ToUserName>
<FromUserName>xxxxxxxx</FromUserName>
<CreateTime>1573190078536</CreateTime>
<MsgType>text</MsgType>
<Content>绑定超时或失败,请再次绑定!</Content>
</xml>
然后再一个,当你是一台电脑做服务器,分布式时,需要在你的nginx里做一个反向代理,大概的意思就是把 /xxx 映射到 xxxx:port/wx
因为设置微信URL时,不能填写端口,所以只能是80端口或者443端口。
location /wx {
proxy_pass http://localhost:8082/wx/checkSignature;
}
原文链接:https://www.cnblogs.com/hellocz/p/11819519.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:ARTS改版啦,在改变中前行
下一篇:创建的第一天
- SpringBoot实现微信小程序登录的完整例子 2020-06-01
- 单点登录终极方案之 CAS 应用及原理 2020-05-22
- 如何利用Spring Boot 整合微信小程序实现登录与增删改查(含 2020-05-20
- CRM系统用户登录功能如何实现?Java高级项目实战必学 2020-05-16
- 面试必问-几种线程安全的Map解析 2020-05-09
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash