写点什么

AngularJS 进阶 (十七) 在 AngularJS 应用中集成微信认证授权遇到的坑

  • 2022-12-04
    江苏
  • 本文字数:1764 字

    阅读完需:约 6 分钟

AngularJS进阶(十七)在AngularJS应用中集成微信认证授权遇到的坑

​前言      

      项目开发过程中,移动端新近增加了一个功能“微信授权登录”,由于自己不是负责移动端开发的,但最后他人负责的部分未达到预期效果。不能准确实现微信授权登录。最后还得靠自己做进一步的优化工作,谁让自己是负责人呢?原来负责人就是负责最后把所有的 BUG 解决掉。

      首先,熟悉一下微信授权部分的源代码,如下所示:


/*-------------- 微信授权登陆 --------------*/// 扩展 API 加载完毕后触发“plusready"事件document.addEventListener("plusready", function() {// 扩展API加载完毕,现在可以正常调用扩展APIplus.oauth.getServices(function(services) {// services.length可获取当前运行环境支持授权登录认证服务数目if (services.length > 0) {auths = services;} else {alert("当前运行环境不支持授权登录认证服务!");}}, function(e) {alert("获取分享服务列表失败:" + e.message + " - " + e.code);});}, false); // 微信授权登录操作$scope.authLogin = function(){for(var i = 0; i < auths.length; i++){console.log(auths[i].description);if(auths[i].description == "微信"){var s = auths[i];break;}}if (!s.authResult) {console.log("微信尚未授权");s.login(//登录认证成功function(e){console.log("微信登录认证成功!");var objuser = s.userInfo;var uname = objuser.nickname;console.log(objuser.nickname);localStorage.uid = uname;localStorage.logined = "2";$rootScope.userinfo = {'logined': "2",'username': uname};console.log(localStorage.logined);$scope.set_defaultaddr();//登录后查询订单$scope.getBillBadge();if (sessionStorage) {        console.log(sessionStorage.getItem("hisURL"));        if(sessionStorage.getItem("hisURL")=='/tab/med_search')        $rootScope.familyBox();        $location.path(sessionStorage.getItem("hisURL"));        }},//登录认证失败function(e){alert( "登录认证失败!" );});}else{console.log("已经登录认证!");}
复制代码


      授权认证步骤:获取授权登录认证服务——>授权登录认证服务

      手机之间在运行同一款软件时由于系统差异也是存在表现差异。如下图所示,上图为红米 Android4.4.4 版本上的测试结果,下图为魅族 5.0.1 版本上的测试结果。很明显下图手机不能实现定位功能。

      更明显的差异存在于授权部分,调用授权服务时返回的数组内容不同,从下图可明显看出微信与 QQ 在返回数组中的位置不同。

 



       参考文献:HTML5+ API Reference

         授权登录插件配置 - DCloud问答


平台支持:

Android - 2.2+ (不支持)

iOS - 5.0+ (不支持)


注: Js 中判断两字符串是否相等,使用“==”判断。不能使用 equals。


又出现了问题,在手机上调试一切正常,等到打包成 APK 就出现不能授权(提示登录认证失败)的问题。

alert( "登录认证失败!" e.message+" - "+e.code);如下图所示:

 


还是直接在手机测试,出现下面的现象:

 


感觉处于一种死循环的状态,但自己也一时找不到可以修改的地方。

注:

      微信登录配置的参数必须要提交在线打包才能生效(真机调试的时候使用的是 HBuilder 基座的参数)。

      尝试根据返回的错误信息进行修正。

      通过查阅资料终于发现问题所在了。授权中配置的参数必须来自微信开放平台申请所得,而非公众平台。那么二者之间又存在什么样的区别呢?接下来继续讲解。



微信开放平台和公众平台的区别?

      简单来讲,微信公众平台是我们常见的公众号,包括订阅号、服务号和企业号,主要用于不具备太强技术开放能力,拥有一定运营能力的品牌、商户、媒体以及个人,作为一个自媒体平台或者服务窗口来用,是面向更广大的人群使用的。

      微信开放平台是一个开发者平台,针对的是有较强技术开发能力、能够研发同微信对接的应用开发者来使用的,面向的是技术公司和开发者,不是面向所有人都可以使用的。

      因此对于分不清二者区别的人来讲,用公众平台就对了,能用得上开放平台的人肯定都是对开放平台功能有一定了解的人群。


      那么,微信开放平台与公众平台注册所得信息通用吗?

      答案是 NO!因为注册时就不允许使用同一邮箱注册。

发布于: 2022-12-04阅读数: 30
用户头像

No Silver Bullet 2021-07-09 加入

岂曰无衣 与子同袍

评论

发布
暂无评论
AngularJS进阶(十七)在AngularJS应用中集成微信认证授权遇到的坑_AngularJS_No Silver Bullet_InfoQ写作社区