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
对请求进行如下修改:
- 需要将类型由示例代码中的facebook改为wechat(根据代码的文件的明明猜测如此,经过验证后也确实为wechat)
- wechat的值中两个字段是必须的
- id,微信的openid
- access_token,微信的access_token。
另外:
- curl要put到的地址填写为你真实的地址
- X-Parse-Application-Id,你的APP_ID
- X-Parse-REST-API-Key,你的MASETER_KEY
- X-Parse-Session-Token,有效的session token(可以从dashboard的Session中找)
- curl要请求的地址,填写为http://your_parse_server/parse/users/user_object_id, user_object_id需要是X-Parse-Session-Token的用户id
修改后示例:
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”是完全一样的,唯一的区别在于:
- 不是:用new Parse.User()
- 而是:使用已经登陆的用户实例,比如Parse.User.current();
完整代码:
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
});