Android應(yīng)用接入微信分享的實(shí)例代碼
最近項(xiàng)目中要接入微信分享,記錄下接入流程
注冊(cè)應(yīng)用信息并下載必要工具
- 在微信開(kāi)放平臺(tái)注冊(cè)應(yīng)用信息
- 下載 簽名生成工具獲取待接入應(yīng)用的簽名
- 應(yīng)用信息填入簽名
注意:由于一般調(diào)試簽名和正式簽名不一致,測(cè)試時(shí)可填入測(cè)試包的簽名,上線時(shí)需要改為正式包的簽名
接入
在build.gradle中,添加如下依賴:
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+'
}
或:
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:+'
}
其中,前者包含統(tǒng)計(jì)功能
AndroidManifest.xml中添加權(quán)限和微信回調(diào)Activity
<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <!-- for mta statistics --> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> <uses-permission android:name="android.permission.READ_PHONE_STATE"/> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> <activity android:name=".WXEntryActivity" android:exported="true" android:screenOrientation="portrait" android:theme="@style/AppTheme.Fullscreen.Translucent"/>
這里使用了一個(gè)透明的Activity來(lái)處理微信分享結(jié)果回調(diào)
主題:
<style name="AppTheme.Fullscreen" parent="Theme.AppCompat.NoActionBar"> <item name="android:windowNoTitle">true</item> <item name="android:windowFullscreen">true</item> <item name="android:windowTranslucentNavigation" tools:targetApi="kitkat">true</item> </style> <style name="AppTheme.Fullscreen.Translucent"> <item name="android:windowBackground">@android:color/transparent</item> <item name="android:windowIsTranslucent">true</item> <item name="android:windowAnimationStyle">@android:style/Animation.Translucent</item> </style>
Activity
當(dāng)微信分享成功,點(diǎn)擊返回App時(shí),微信會(huì)主動(dòng)調(diào)用WXEntryActivity,并將結(jié)果通過(guò)Intent傳給WXEntryActivity,此時(shí)調(diào)用api.handleIntent(getIntent(), this)對(duì)結(jié)果進(jìn)行處理,handleIntent第二個(gè)參數(shù)為IWXAPIEventHandler,分享結(jié)果會(huì)在onResp方法中處理,在這里我們發(fā)送一個(gè)廣播,并在WXShare對(duì)象中對(duì)該廣播進(jìn)行監(jiān)聽(tīng)
public class WXEntryActivity extends BaseActivity implements IWXAPIEventHandler {
private IWXAPI api;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Logger.i("WXEntryActivity");
WXShare share = new WXShare(this);
api = share
// .register()
.getApi();
//注意:
//第三方開(kāi)發(fā)者如果使用透明界面來(lái)實(shí)現(xiàn)WXEntryActivity,需要判斷handleIntent的返回值,如果返回值為false,則說(shuō)明入?yún)⒉缓戏ㄎ幢籗DK處理,應(yīng)finish當(dāng)前透明界面,避免外部通過(guò)傳遞非法參數(shù)的Intent導(dǎo)致停留在透明界面,引起用戶的疑惑
try {
if (!api.handleIntent(getIntent(), this)) {
finish();
}
} catch (Exception e) {
e.printStackTrace();
}
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
Logger.i("onNewIntent");
setIntent(intent);
if (!api.handleIntent(intent, this)) {
finish();
}
}
@Override
public void onReq(BaseReq baseReq) {
}
@Override
public void onResp(BaseResp baseResp) {
Intent intent = new Intent(WXShare.ACTION_SHARE_RESPONSE);
intent.putExtra(WXShare.EXTRA_RESULT, new WXShare.Response(baseResp));
sendBroadcast(intent);
finish();
}
}
工具類
public class WXShare {
public static final String APP_ID = "wx0123456789";
public static final String ACTION_SHARE_RESPONSE = "action_wx_share_response";
public static final String EXTRA_RESULT = "result";
private final Context context;
private final IWXAPI api;
private OnResponseListener listener;
private ResponseReceiver receiver;
public WXShare(Context context) {
api = WXAPIFactory.createWXAPI(context, APP_ID);
this.context = context;
}
public WXShare register() {
// 微信分享
api.registerApp(APP_ID);
receiver = new ResponseReceiver();
IntentFilter filter = new IntentFilter(ACTION_SHARE_RESPONSE);
context.registerReceiver(receiver, filter);
return this;
}
public void unregister() {
try {
api.unregisterApp();
context.unregisterReceiver(receiver);
} catch (Exception e) {
e.printStackTrace();
}
}
public WXShare share(String text) {
WXTextObject textObj = new WXTextObject();
textObj.text = text;
WXMediaMessage msg = new WXMediaMessage();
msg.mediaObject = textObj;
// msg.title = "Will be ignored";
msg.description = text;
SendMessageToWX.Req req = new SendMessageToWX.Req();
req.transaction = buildTransaction("text");
req.message = msg;
req.scene = SendMessageToWX.Req.WXSceneSession;
boolean result = api.sendReq(req);
Logger.i("text shared: " + result);
return this;
}
public IWXAPI getApi() {
return api;
}
public void setListener(OnResponseListener listener) {
this.listener = listener;
}
private String buildTransaction(final String type) {
return (type == null) ? String.valueOf(System.currentTimeMillis()) : type + System.currentTimeMillis();
}
private class ResponseReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Response response = intent.getParcelableExtra(EXTRA_RESULT);
Logger.d("type: " + response.getType());
Logger.d("errCode: " + response.errCode);
String result;
if (listener != null) {
if (response.errCode == BaseResp.ErrCode.ERR_OK) {
listener.onSuccess();
} else if (response.errCode == BaseResp.ErrCode.ERR_USER_CANCEL) {
listener.onCancel();
} else {
switch (response.errCode) {
case BaseResp.ErrCode.ERR_AUTH_DENIED:
result = "發(fā)送被拒絕";
break;
case BaseResp.ErrCode.ERR_UNSUPPORT:
result = "不支持錯(cuò)誤";
break;
default:
result = "發(fā)送返回";
break;
}
listener.onFail(result);
}
}
}
}
public static class Response extends BaseResp implements Parcelable {
public int errCode;
public String errStr;
public String transaction;
public String openId;
private int type;
private boolean checkResult;
public Response(BaseResp baseResp) {
errCode = baseResp.errCode;
errStr = baseResp.errStr;
transaction = baseResp.transaction;
openId = baseResp.openId;
type = baseResp.getType();
checkResult = baseResp.checkArgs();
}
@Override
public int getType() {
return type;
}
@Override
public boolean checkArgs() {
return checkResult;
}
@Override
public int describeContents() {
return 0;
}
@Override
public void writeToParcel(Parcel dest, int flags) {
dest.writeInt(this.errCode);
dest.writeString(this.errStr);
dest.writeString(this.transaction);
dest.writeString(this.openId);
dest.writeInt(this.type);
dest.writeByte(this.checkResult ? (byte) 1 : (byte) 0);
}
protected Response(Parcel in) {
this.errCode = in.readInt();
this.errStr = in.readString();
this.transaction = in.readString();
this.openId = in.readString();
this.type = in.readInt();
this.checkResult = in.readByte() != 0;
}
public static final Creator<Response> CREATOR = new Creator<Response>() {
@Override
public Response createFromParcel(Parcel source) {
return new Response(source);
}
@Override
public Response[] newArray(int size) {
return new Response[size];
}
};
}
}
接口
public interface OnResponseListener {
void onSuccess();
void onCancel();
void onFail(String message);
}
使用
在需要使用微信分享的Activity中:
@Override
protected void onCreate(Bundle savedInstanceState) {
wxShare = new WXShare(this);
wxShare.setListener(new OnResponseListener() {
@Override
public void onSuccess() {
// 分享成功
}
@Override
public void onCancel() {
// 分享取消
}
@Override
public void onFail(String message) {
// 分享失敗
}
});
}
@Override
protected void onStart() {
super.onStart();
wxShare.register();
}
@Override
protected void onDestroy() {
wxShare.unregister();
super.onDestroy();
}
啟動(dòng)分享
wxShare.share("這是要分享的文字");
到這里微信分享就完成啦!
另外,在微信官方例程中,有個(gè)定時(shí)刷新應(yīng)用注冊(cè)信息的receiver
AndroidManifest.xml中添加:
<receiver
android:name=".AppRegister"
android:permission="com.tencent.mm.plugin.permission.SEND">
<intent-filter>
<action android:name="com.tencent.mm.plugin.openapi.Intent.ACTION_REFRESH_WXAPP"/>
</intent-filter>
</receiver>
代碼:
public class AppRegister extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
final IWXAPI api = WXAPIFactory.createWXAPI(context, null);
// 將該app注冊(cè)到微信
api.registerApp(WXShare.APP_ID);
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android實(shí)現(xiàn)上拉加載更多以及下拉刷新功能(ListView)
這篇文章主要介紹了Android實(shí)現(xiàn)上拉加載更多功能以及下拉刷新功能的相關(guān)資料,需要的朋友可以參考下2016-01-01
如何給Flutter界面切換實(shí)現(xiàn)點(diǎn)特效
這篇文章主要給大家介紹了關(guān)于如何給Flutter界面切換實(shí)現(xiàn)點(diǎn)特效的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Flutter具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
Android 兩種啟動(dòng)模式的實(shí)例詳解
這篇文章主要介紹了Android 兩種啟動(dòng)模式的實(shí)例詳解的相關(guān)資料,Activity的兩種啟動(dòng)模式:FLAG_ACTIVITY_CLEAR_TOP和FLAG_ACTIVITY_REORDER_TO_FRONT ,需要的朋友可以參考下2017-08-08
Android廣播接收機(jī)制詳細(xì)介紹(附短信接收實(shí)現(xiàn))
這篇文章主要介紹了Android廣播接收機(jī)制詳細(xì)介紹(附短信接收實(shí)現(xiàn)),本文講解了BroadcastReceiver的注冊(cè)過(guò)程BroadcastReceiver的步驟,并給出一個(gè)短信廣播實(shí)現(xiàn)示例,需要的朋友可以參考下2015-06-06
android開(kāi)發(fā)環(huán)境遇到adt無(wú)法啟動(dòng)的問(wèn)題分析及解決方法
開(kāi)始研究android開(kāi)發(fā),搭建開(kāi)發(fā)環(huán)境的時(shí)候就出了問(wèn)題,真是束手無(wú)策2013-02-02
Android Button的基本用法詳解及簡(jiǎn)單實(shí)例
這篇文章主要介紹了Android Button的基本用法詳解及簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-02-02
Android 獲取手機(jī)聯(lián)系人實(shí)例代碼詳解
最近做了個(gè)項(xiàng)目,其中有項(xiàng)目需求是這樣的,需要獲取手機(jī)聯(lián)系人,下面小編把代碼分享給大家,供大家參考2015-12-12
flutter 自定義websocket路由的實(shí)現(xiàn)
這篇文章主要介紹了flutter 自定義websocket路由的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12

