数天前,为解决微信二维码扫码登陆在Electorn跳转处理繁琐的问题,写一个微信开放平台扫码登陆解析处理工具😊,将frame数据处理为图片或Base64图片数据返回客户端进行扫码。解决Chrome70中open.weixin.qq.com腾讯SSL证书不被信任的问题(微信官方于2018年8月23日更换了域名证书),解决Chrome68中frame跨域被拦截的问题。
此方案最大特点:扫码登录无跳转🤠。
Node.js 版本 Demo:https://weixin.openapi.site/demo
PHP 版本 Demo:https://apio.xyz/weixin-login-php/
此方案仅适用于微信开放平台-网站应用。
Node.js版本为什么不封为NPM库? 这个功能的代码比较简单,https和URL库都是nodejs自带的,直接复制过去用就好了。
请阅读WeixinLoginClientHandler.js文件。
第一步:获取微信UUID;
第二步:根据微信UUID获取二维码图片;
第三步:获取微信服务器返回的Code(详见微信开放平台文档)。
直接请求https://weixin.openapi.site/img?appid=您的appid&redirect_uri=您在微信开放平台后台设置的授权回调域,获取二维码和UUID。
再次请求https://weixin.openapi.site/check?uuid=上一步得到的UUID,获得登录结果的数据。
您要是懒得部署一套,可以直接使用以上地址。
先阅读源码,修改server.js里面的配置信息,使用npm start启动项目。
访问http://localhost:65533/login/weixin/demo即可进行测试。
weixinLoginClientHandler.weixinUUID().then(r => console.log(r)) \\ 获取微信uuid(用于获取微信二维码和Ajax轮询结果所需参数)
weixinLoginClientHandler.weixinQRCodeImgURL().then(r => console.log(r)) \\ 可以直接获取二维码图片
weixinLoginClientHandler.weixinQRCodeImgBase64().then(r => console.log(r)) \\ 获取二维码图片的Base64数据(主要用于Chrome70中腾讯所使用的赛门铁克证书失效的情况)
weixinLoginClientHandler.getCode(uuid, params.last).then(r => console.log(r)) \\ 获取微信服务器返回的Code(第一个连接是长连接,当用户处于“扫描成功,请在微信中点击确认即可登录”状态时可能会变为轮询,这主要由腾讯服务器控制)
import WeixinLoginClientHandler from './WeixinLoginClientHandler.js'
const weixinLoginClientHandler = new WeixinLoginClientHandler({
appid: 'wx827225356b689e24',
redirect_uri: 'https://qq.jd.com/',
state: ''
})
weixinLoginClientHandler.weixinUUID().then(r => {
console.log(r)
weixinLoginClientHandler.weixinQRCodeImgBase64(r).then(r => console.log(r))
})
weixinLoginClientHandler.weixinQRCodeImgURL().then(r => console.log(r))
第一步:根据Appid及授权回调域获取二维码图片和微信UUID; 第二步:获取微信服务器返回的Code(详见微信开放平台文档)。
直接请求https://apio.xyz/weixin-login-php/weixin.php?appid=您的appid&redirect_uri=您在微信开放平台后台设置的授权回调域,获取二维码和UUID。
再次请求https://apio.xyz/weixin-login-php/weixin.php?uuid=上一步得到的UUID,获得登录结果的数据。
您要是懒得部署一套,可以直接使用以上地址。
数天前,为解决微信二维码扫码登陆在Electorn跳转处理繁琐的问题,写一个微信开放平台扫码登陆解析处理工具😊,将frame数据处理为图片或Base64图片数据返回客户端进行扫码。解决Chrome70中open.weixin.qq.com腾讯SSL证书不被信任的问题(微信官方于2018年8月23日更换了域名证书),解决Chrome68中frame跨域被拦截的问题。
此方案最大特点:扫码登录无跳转🤠。
Node.js 版本 Demo:https://weixin.openapi.site/demo
PHP 版本 Demo:https://apio.xyz/weixin-login-php/
此方案仅适用于微信开放平台-网站应用。
Node.js版本为什么不封为NPM库? 这个功能的代码比较简单,https和URL库都是nodejs自带的,直接复制过去用就好了。
请阅读WeixinLoginClientHandler.js文件。
第一步:获取微信UUID;
第二步:根据微信UUID获取二维码图片;
第三步:获取微信服务器返回的Code(详见微信开放平台文档)。
直接请求https://weixin.openapi.site/img?appid=您的appid&redirect_uri=您在微信开放平台后台设置的授权回调域,获取二维码和UUID。
再次请求https://weixin.openapi.site/check?uuid=上一步得到的UUID,获得登录结果的数据。
您要是懒得部署一套,可以直接使用以上地址。
先阅读源码,修改server.js里面的配置信息,使用npm start启动项目。
访问http://localhost:65533/login/weixin/demo即可进行测试。
weixinLoginClientHandler.weixinUUID().then(r => console.log(r)) \\ 获取微信uuid(用于获取微信二维码和Ajax轮询结果所需参数)
weixinLoginClientHandler.weixinQRCodeImgURL().then(r => console.log(r)) \\ 可以直接获取二维码图片
weixinLoginClientHandler.weixinQRCodeImgBase64().then(r => console.log(r)) \\ 获取二维码图片的Base64数据(主要用于Chrome70中腾讯所使用的赛门铁克证书失效的情况)
weixinLoginClientHandler.getCode(uuid, params.last).then(r => console.log(r)) \\ 获取微信服务器返回的Code(第一个连接是长连接,当用户处于“扫描成功,请在微信中点击确认即可登录”状态时可能会变为轮询,这主要由腾讯服务器控制)
import WeixinLoginClientHandler from './WeixinLoginClientHandler.js'
const weixinLoginClientHandler = new WeixinLoginClientHandler({
appid: 'wx827225356b689e24',
redirect_uri: 'https://qq.jd.com/',
state: ''
})
weixinLoginClientHandler.weixinUUID().then(r => {
console.log(r)
weixinLoginClientHandler.weixinQRCodeImgBase64(r).then(r => console.log(r))
})
weixinLoginClientHandler.weixinQRCodeImgURL().then(r => console.log(r))
第一步:根据Appid及授权回调域获取二维码图片和微信UUID; 第二步:获取微信服务器返回的Code(详见微信开放平台文档)。
直接请求https://apio.xyz/weixin-login-php/weixin.php?appid=您的appid&redirect_uri=您在微信开放平台后台设置的授权回调域,获取二维码和UUID。
再次请求https://apio.xyz/weixin-login-php/weixin.php?uuid=上一步得到的UUID,获得登录结果的数据。
您要是懒得部署一套,可以直接使用以上地址。