如今的app中,几乎都包含了分享这个功能,十分的常用,如
我们经常使用的网易云音乐
一般我们都会采用市面上用的最广泛的ShareSDK
来完成类似的功能.
www.mob.com
注册获取App Key
和App Secret
如果没有ShareSDK账号的话,需要先注册一个.进入后台,并创建应用
进入到后台后,我们就可以创建自己的应用,并拿到App Key
和App Secret
,应用名称可以随意,后面可以更改
SDK下载
导入SDK
在刚才下载的SDK中,会有一个快速集成程序,QuickIntegrater.jar
,按照相应操作,即可生成相关集成所需文件
点击确定后,会生成一个Sample
目录.将目录中的文件拷贝到项目中,在Android Studio中我们可以选中我们的module,并新建一个assets目录.将ShareSDK.xml
拷贝到目录下
配置SDK’
setPlatformDevInfo(String, HashMap<String, Object>)
HashMap<String,Object> hashMap = new HashMap<String, Object>();
hashMap.put("Id","1");
hashMap.put("SortId","1");
hashMap.put("AppKey","568898243");
hashMap.put("AppSecret","38a4f8204cc784f81f9f0daaf31e02e3");
hashMap.put("RedirectUrl","http://www.sharesdk.cn");
hashMap.put("ShareByAppClient","true");
hashMap.put("Enable","true");
ShareSDK.setPlatformDevInfo(SinaWeibo.NAME,hashMap);
使用此方法需要调用ShareSDK.init(context,你的应用在sharesdk注册时返回的AppKey)方法进行初始化。
此种方法比较复杂,不推荐!
uses-permission
权限配置
<uses-permission android:name="android.permission.GET_TASKS" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.MANAGE_ACCOUNTS"/>
<uses-permission android:name="android.permission.GET_ACCOUNTS"/>
<!-- 蓝牙分享所需的权限 -->
<uses-permission android:name="android.permission.BLUETOOTH" />
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
Activity
及回调配置
<activity android:name="com.mob.tools.MobUIShell" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:configChanges="keyboardHidden|orientation|screenSize" android:screenOrientation="portrait" android:windowSoftInputMode="stateHidden|adjustResize" >
<!-- 调用新浪原生SDK,需要注册的回调activity -->
<intent-filter>
<action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
<!-- 如果集成QQ分享,或者使用QQ客户端来进行QQ空间的分享,须要在此处添加一个对ACTION_VIEW 事件的过滤器,其中的scheme是“tencent”前缀再开发者应用的加上appId。如果此过滤器不设置, 则分享结束以后不能得到正确的回调 -->
<intent-filter android:priority="1000" >
<data android:scheme="tencent100371282" />
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
</intent-filter>
</activity>
<!--微信分享回调 -->
<activity android:name=".wxapi.WXEntryActivity" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:configChanges="keyboardHidden|orientation|screenSize" android:exported="true" android:screenOrientation="portrait" />
注意: MobUIShell的路径是固定的,一定要在cn.sharesdk.framework
下,因为它在Share-Core
中。
<data android:scheme="tencent100371282" />//中的数字改成在腾讯开放平台申请到的AppId
SDK集成后,我们需要来测试一下,看看是否能够成功分享.
1. 打开您项目的入口Activity
,在其onCreate
中插入下面的代码:
//使用ShareSDK.xml方式配置
ShareSDK.initSDK(this);
// 使用代码或者应用后台配置
ShareSDK.initSDK(this,”androidv1101″);
//androidv1101:是你的应用在ShareSDK注册应用信息时返回的AppKey
如果不在所有的ShareSDK的操作之前调用这行代码,就会抛出空指针异常
2. 在项目出口Activity
的onDestroy
方法中第一行插入下面的代码
ShareSDK.stopSDK(this);
//结束ShareSDK的统计功能并释放资源
3. 调用分享,参考官网
private void showShare() {
ShareSDK.initSDK(this);
OnekeyShare oks = new OnekeyShare();
//关闭sso授权
oks.disableSSOWhenAuthorize();
// 分享时Notification的图标和文字 2.5.9以后的版本不调用此方法
//oks.setNotification(R.drawable.ic_launcher, getString(R.string.app_name));
// title标题,印象笔记、邮箱、信息、微信、人人网和QQ空间使用
oks.setTitle(getString(R.string.share));
// titleUrl是标题的网络链接,仅在人人网和QQ空间使用
oks.setTitleUrl("http://sharesdk.cn");
// text是分享文本,所有平台都需要这个字段
oks.setText("我是分享文本");
// imagePath是图片的本地路径,Linked-In以外的平台都支持此参数
oks.setImagePath("/sdcard/test.jpg");//确保SDcard下面存在此张图片
// url仅在微信(包括好友和朋友圈)中使用
oks.setUrl("http://sharesdk.cn");
// comment是我对这条分享的评论,仅在人人网和QQ空间使用
oks.setComment("我是测试评论文本");
// site是分享此内容的网站名称,仅在QQ空间使用
oks.setSite(getString(R.string.app_name));
// siteUrl是分享此内容的网站地址,仅在QQ空间使用
oks.setSiteUrl("http://sharesdk.cn");
// 启动分享GUI
oks.show(this);
}
<SinaWeibo
AppKey="858316951"
AppSecret="52685221be9572d0fb99e35a7ba25364"
Enable="true"
Id="1"
// 此处配置需要和新浪开放平台设置一致
RedirectUrl="http://www.baidu.com"
// true,调用新浪微博app,如果没有安装,可能分享失败
// false,调用网页版分享.
ShareByAppClient="true"
SortId="1"/>
分享回调
OnekeyShare oks = new OnekeyShare();
oks.setCallback(PlatformActionListener listener);
// 分享成功的回调
public void onComplete(Platform platform, int i, HashMap<String, Object> hashMap){}
// 分享失败的回调
public void onError(Platform platform, int i, Throwable throwable){}
// 取消分享的回调
public void onCancel(Platform platform, int i) {}
// 可以设置listener来对分享进行监听,以进行后续操作.
新浪微博error:redirect_uri_mismatch
的解决方法:
到新浪微博注册应用的地方填上回调地址,然后将代码中的回调地址修改成和新浪微博开放平台里一样即可
参考:在Android Studio中使用shareSDK进行社会化分享(图文教程)
【ShareSDK For Android】微信分享(对比及配置)