QQ分享
引入sdk里的jar包
清单文件配置
<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>
要接收分享的回调,需要实现IUiListener,里面有三个回调方法。并在调用分享的Activity的onActivityResult方法中,增加如下代码
Tencent.onActivityResultData(requestCode,resultCode,data,listener);
微博分享
申请key
App Key:1647950651
App Secret:
2167d823481f16b3454259fe37ce7aa4
接入
接入文档
- 项目层级的build下添加maven { url "https://dl.bintray.com/thelasterstar/maven/" }
allprojects {
repositories {
jcenter()
mavenCentral()
maven { url "https://dl.bintray.com/thelasterstar/maven/" }
}
}
app层级下的build添加 compile 'com.sina.weibo.sdk:core:4.3.5:openDefaultRelease@aar'或者直接复制aar文件引入
关于so文件,微博sdk aar中默认直提供了[armeabi] [armeabi-v7a] [x86]三个平台的so,如果你需要适配更多版本的so,请到github->so目录中获取全部平台的so文件
关于混淆 -keep class com.sina.weibo.sdk.** { *; }
-
关于回调:
4.3.0开始用下面方法接收,之前是重写onNewIntent,需要注意@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); shareHandler.doResultIntent(data,this); }
微信分享
-
声明依赖
dependencies { compile 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:+' }
或者
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+'
}
第一个的without版本不包含统计功能
-
加权限
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
-
在程序入口向微信客户端注册你的APP_ID
iwxapi = WXAPIFactory.createWXAPI(this,WeChatConstants.APP_ID,true); iwxapi.registerApp(WeChatConstants.APP_ID);
-
接收微信的请求及返回值
需要在包名目录下新建一个wxapi目录,新增一个WXEntryActivity类,继承自Activity,注意包名目录在AS环境下应该是applicationId
实现IWXAPIEventHandler接口,微信发送的请求将回调到onReq方法,发送到微信请求的响应结果将回调到onResp方法,实例代码
public class WXEntryActivity extends Activity implements IWXAPIEventHandler {
IWXAPI api;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
api = WXAPIFactory.createWXAPI(this, WeChatConstants.APP_ID);
api.handleIntent(getIntent(), this);
}
@Override
public void onReq(BaseReq baseReq) {
}
@Override
public void onResp(BaseResp resp) {
String result = "";
switch (resp.errCode) {
case BaseResp.ErrCode.ERR_OK:
result = "微信发送成功";
break;
case BaseResp.ErrCode.ERR_USER_CANCEL:
result = "微信发送取消";
break;
case BaseResp.ErrCode.ERR_AUTH_DENIED:
result = "微信发送被拒绝";
break;
case BaseResp.ErrCode.ERR_UNSUPPORT:
result = "微信不支持错误";
break;
default:
result = "微信发送返回";
break;
}
Toast.makeText(this, result, Toast.LENGTH_LONG).show();
finish();
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
if (api == null) {
api = WXAPIFactory.createWXAPI(this, WeChatConstants.APP_ID);
}
api.handleIntent(intent, this);
}
}
在AndroidManifest里注册
<activity
android:name="${applicationId}.wxapi.WXEntryActivity"
android:label="@string/app_name"
android:exported="true"
/>
- 混淆
-keep class com.tencent.mm.opensdk.** {
*;
}
-keep class com.tencent.wxop.** {
*;
}
-keep class com.tencent.mm.sdk.** {
*;
}
关于回调
由于微博跟QQ都是在onActivityResult里接收回调的,所以要判断是哪个分享的返回,微信的返回写在WXEntryActivity里
if (data!=null && data.getComponent() !=null){
if (data.getComponent().getClassName().equals("com.sina.weibo.sdk.share.WbShareTransActivity")){
ShareUtils.INSTANCE.getAction().wbShareHandler.doResultIntent(data,ShareUtils.INSTANCE.getAction());
} else if (data.getComponent().getClassName().equals("com.tencent.connect.common.AssistActivity")){
Tencent.onActivityResultData(requestCode,resultCode,data,ShareUtils.INSTANCE.getAction());
}
}
微信的回调在WXEntryActivity下的onResp方法中,值得注意的是,无论是分享成功还是取消分享,返回的结果码都是BaseResp.ErrCode.ERR_OK,另外分享成功时,如果选择停留在微信,将收不到返回结果。