前言



  现在几乎所有的app都带有分享功能,第一为了更好地推广自己的产品,第二作为使用者也能及时的把自己觉得好的文章,话题,app分享到社交平台供大家一起学习和使用。开发中虽然android系统自带分享功能,可以直接调用。但是系统的功能和平台往往不是很符合客户需求和人性化设计。所以很多第三方分享平台应运而生。今天重点学习一下友盟的社会化组件分享功能的实现。



 



声明



  欢迎转载,但请保留文章原始出处:) 



    博客园:



 



正文



  一、实现目标 



    1.1  社会化组件--分享内容到各大社交平台

 

 

  二、具体步骤

    

          1、获取友盟appkey

      去友盟官网http://www.umeng.com注册开发者账号
如果你之前已经在友盟注册了应用,并获取到了Appkey,可以继续使用它.
如果你尚未在友盟注册开发者账号,需要先注册,注册之后登录你的账号,点击**添加新应用**,填写完应用基本信息后,将进入"下载SDK并添加代码"页面,此页面即可得到Appkey。

          2、下载并安装sdk

     下载最新版本sdk(友盟提供很多社交平台的分享集成,下载的时候只需勾选自己需要的社交平台)
添加代码和资源引用,友盟提供了添加资源文件和jar文件的两种方式,可以根据需求选择

  方法一:

       解压SDK压缩包,将文件夹中的'main/libs'和'main/res'文件夹复制到你的项目工程根目录下(如使用'ADT 17'以下用户需要手动添加'libs'下的jar文件到工程Path中)
注意:
    1:QQ和QQ Zone SSO(免登录)引用的jar文件相同。当需要同时支持QQ和QQ Zone的时候,只需添加一次SocialSDK_QQZone_1.jar,SocialSDK_QQZone_2.jar,SocialSDK_QQZone_3.jar文件即可.
    2:由于我们对微信的包名做了修改(libammsdk.jar -> SocialSDK_WeiXin.jar),如出现"Unable to execute dex: Multiple dex files define "问题,请删除libammsdk.jar或者SocialSDK_WeiXin.jar中的一个即可解决问题。

  

   方法二:

     解压SDK压缩包,将文件夹中的social_sdk_library_project文件夹导入Eclipse,并在您的工程中添加对此项目的引用即可。

注意:

    social_sdk_library_project文件夹下包含所有平台jar包资源只添加自己需要的平台jar包,多余的删除

 

         3、Manifest配置,添加友盟Appkey/Activity/权限



<!-- #######注册SDK使用的Activity######### -->
        <!--分享编辑页-->
        <activity
          android:name="com.umeng.socialize.view.ShareActivity"
            android:configChanges="orientation|keyboard"
            android:launchMode="singleTask"
            android:noHistory="true"
            android:theme="@style/Theme.UMDialog"       
            android:windowSoftInputMode="stateVisible|adjustResize" >
        </activity>

        <!-- ####QQ空间和QQ SSO授权的Activity注册 ##### -->
        <activity android:name="com.tencent.tauth.AuthActivity" />

               <!-- 友盟AppKey, 需要替换成你自己的 -->
        <meta-data
            android:name="UMENG_APPKEY"
            android:value="566fb983e0f55a12cd001b84" >
        </meta-data>


<!--####################友盟分享的相关权限 ##################-->
    <!-- 检测网络状态 -->
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />  
    <!-- 获取mac地址作为用户的备用唯一标识 -->
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />     
    <!-- 获取用户手机的IMEI,用来唯一的标识用户 -->
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />      
    <!-- 缓存资源优先存入SDcard -->
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <!-- 允许应用程序联网,以便向我们的服务器端发送数据 -->
<uses-permission android:name="android.permission.INTERNET" />



        4、编辑分享代码

     首先要在各分享平台注册开发者账号,添加你的应用获得相应的appId和appSecret
然后替换到平台配置中
新浪微博需要在新浪微博开放平台申请应用,并且填写应用签名与包名审核通过,将申请获取的appkey及secret绑定在友盟主站后台。
(在友盟主站找到我的应用--组件--社会化分享--设置--社交平台配置)
下面是写好的一个友盟分享工具类
使用时直接调用



