最近项目中要接入微信分享,记录下接入流程

注册应用信息并下载必要工具
注意:由于一般调试签名和正式签名不一致,测试时可填入测试包的签名,上线时需要改为正式包的签名
接入
在build.gradle中,添加如下依赖:
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+'
}
或:
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:+'
}
其中,前者包含统计功能
AndroidManifest.xml中添加权限和微信回调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"/>
这里使用了一个透明的Activity来处理微信分享结果回调
主题:
<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
当微信分享成功,点击返回App时,微信会主动调用WXEntryActivity,并将结果通过Intent传给WXEntryActivity,此时调用api.handleIntent(getIntent(), this)对结果进行处理,handleIntent第二个参数为IWXAPIEventHandler,分享结果会在onResp方法中处理,在这里我们发送一个广播,并在WXShare对象中对该广播进行监听
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();
//注意:
//第三方开发者如果使用透明界面来实现WXEntryActivity,需要判断handleIntent的返回值,如果返回值为false,则说明入参不合法未被SDK处理,应finish当前透明界面,避免外部通过传递非法参数的Intent导致停留在透明界面,引起用户的疑惑
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 = "发送被拒绝";
break;
case BaseResp.ErrCode.ERR_UNSUPPORT:
result = "不支持错误";
break;
default:
result = "发送返回";
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();
}
启动分享
wxShare.share("这是要分享的文字");
到这里微信分享就完成啦!
另外,在微信官方例程中,有个定时刷新应用注册信息的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注册到微信
api.registerApp(WXShare.APP_ID);
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关文章:
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何快速生成橙子建站落地页链接?
成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?
动图在线制作网站有哪些,滑动动图图集怎么做?
如何在云虚拟主机上快速搭建个人网站?
制作国外网站的软件,国外有哪些比较优质的网站推荐?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
建站之星后台搭建步骤解析:模板选择与产品管理实操指南
常州自助建站工具推荐:低成本搭建与模板选择技巧
高性能网站服务器部署指南:稳定运行与安全配置优化方案
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
如何制作算命网站,怎么注册算命网站?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
高端企业智能建站程序:SEO优化与响应式模板定制开发
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
网站制作企业,网站的banner和导航栏是指什么?
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
C++中引用和指针有什么区别?(代码说明)
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站之星价格显示格式升级,你的预算足够吗?
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
如何安全更换建站之星模板并保留数据?
香港服务器租用每月最低只需15元?
如何用美橙互联一键搭建多站合一网站?
如何在Windows 2008云服务器安全搭建网站?
企业微网站怎么做,公司网站和公众号有什么区别?
如何破解联通资金短缺导致的基站建设难题?
网站网页制作专业公司,怎样制作自己的网页?
建设网站制作价格,怎样建立自己的公司网站?
香港服务器选型指南:免备案配置与高效建站方案解析
如何有效防御Web建站篡改攻击?
如何彻底卸载建站之星软件?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
如何通过网站建站时间优化SEO与用户体验?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
如何通过山东自助建站平台快速注册域名?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
建站之星各版本价格是多少?
定制建站流程步骤详解:一站式方案设计与开发指南
制作农业网站的软件,比较好的农业网站推荐一下?
深入理解Android中的xmlns:tools属性
已有域名和空间如何搭建网站?
建站之星如何快速生成多端适配网站?
建站之星伪静态规则如何正确配置?
网站制作软件有哪些,制图软件有哪些?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
如何自定义建站之星模板颜色并下载新样式?
*请认真填写需求信息,我们会在24小时内与您取得联系。