Android,微信,微博,QQ三方分享
QQ分享
SDK下載地址
引入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
接入
接入文件
ofollow,noindex">github地址
- 專案層級的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"/>
-
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,另外分享成功時,如果選擇停留在微信,將收不到返回結果。