Android接入第三方QQ登录

本文档详细介绍了如何在Android应用中接入第三方QQ登录,包括添加依赖、配置AndroidManifest.xml、初始化SDK、创建实例、实现回调、调用登录接口以及在Android 10以上版本的适配方法。在接入过程中,特别注意Android 10以上的权限适配和SDK的设备信息处理,以确保登录流程的顺利进行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

上周五老板发飙,苦逼程序员抓狂,纠结了一天,郁闷了周六和周末,今天再次打开第三方QQ登录的demo,猛然发现demo的compileSdkVersion竟然是29,而我的工程compileSdkVersion是30,点击使用qq登录时,界面跳转至QQ下载界面,日志显示fileProvider找不到,我也是醉了,android 10以上的变化还是得做好适配!

开始接入

1. 添加依赖

dependencies {
   
 implementation 'com.tencent.tauth:qqopensdk:3.52.0'
}

2.AndroidManifest.xml配置

<uses-permission android:name="android.permission.INTERNET" /> 
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<application>  
 <activity        
    android:name="com.tencent.tauth.AuthActivity"      
    android:noHistory="true"       
    android:launchMode="singleTask" >     
  <intent-filter>            
      <action android:name="android.intent.action.VIEW" />           
      <category android:name="android.intent.category.DEFAULT" />            
      <category android:name="android.intent.category.BROWSABLE" />            
      <data android:scheme="tencent你的AppId" />     
  </intent-filter>  
 </activity> 
<activity        
   android:name="com.tencent.connect.common.AssistActivity"       
   android:configChanges="orientation|keyboardHidden"        
   android:screenOrientation="behind" 
android:theme="@android:style/Theme.Translucent.NoTitleBar" /> 
<application>

3.初始化SDK

3.5.7版本新增接口提供用户设置是否已授权获取设备信息,在调用互联SDK相关功能接口之前,需要应用在确认用户已授权应用获取设备信息后,调用下面代码通知 SDK:

Tencent.setIsPermissionGranted(true);

如果未调用该接口或传参为false时,调用其它功能接口将直接返回失败。

3.5.9版本中可以调用Tencent.setisPermissionGranted(true, Build.Model)传入Build.Model,传入后SDK内部不再自行获取。

4.创建实例

@Override
public void onCreate(Bundle savedInstanceState){
    
super.onCreate(savedInstanceState); 
setContentView(R.layout.activity_main); 
// Tencent类是SDK的主要实现类,开发者可通过Tencent类访问腾讯开放的OpenAPI。 
// 其中APP_ID是分配给第三方应用的appid,类型为String。 
// 其中Authorities为 Manifest文件中注册FileProvider时设置的authorities属性值 
mTencent = Tencent.createInstance(APP_ID, this.getApplicationContext(), Authorities); 
// 1.4版本:此处需新增参数,传入应用程序的全局context,可通过activity的getApplicationContext方法获取 
// 初始化视图 initViews(); 
}

5.实现回调

所有的SDK接口调用,都会传入一个回调,用以接收SDK返回的调用结果。回调的主要接口有两种:

(1) 实现回调 IUiListener

调用SDK已经封装好的接口时,例如:登录、快速支付登录、应用分享、应用邀请等接口,需传入该回调的实例。

IUiListener的实现示例代码如下:

private class BaseUiListener implements IUiListener {
    
@Override
public void onComplete(JSONObject response) {
    
mBaseMessageText.setText("onComplete:"
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值