微信小程序技术教程之用户授权登陆开发

2018/3/28 18:14:47
摘要: 微信用户授权登陆的时候,用来记录用户身份唯一性的标识就是微信中的unionID,所以在做授权登陆开发的时候,如何拿到


 微信用户授权登陆的时候,用来记录用户身份唯一性的标识就是微信中的unionID,所以在做授权登陆开发的时候,如何拿到unionID就成为开发的关键之一。本文介绍微信小程序JS代码登陆流程与服务器处理流程,来说说如何进行用户授权登陆开发 。

1、JS代码登陆流程及示例代码

(1)微信小程序JS代码的登陆流程为:login ->获取code ->getUserInfo获取iv和encryptedData ->传给自己的服务器处理 ->返回给小程序结果。

(2)JS登陆示例代码如下

var API_URL = "自己的服务器地址";

Page({

  onLoad: function () {

  console.log("iv");

  wx.login({//login流程

  success: function (res) {//登录成功

    if (res.code) {

      var code = res.code;

      wx.getUserInfo({//getUserInfo流程

        success: function (res2) {//获取userinfo成功

        console.log(res2);

        var encryptedData = encodeURIComponent(res2.encryptedData);//一定要把加密串转成URI编码

          var iv = res2.iv;

          //请求自己的服务器

         Login(code,encryptedData,iv);

        }

      })

 

    } else {

      console.log('获取用户登录态失败!' + res.errMsg)

    }

  }

});

(3)所需参数介绍

code:服务器用来获取sessionKey的必要参数

encryptedData:加密过的字符串

IV:加密算法的初始向量

(4)服务器处理流程示例代码

function  Login(code,encryptedData,iv){  console.log('code='+code+'&encryptedData='+encryptedData+'&iv='+iv);

 //创建一个dialog

          wx.showToast({

            title: '正在登录...',

            icon: 'loading',

            duration: 10000

          });

          //请求服务器

          wx.request({

            url: API_URL,

            data: {

              code:code,

              encryptedData:encryptedData,

              iv:iv

            },

            method: 'GET', // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT

            header: {

              'content-type': 'application/json'

            }, // 设置请求的 header

            success: function (res) {

              // success

              wx.hideToast();

              console.log('服务器返回'+res.data);

 

            },

            fail: function () {

              // fail

              // wx.hideToast();

            },

            complete: function () {

              // complete

            }

          })

  }

2、服务器解析说明及示例代码

  微信授权登陆所需的标识用户身份唯一性的unionID,就在encryptedData中,所以获取unionID则需要在encryptedData这些信息中将它解析出来,解析流程是:通过微信的https://api.weixin.qq.com/sns/jscode2session接口获取seesionKey,然后在通过sessionKey和iv来解密encryptedData数据获取UnionID。 示例代码如下所示。

/**

     *    登录

     *

     * @return Response

     */

    public function weixinlogin( $user_id=null )

    {

            global $App_Error_Conf,$Gift_Ids,$Server_Http_Path,$Is_Local,$Test_User,$Good_Vcode,$WeiXin_Xd_Conf;

            $validator_result = input_validator(array('code','iv','encryptedData'));

            if(!empty($validator_result)){

                    return response($validator_result);

            }

            $js_code = $_REQUEST['code'];

            $encryptedData = $_REQUEST['encryptedData'];

            $iv = $_REQUEST['iv'];

            $appid = $WeiXin_Xd_Conf['appid'];

            $secret =  $WeiXin_Xd_Conf['secret'];

            $grant_type =  $WeiXin_Xd_Conf['grant_type'];

            //从微信获取session_key

            $user_info_url = $WeiXin_Xd_Conf['code2session_url'];

            $user_info_url = sprintf("%s?appid=%s&secret=%s&js_code=%s&grant_type=%",$user_info_url,$appid,$secret,$js_code,$grant_type);

            $weixin_user_data = json_decode(get_url($user_info_url));

            $session_key = $weixin_user_data->session_key;

//解密数据

$data = '';

$wxBizDataCrypt = new WXBizDataCrypt($appid, $session_key);

$errCode=$wxBizDataCrypt>decryptData($appid,$session_key,$encryptedData, $iv, $data );

在拿到解析后的encryptedData之后,就可以在里面找到unionID,而用户的微信授权登陆开发也就实现了。


声明:文章"微信小程序技术教程之用户授权登陆开发"为互诚科技—微信小程序开发公司的原创文章,转载请注明出处,谢谢合作!
标签:小程序干货
电话咨询:18011971195(黄先生)
在线留言:
微信扫码,关注我们
相关文章
  • 小程序在未来的应用场景可以有哪些?

    现在的微信小程序应用场景除了线上之外,更多的是线下的。不过由于现在仍处于发展的初级阶段,所以不是每个行业都能在小程序开发的服务范围之内,一些仍未涉及到的行业还有待开发。这些有待开发的行业与应用场景,就是我们今天这篇文章要说的中心点。

  • 开发微信小程序对哪些行业影响比较大?

    虽然小程序从内测到上线后都没有来势汹汹的气势,但还是止不住小程序的各种优点的传播发散以及对一些

  • 小程序onLaunch执行异步,如何解决onLoad先执行的问题?

    小程序开发时,按照事件顺序,小程序初始化触发APP的onlaunch后,在去是行页面Page的onload。但现实常常是,由于onlaunch

  • 微信小程序开发,想要突破重围力压对手这样做

    ​虽说微信小程序现在的开发市场竞争力还不是很大,但是小程序的开发数量还是在以快速的增加速度增长着,因而市场竞争压力也会逐渐加大,一如公众号当初的发展趋势一样。对于一些比较迟进入小程序

  • 定制化微信小程序为何价格会高那么多

    无论是定制版本的微信小程序还是公众号、微商城,价格都会比模板制作的高出一些。那为什么会高?又高在哪里?这两个问题的回答就能让企业商家看出定制开发是否值得,所以小编得摩拳擦掌来好好夸大其词了。

  • 品牌电商公司如何借力微信小程序开发来促进发展

    虽然微信小程序刚开始的定位是为用户提供线下工具性服务,但却也因为这个定位限制了小程序的发展以致带来不满意的用户体验与开发体验。在后续的调整后,小程序也可以用作线上服务使用,