ShareUtils.shareUmeng(ct, shareTitle, summary, msgSinaContent, imageUrl, shareUrl);
// 是否只有已登录用户才能打开分享选择页
ShareUtils.mController.openShare(NewsDetailActivity.this, false);



  /**
     * 友盟分享工具类
     * shareUmeng 
     * /
  public class ShareUtils {
    // 友盟分享平台的Controller,负责管理整个SDK的配置、操作等处理
    public final UMSocialService mController = UMServiceFactory
                    .getUMSocialService("com.umeng.share");    
    /**
     * 友盟分享
     * shareUmeng 
     * 
     * @param context
     * @param msgTitle
     * @param msgText
     * @param imgPath   
     * void
     */
    public static void shareUmeng(Context context, String msgTitle, String msgContent, String msgSinaContent,  String imgPath, String msgUrl){
        // 配置需要分享的相关平台
        configPlatforms(context);
        // 设置分享的内容
        setShareContent(context, msgTitle, msgContent, msgSinaContent, imgPath, msgUrl);
        
    }
    
    /**
     * 根据不同的平台设置不同的分享内容</br>
     * @param context 
     * @param imgPath 
     * @param msgText 
     * @param msgTitle 
     * @param msgUrl 
     */
    private static void setShareContent(Context context, String msgTitle, String msgContent, String msgSinaContent, String imgPath, String msgUrl) {
        LogUtil.i("Share="+msgContent+imgPath+msgUrl);
        // 配置SSO
        mController.getConfig().setSsoHandler(new SinaSsoHandler());
        //微信
         WeiXinShareContent weixinContent = new WeiXinShareContent();
         // 设置朋友圈分享的内容
         CircleShareContent circleMedia = new CircleShareContent();
         //新浪
         SinaShareContent sinaContent = new SinaShareContent();
        //本地图片
//      UMImage localImage = new UMImage(context, R.drawable.ic_about_app);
        //url
        UMImage urlImage = new UMImage(context, imgPath);
        // 设置分享图片,参数2为本地图片的路径(绝对路径)
//      UMImage urlImage = new UMImage(context, BitmapFactory.decodeFile(imgPath));
         weixinContent.setShareImage(urlImage);
         circleMedia.setShareImage(urlImage);
         sinaContent.setShareImage(urlImage);
        //添加微信分享内容
        weixinContent.setShareContent(msgContent);//分享内容摘要
        weixinContent.setTitle(msgTitle);          //标题
        weixinContent.setTargetUrl(msgUrl);       //url
        mController.setShareMedia(weixinContent);
        //添加朋友圈分享内容
        circleMedia.setShareContent(msgContent);
        circleMedia.setTitle(msgTitle);
        circleMedia.setTargetUrl(msgUrl);
        mController.setShareMedia(circleMedia);
        //添加新浪分析内容
        sinaContent.setShareContent(msgSinaContent);
        sinaContent.setTitle(msgTitle);
        sinaContent.setTargetUrl(msgUrl);
        mController.setShareMedia(sinaContent);
    }
    
    /**
     * 配置分享平台参数</br>
     * @param context 
     */
    private static void configPlatforms(Context context) {
        // 添加新浪SSO授权
        mController.getConfig().setSsoHandler(new SinaSsoHandler());
        // 添加微信、微信朋友圈平台
        addWXPlatform(context);
// 打开分享选择页并设置分享平台顺序
        mController.getConfig().setPlatforms(SHARE_MEDIA.WEIXIN, SHARE_MEDIA.WEIXIN_CIRCLE, SHARE_MEDIA.SINA);
    }
    
    /**
    * @param context 
     * @功能描述 : 添加微信平台分享
    * @return
    */
   private static void addWXPlatform(Context context) {
       // 注意:在微信授权的时候,必须传递appSecret
       // wx967daebe835fbeac是你在微信开发平台注册应用的AppID, 这里需要替换成你注册的AppID
       String appId = "xxxxxxxxxxxxxxx";//这个填写通过的审核的APPID
       String appSecret = "xxxxxxxxxxxxxxxxxxxxxxx";
       // 添加微信平台
       UMWXHandler wxHandler = new UMWXHandler(context, appId, appSecret);
       wxHandler.addToSocialSDK();
       // 支持微信朋友圈
       UMWXHandler wxCircleHandler = new UMWXHandler(context, appId, appSecret);
       wxCircleHandler.setToCircle(true);
       wxCircleHandler.addToSocialSDK();
   }
}



在对应的activity中实现onActivityResult方法
/**
     * 如果有使用任一平台的SSO授权, 则必须在对应的activity中实现onActivityResult方法, 并添加如下代码
     */
@Override 
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        /**使用SSO授权必须添加如下代码 */
        UMSsoHandler ssoHandler = ShareUtils.mController.getConfig().getSsoHandler(requestCode) ;
        if(ssoHandler != null){
           ssoHandler.authorizeCallBack(requestCode, resultCode, data);
        }
    }
注意onActivityResult方法必须写在分享所在的Activity或fragment依赖的Activity中,不可以直接写在fragment中



      5、混淆

为了保证引用友盟Social SDK jar文件以及腾讯jar文件被混淆,请在proguard.cfg文件中添加以下代码避免被混淆.



-dontshrink
-dontoptimize
-dontwarn com.google.android.maps.**
-dontwarn android.webkit.WebView
-dontwarn com.umeng.**
-dontwarn com.tencent.weibo.sdk.**
-dontwarn com.facebook.**


-keep enum com.facebook.**
-keepattributes Exceptions,InnerClasses,Signature
-keepattributes *Annotation*
-keepattributes SourceFile,LineNumberTable

-keep public interface com.facebook.**
-keep public interface com.tencent.**
-keep public interface com.umeng.socialize.**
-keep public interface com.umeng.socialize.sensor.**
-keep public interface com.umeng.scrshot.**

