react native qq登录,微信登录实现(android端)

QQ登录实现:

使用第三方库react-native-qq,链接

https://github.com/reactnativecn/react-native-qq

qq腾讯开放平台获取获取用户信息文档链接

http://wiki.open.qq.com/wiki/mobile/get_simple_userinfo

1.安装npm包

yarn add react-native-qq 或 npm install react-native-qq --save

然后link执行 react-native link react-native-qq

2.配置android工程:

在android/app/build.gradle里,defaultConfig栏目下添加如下代码如图:


image
manifestPlaceholders = [
    QQ_APPID: "平台申请的APPID"
]

3.检查配置

3.1在android/settings.gradle下:

include ':react-native-qq'

project(':react-native-qq').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-qq/android')

3.2在android/app/build.gradle下

dependencies {
compile project(':react-native-qq')
}

3.3 MainApplication getPackages里面添加

image
new QQPackage(),

导入库:

import cn.reactnative.modules.qq.QQPackage;

4.代码实现

qqLogin() {

let scopes ='get_user_info';

    QQAPI.isQQInstalled()

.then(install => {

if (install) {

QQAPI.login(scopes)

.then((data) => {

if(data.errCode===0){

getRequest('https://graph.qq.com/user/get_simple_userinfo?access_token=' + data.access_token +'&openid=' + data.openid+'&oauth_consumer_key='+data.oauth_consumer_key)

.then(res => {

alert('用户信息' + JSON.stringify(res))

}).catch(err => {

})

}

}).catch((err) => {

alert('授权失败 失败信息为' +JSON.stringify(err))

})

}

})

.catch(unInstall => {

alert('没有安装QQ' + unInstall)

})

}
image

微信登录实现(react-native-wechat)

开源库地址

https://github.com/weflex/react-native-wechat

1.首先需要去微信开发平台去注册账号并且创建一个移动应用 链接 https://open.weixin.qq.com

签名获取推荐使用签名工具获取

image

2.Android版本安装配置方法,类似qq

2.1.在android/settings.gradle文件中添加如下代码:

include ':RCTWeChat'

project(':RCTWeChat').projectDir = newFile(rootProject.projectDir, '../node_modules/react-native-wechat/android')

2.2 .在android/app/build.gradle文件中的dependencies中添加模块依赖

dependencies {
compile project(':react-native-wechat')
}

2.3在MainActivity.java文件,添加如下代码

newWeChatPackage() ,

导入引用:

importcom.theweflex.react.WeChatPackage; 

2.4在android包名下创建wxapi包名,在该包名底下创建WXEntryActivity.java类

import android.app.Activity;

import android.os.Bundle;

import com.theweflex.react.WeChatModule;

public class WXEntryActivity extends Activity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

WeChatModule.handleIntent(getIntent());

finish();

}

}

在AndroidManifest.xml注册

   <activity

   android:name=".wxapi.WXEntryActivity"

    android:exported="true"

    android:label="@string/app_name" />

2.5在proguard-rules.pro添加混淆

-keep classcom.tencent.mm.sdk.** {

   *;

}

3.代码实现:

/**

* 微信登录注册

*/

componentDidMount() {

try {

WeChat.registerApp('你自己的wxid');

    }catch (e) {

console.error(e);

    }

}
/**
* 微信登录  之授权
*/
weixinLogin() {
let scope ='snsapi_userinfo';
let state ='wechat_sdk_abcs';
//判断微信是否安装
WeChat.isWXAppInstalled()
.then((isInstalled) => {
if (isInstalled) {
// 获取微信授权
  WeChat.sendAuthRequest(scope, state)
.then(responseCode => {
//授权成功获取token
this.getAccessToken(responseCode);
                    })
.catch(error => {
alert('登录授权发生错误:', error.message, [
{text:'确定'}
]);
                    })

}else {
alert('没有安装微信', '请先安装微信客户端在进行登录', [
{text:'确定'}
])
}
})
}
/**
* 微信登录 获取 token
* @param responseCode
*/
getAccessToken(responseCode) {
let appId ='你申请的appid';
 let secret ='你申请的secret';
switch (parseInt(responseCode.errCode)) {
// 用户换取access_token的code,仅在ErrCode为0时有效  
        case 0:
//获取token值
getRequest('https://api.weixin.qq.com/sns/oauth2/access_token?appid=' + appId +'&secret=' + secret +'&code=' + responseCode.code +'&grant_type=authorization_code')
.then(res => {
//授权成功,获取用户头像等信息
this.getUserInfoFormWx(res);
                })
.catch(err => {

})
break;
        case -4:
//用户拒绝
            break;
        case -2:
//用户取消
            break;
    }
}
/*** 微信登录 获取用户信息*/

getUserInfoFormWx(res)
{
getRequest('https://api.weixin.qq.com/sns/userinfo?access_token=' +
res.access_token +'&openid=' + res.openid).then(res =>
{
ToastAndroid.show('用户信息' + JSON.stringify(res),
ToastAndroid.SHORT)
}
).catch(err => {})
}
wx_jt.png

(完)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342