【Android 分享】ShareSDK微信分享详解

目前市面上大大小小的软件,几乎都支持分享的功能,前几天在做的项目中也有此功能,使用的ShareSDK来实现的微信分享功能,下面就跟着我来一步步实现微信分享吧!

ShareSDK介绍:ShareSDK官网,Mob移动开发者服务平台,为全球移动开发者提供社会化分享SDK、手游视频录像SDK、免费手机短信验证码SDK,BigApp掌上社区等服务。

1.在ShareSDK注册个账户,进入创建应用的界面:

这里写图片描述

点击创建应用按钮

2.输入自己的应用名称,选择开发平台(以Android为例)

【Android 分享】ShareSDK微信分享详解_第1张图片

3.点击确定,进入后台管理界面,此时已经生成了该应用的App Key和App Secret,这是后面分享必须的。

【Android 分享】ShareSDK微信分享详解_第2张图片

注:此时在ShareSDK配置已经完成,下面需要到各自分享的平台去申请对应的AppId和AppSecret。

4.进入微信开放平台,点击顶部的管理中心按钮

【Android 分享】ShareSDK微信分享详解_第3张图片

5.填写应用信息

【Android 分享】ShareSDK微信分享详解_第4张图片
【Android 分享】ShareSDK微信分享详解_第5张图片

6.下一步,接着填写信息

【Android 分享】ShareSDK微信分享详解_第6张图片
【Android 分享】ShareSDK微信分享详解_第7张图片


这里详细介绍一下签名,此处填写的签名必须和应用发布时的签名保持一致才可以分享,为了保持一致,此处的签名可以这样来产生:

  • 使用命令来生成签名文件,命令如下:keytool -genkey -alias demo.keystore -keyalg RSA -validity 20000 -keystore demo.keystore,cmd命令行直接执行就可以了,至于输入的内容,记住密匙库口令,也就是密码,重复输入两次,输入的过程不会显示!

【Android 分享】ShareSDK微信分享详解_第8张图片

  • 此时在你执行命令的目录就会生成一个签名文件demo.keystore

这里写图片描述

  • 右键工程–Export
    【Android 分享】ShareSDK微信分享详解_第9张图片

  • next—找到你的签名文件—输入生成签名文件时的密码

【Android 分享】ShareSDK微信分享详解_第10张图片
【Android 分享】ShareSDK微信分享详解_第11张图片
【Android 分享】ShareSDK微信分享详解_第12张图片
【Android 分享】ShareSDK微信分享详解_第13张图片

上面这个图才是关键,看到Certificate fingerprints下有个MD5,咱们要的就是这个,记住这个,就是微信验证时输入的应用签名

【Android 分享】ShareSDK微信分享详解_第14张图片

把上面的md5那一串数字和字母输入在上图的应用签名一栏就可以了!!!


7.提交审核就Ok了,耐心等待,说是7天内,一般一两天就审核通过了!

【Android 分享】ShareSDK微信分享详解_第15张图片

8.过个一两天应用审核通过,在管理中心可以看到应用已经审核通过。
这里写图片描述

9.点击查看,可进入应用后台管理页面,可以看到,已经生成了我们分享所需要的AppId和AppSecret.

【Android 分享】ShareSDK微信分享详解_第16张图片

10.下面就是代码实现分享功能了,我们一步步来看,首先看一下工程结构图,在libs目录下导入分享所需要的jar包,在assets目录下,复制ShareSDK.xml,这是分享的配置文件,至于如何获取jar和ShareSDK.xml,请点击:Android快速集成指南。

【Android 分享】ShareSDK微信分享详解_第17张图片

11.打开ShareSDK.xml文件,输入shareSdk的APPKey,和已经在微信开放平台申请到的APPID和AppSecret。

这里写图片描述

【Android 分享】ShareSDK微信分享详解_第18张图片

12.代码实现分享功能,首先在onCreate方法中初始化ShareSDK。

@Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //初始化ShareSDK
        ShareSDK.initSDK(MainActivity.this);
        initView();
    }

13.封装分享的方法,微信支持四种分享类型,文本,图片,音乐,网页。

