Parse学习社区Parse PlatformParse开发交流

微信账号登陆Parse

2017-09-06  本文已影响0人  NoStory

parse的官方文档提到如何通过第三方账号登陆注册,如facebook、twitter的登陆。同时也提供google、github等账号的登陆能力。至于如何登陆,文档里有简短描述但实验一直未成功,对国内微信、QQ等账号的登陆更是只字未提,原以为即使要使用也需要进行二次开发。但近期看其源码时竟然发现了oauth登陆微信、qq、微博等国内openid的踪迹
https://github.com/parse-community/parse-server/tree/master/src/Adapters/Auth

微信登陆和注册(REST API版本)

但如何才能绑定这些账号呢?经过大量的搜寻,终于在REST API中找到一些踪迹
http://docs.parseplatform.org/rest/guide/#linking

示例代码中,演示如何用REST API绑定facebook账号,虽然没有提到支持微信,但根据parse server在github代码证据可以猜测微信也能行得通。
参照源码:

https://github.com/parse-community/parse-server/blob/master/src/Adapters/Auth/wechat.js

对请求进行如下修改:

  1. 需要将类型由示例代码中的facebook改为wechat(根据代码的文件的明明猜测如此,经过验证后也确实为wechat)
  2. wechat的值中两个字段是必须的
    • id,微信的openid
    • access_token,微信的access_token。

另外:

修改后示例:

curl -X PUT \
  -H "X-Parse-Application-Id: YOUR_APP_ID" \
  -H "X-Parse-REST-API-Key: YOUR_MASTER_KEY" \
  -H "X-Parse-Session-Token: r:32d5839c5cb973927680a30c0e8e1a2c" \
  -H "Content-Type: application/json" \
  -d '{
        "authData": {
          "wechat": {
            "id": "your_openid",
            "access_token": "t9kYDaf1-vjBmYm4SbtwrehYOMa0Oe-iPDrRgfQ5uIUrAI-rqpgGdSk0KZbNvqgAMaqtgbm-xPz51baqq7IEuA"
          }
        }
      }' \
http://yourhost:1337/parse/users/1jhp70s6M8

微信登陆和注册(JS版本)

注册和登陆 | SIGNING UP AND LOGGING IN

假如已经完成了微信的第三方登陆授权,获得对应openid和access_token,就可以通过_linkWith方法做到自动注册(如果不存在绑定此openid的账号会注册)和登陆(如果已经存在则直接登陆),这也意味着通过_linkWith方法可以自动创建和登陆Parse账号。

关于_linkWith方法,见
http://docs.parseplatform.org/js/guide/#signing-up-and-logging-in

对应_linkWith这个函数的下划线有些好奇,是特意为止还是代码缺陷?不过没时间管了,因为除了名字还有大坑!

大坑在哪?
坑在按照官方的文档无论如何都成功不了,另外加上网上的资料几乎为零,国外的网站大部分是登陆facebook或者twitter,对登陆国内的微信之类的遇到的不是同类问题。国内又没有相关的案例(可能是Parse这个名字对搜索引擎不友好)

当前该文档和js sdk的具体行为不一致,实际使用时发现_linkWith的第二个参数需要“包”一层,否则会拼接成错误的格式,这个错误还是对比rest api版本的_linkWith时发现的,要不是rest api成功过肯定会再次放弃。

源文档中错误的代码示例:
let myAuthData = {
    //...
}
let user = new Parse.User();
user._linkWith('twitter', myAuthData).then(function(user){
    // user
});
修正后的代码示例
var myAuthData = {
  authData:{
    // 根据具体的类型,决定该字段需要填写哪些参数,比如微信需要填写id(值应当是微信的openid)和access_token
    id: "your_wechat_openid",
    "access_token": "your_access_token",
  }
}

let user = new Parse.User();
user._linkWith('wechat', myAuthData).then(function(user){
    // user
});

绑定 | LINKING

并不是所有的微信用户都是新用户。如果用户已经有了Parse账户,希望也能通过微信登陆,那需要的就需要绑定。从使用上和“注册和登陆 | SIGNING UP AND LOGGING IN”是完全一样的,唯一的区别在于:

完整代码:

    var myAuthData = {
      authData:{
        // 根据具体的类型,决定该字段需要填写哪些参数,比如微信需要填写id(值应当是微信的openid)和access_token
        id: "your_wechat_openid",
        "access_token": "your_access_token",
      }
    }
    
    var user = Parse.User.current(); // 已经登陆的user
    user._linkWith('wechat', myAuthData).then(function(user){
        // user
    });

解除绑定 | UNLINKING

又一大坑,v1.10.0版本的js sdk,绑定还可以通过改改使用方式绕过,而解绑连绕过的办法都没有!!!

被迫找找到旧版本的sdk尝试,终于在v1.9.0-rc2发现可以通过类似绑定和解绑的方式绕过bug,解除绑定

代码示例

var myAuthData = {
  authData:null
}

var user = Parse.User.current();
user._linkWith('wechat', myAuthData).then(function(user){
    // user
});
上一篇下一篇

猜你喜欢

热点阅读