-keep public class com.umeng.socialize.* {*;}
-keep public class javax.**
-keep public class android.webkit.**

-keep class com.facebook.**
-keep class com.facebook.** { *; }
-keep class com.umeng.scrshot.**
-keep public class com.tencent.** {*;}
-keep class com.umeng.socialize.sensor.**
-keep class com.umeng.socialize.handler.**
-keep class com.umeng.socialize.handler.*
-keep class com.tencent.mm.sdk.modelmsg.WXMediaMessage {*;}
-keep class com.tencent.mm.sdk.modelmsg.** implements com.tencent.mm.sdk.modelmsg.WXMediaMessage$IMediaObject {*;}

-keep class im.yixin.sdk.api.YXMessage {*;}
-keep class im.yixin.sdk.api.** implements im.yixin.sdk.api.YXMessage$YXMessageData{*;}

-dontwarn twitter4j.**
-keep class twitter4j.** { *; }

-keep class com.tencent.** {*;}
-dontwarn com.tencent.**
-keep public class com.umeng.soexample.R$*{
    public static final int *;
}
-keep public class com.umeng.soexample.R$*{
    public static final int *;
}
-keep class com.tencent.open.TDialog$*
-keep class com.tencent.open.TDialog$* {*;}
-keep class com.tencent.open.PKDialog
-keep class com.tencent.open.PKDialog {*;}
-keep class com.tencent.open.PKDialog$*
-keep class com.tencent.open.PKDialog$* {*;}

-keep class com.sina.** {*;}
-dontwarn com.sina.**
-keep class  com.alipay.share.sdk.** {
   *;
}
-keepnames class * implements android.os.Parcelable {
    public static final ** CREATOR;
}



         6、更多详细文档参考友盟文档中心http://dev.umeng.com/social/android/operation

         7、在程序入口加入**com.umeng.socialize.utils.Log.LOG = true**,可在LogCat中观察友盟日志

         8、常用开放平台
    微信开放平台:https://open.weixin.qq.com/
    新浪开放平台:http://open.weibo.com/
    腾讯开放平台:http://open.qq.com/

        9、//设置打印友盟log日志
    com.umeng.socialize.utils.Log.LOG = true;
     //关闭友盟toast提示
    mController.getConfig().closeToast();

结束

        按照sdk的demo进行集成后,碰到几个大坑。现在总结下这些坑同时给出我的解决方法。
       1、点击qq或空间分享,出现应用无响应(ANR)的情况。
 解决方法:查查是否分享的图片参数是否已经设置,没有设置会出现ANR,设置后可以正常分享。title、url、    content等参数尽量都设置一下,以防出现其他莫名奇妙问题
       2、微信分享不成功。现象是点击微信或朋友圈分享后,出现微信的界面,提示请稍候,然后一闪而过消失。查看logcat出现错误:
## get sso Handler, requestCode = 10086, 微信访问被拒绝(未知错误)-----------微信分享
## get sso Handler, requestCode = 10085, 微信访问被拒绝(未知错误)-----------微信朋友圈分享
解决方法:
这个看看应用md5签名和在微信开放平台上登记的md5签名是否一致。值得注意的是在开放平台上录入的md5签名必须没有冒号,同时应该全部是小写字母。请特别注意。如果是一致的话,还是不行的话,清空下微信缓存,再不行,重新安装应用或换手机测试。

       3、新浪微博分享,web页面显示:你所访问的站点在微博的认证失败,请稍后再试。如有疑问,请联系XX。(error:redirect_uri_mismatch) 。这种问题往往发生在新提交了移动应用但未审核的情况下。
解决方法:需要在微博开放平台的应用基本信息中配置安全域名:sns.whalecloud.com。同时在高级信息中配置OAuth2.0 授权设置:
授权回调页:
http://sns.whalecloud.com/sina2/callback取消授权回调页:
http://sns.whalecloud.com/sina2/callback

      4、新浪微博开始分享后不久出现分享失败的错误,查看Logcat出现错误:sina : error,
  User is not in platform app test list
解决办法:从日志错误来看,是提示用来分享的用户不在平台应用的测试账号列表中。这一般发生在未审核应用中。可以在应用的测试信息中添加测试账号来测试分享。
      5、新浪微博分享,在安装微博客户端的时候,分享时总是提示“sso package or sign error”,而在未安装微博客户端的时候,在web auth授权页面又总是提示来自“来自友盟社会化组件”,而不是显示来自"XXX应用"。
解决办法:
1、检查应用包名和md5签名是否在新浪开放平台填写正确。
2、检查授权回调页是否填写正确
3、检查应用是否审核成功
4、检查友盟的分享设置页面,新浪微博分配的appkey和appsecret是否填写正确并正确绑定。
5、如果以上四个步骤都检查无误,但是还是出现来源错误的话检查Androidmanifest.xml中UMENG_APPKEY是否填写正确。