/**
     * 方法名称:xinWeiShare
     * 

方法描述:微信分享 * @param isWeiXin true为微信 false为微信朋友圈 * @param handler 分享界面回调 不能为空 * @param context 分享界面mContext * @param type 分享类型 如:Platform.SHARE_TEXT,Platform.SHARE_IMAGE,Platform.SHARE_MUSIC,Platform.SHARE_WEBPAGE * @param args 分享类型 如Platform.SHARE_TEXT(微信文本类型) 必须传入 两个参数(不能少传,也不能多传) :第一个为标题 * 第二个为分享内容 * * 分享类型 如Platform.SHARE_IMAGE(微信图片类型) 必须传入 两个参数(不能少传,也不能多传):第一个为标题 * 第二个为分享图片 URL地址 或者 手机文件地址 * * 分享类型 如Platform.SHARE_MUSIC(微信音乐分享) 必须传入 五个参数(不能少传,也不能多传):第一个为标题 * 第二个为分享内容 * 第三个为分享图片地址 URL地址 或者 手机文件地址 * 第四个为分享音乐地址(必须携带http:// 或者 https://) * 第五个为分享音乐详细地址(必须携带http:// 或者 https://) * * 分享类型 如Platform.SHARE_WEBPAGE(微信网页链接分享) 必须传入四个参数(不能少传,也不能多传): 第一个为标题 * 第二个为分享内容 * 第三个为分享网页图片地址 URL地址 或者 手机文件地址 * 第四个为分享网页的地址 (必须携带http:// 或者 https://) *

备注: */ public void weiXinShare(boolean isWeiXin, Handler handler, Context mContext, int type, String... args) { switch (type) { case Platform.SHARE_TEXT: if (null != handler) { this.mHandler = handler; weixinTxtShare(isWeiXin, mContext, args); } //微信文本分享 break; case Platform.SHARE_IMAGE: //微信图片分享 if (null != handler) { this.mHandler = handler; weiXinImgShare(isWeiXin, mContext, args); } break; case Platform.SHARE_MUSIC: //分享音乐 if (null != handler) { this.mHandler = handler; weixinMusicShare(isWeiXin, mContext, args); } break; case Platform.SHARE_WEBPAGE: //分享网页 if (null != handler) { this.mHandler = handler; weiXinWebShare(isWeiXin, mContext, args); } break; default: break; } }

14.此处测试的是分享网页,分享网页的方法如下:

/**
     * 方法名称:xinweiWebShare
     * 

方法描述:网页分享 *

备注: */ private void weiXinWebShare(boolean isWeixin, Context mContext, String... args) { if (null == mContext || args.length < SHARE_WEB_MIN_LEN) { MainApplication.getIns().tip("分享失败"); return; } else { this.context = mContext; for (int i = 0; i < args.length; i++) { String str = args[i]; if (TextUtils.isEmpty(str) && i != 2) { MainApplication.getIns().tip("分享失败"); return; } } String title = args[0]; String text = args[1]; String image = args[2]; String url = args[3]; WechatHelper.ShareParams sp = null; if (isWeixin) { sp = new Wechat.ShareParams(); } else { sp = new WechatMoments.ShareParams(); } sp.title = title; if (TextUtils.isEmpty(image)) { sp.imageData = ((BitmapDrawable)context.getResources().getDrawable(R.drawable.logo_mingdao)).getBitmap(); } else if (image.contains("http://") || image.contains("https://")) { sp.imageUrl = image; } sp.text = text; if (url.contains("http://") || url.contains("https://")) { sp.url = url; } sp.setShareType(Platform.SHARE_WEBPAGE); Platform plat = null; if (isWeixin) { plat = ShareSDK.getPlatform(Wechat.NAME); } else { plat = ShareSDK.getPlatform(WechatMoments.NAME); } plat.setPlatformActionListener(listener); plat.share(sp); } }

15.具体的分享调用

/**
     * 方法名称:weixinShare
     * 方法描述:微信分享
     */
    private void weixinShare()
    {
        String shareContentTxt = "我是来自Android客户端分享实例Demo的数据";
        String sharklink = "http://user.qzone.qq.com/1039163285/infocenter?ptsig=*Sb6sER-9smBstwyL28cYg2h0D99pYGcPvoySuzkGyc_";
        ShareUtil.getInstance().weiXinShare(true, mHandler, this, Platform.SHARE_WEBPAGE, "Note客户端分享", shareContentTxt, "", sharklink);
    }

    /**
     * 方法名称:weixinQuanShare
     * 方法描述:微信朋友圈分享
     */
    private void weixinQuanShare()
    {
        String shareContentTxt = "我是来自Android客户端分享实例Demo的数据,如果您看到此条数据,可以选择忽略它!";
        String sharklink = "http://user.qzone.qq.com/1039163285/infocenter?ptsig=*Sb6sER-9smBstwyL28cYg2h0D99pYGcPvoySuzkGyc_";
        ShareUtil.getInstance().weiXinShare(false, mHandler, this, Platform.SHARE_WEBPAGE, shareContentTxt, "Note客户端分享", "", sharklink);
    }

16.分享完成,测试

【Android 分享】ShareSDK微信分享详解_第19张图片

分享成功

【Android 分享】ShareSDK微信分享详解_第20张图片




Android技术交流群,群号为204368065,欢迎各位Androider加入,共同探讨技术问题,共同进步,也可以扫码申请接入哦

【Android 分享】ShareSDK微信分享详解_第21张图片

你可能感兴趣的:(android开发进阶)