Android社会化分享详解~

简介: 前言  现如今app市场竞争激烈,做app不会放过任何推广自己的app的渠道,如果app中没有社会化分享功能,那真的是OUT了,我们先来看下一些app中的分享界面功能吧。 现在主流的分享平台,一般用的都是微信、QQ、微博,国外的话就Fb、Twitter等,如果每一个都要去单独加,对我们来说是耗时耗力,最重要的是每个第三方的SDK都很大,会增大很多包的体积,这个是我们最不想看到的;   现在市面上提供了很多SDK,从集成速度,包的体积,平台多样,服务响应,用户基数上来讲,ShareSDK是个不错的选择,最重要的是,现在上了maven的集成方式,集成超快。

前言
  现如今app市场竞争激烈,做app不会放过任何推广自己的app的渠道,如果app中没有社会化分享功能,那真的是OUT了,我们先来看下一些app中的分享界面功能吧。
Android1

   现在主流的分享平台,一般用的都是微信、QQ、微博,国外的话就Fb、Twitter等,如果每一个都要去单独加,对我们来说是耗时耗力,最重要的是每个第三方的SDK都很大,会增大很多包的体积,这个是我们最不想看到的;

  现在市面上提供了很多SDK,从集成速度,包的体积,平台多样,服务响应,用户基数上来讲,ShareSDK是个不错的选择,最重要的是,现在上了maven的集成方式,集成超快。
简单的准备工作
  下面我们看看我们需要做的准备工作,首先先确定我们想要分享的第三方平台,这里面我们就以国内主流的平台举例,微信、QQ、微博;首先我们必须去其第三方平台去申请应用得到对应的appid等信息,第三方给了appid,我们才可以去做分享;
话不多说上网站:
QQ:http://open.qq.com QQ与QZone共用一套key即可
微信:http://open.weixin.qq.com 微信好友,微信朋友圈,微信收藏共用一套key即可
微博:http://open.weibo.com
  哦对了,ShareSDK有提供一些常见平台的申请步骤,点击这里去围观能帮助我们快速的进行注册;
ShareSDK集成步骤
第一步,注册账号申请ShareSDK应用
  ShareSDK的AppKey直接到Mob官网申请即可,具体的注册应用的流程请参考这里:Mob创建应用流程
  拿到appkey与appsecret了我们去看看文档吧,http://wiki.mob.com/进入ShareSDK快速集成文档猛戳这里,这个时候有人会问,问什么不下载SDK,直接开始看文档集成了呢,因为ShareSDK 提供了Gradle的maven集成方式,无需手动下载,无需手动配置资源,权限;是不是听起来很牛B,忍不住去看看;
第二步,sharesdk的maven集成
  首先、如下图所示,需要在build.gradle中配置

 maven {
    url "http://mvn.mob.com/android"
    }
    dependencies {
    classpath 'com.mob.sdk:MobSDK:+'
    }

添加的位置按照截图上面的配置即可;
Android2
  其次,在使用到Mob产品的module下面的build.gradle文件里面添加引用

applyplugin:'com.mob.sdk'

  maven集成方式可以在Mob产品的module下面的build.gradle文件里面配置ShareSDK各个社交平台的key信息

 MobSDK {

   appKey "d580ad56b4b5"
   appSecret "7fcae59a62342e7e2759e9e397c82bdd"

   ShareSDK {
        gui true //调用ShareSDK默认的界面
       //平台配置信息
       devInfo {
           SinaWeibo {
              appKey "568898243"
              appSecret "38a4f8204cc784f81f9f0daaf31e02e3"
              callbackUri "http://www.sharesdk.cn"//回调地址,需要与微博后台配置的回调地址一致,http://bbs.mob.com/forum.php?mod=viewthread&tid=47
              shareByAppClient true
           }

           Wechat {
               appId "wxdb0f7a71c883b423"
               appSecret "64020361b8ec4c99936c0e3999a9f249"//登录需要配置appsecret 分享不需要配置
           }

           WechatMoments{
               appId "wxdb0f7a71c883b423"
               appSecret "64020361b8ec4c99936c0e3999a9f249"//登录需要配置appsecret 分享不需要配置
               bypassApproval false

           }

           QQ {
               appId "100371282"
               appKey "aed9b0303e3ed1e27bae87c33761161d"
               shareByAppClient true
           }

           QZone {
               appId "100371282"
               appKey "aed9b0303e3ed1e27bae87c33761161d"
               bypassApproval false
           }
       }
   }
}

配置第三方key的字段说明可以点击这里看文档即可;
Android3

  如上图所示配置完之后点击Sync Now进行重新编译,到这里我们就集成完成了,下面我们调用代码即可;
  注意事项:如果您没有在AndroidManifest中设置appliaction的类名,MobSDK会将这个设置为com.mob.MobApplication,但如果您设置了,请在您自己的Application类中调用:
MobSDK.init(this);

并且在Manifest清单文件中配置:tools:replace=”android:name”,如下所示:

<application
   android:name = ".MyApplication"
   tools:replace="android:name">

第三步,代码调用
 下面的代码就是onekeyshare的分享,即ShareSDK下面配置的gui true才可以调用,下面的代码复制到您的工程中,在需要分享的地方调用即可;

private void showShare(String platformToShare) {
        OnekeyShare oks = new OnekeyShare();
        //关闭sso授权
        oks.disableSSOWhenAuthorize();
        if (platformToShare != null) {
            oks.setPlatform(platformToShare);
        }
        // title标题,微信、QQ和QQ空间等平台使用
        oks.setTitle("测试标题");
        // titleUrl QQ和QQ空间跳转链接
        oks.setTitleUrl("http://www.baidu.com");
        // text是分享文本,所有平台都需要这个字段
        oks.setText("我是分享文本");
        //分享网络图片、分享本地图片用oks.setImagePath("/sdcard/test.jpg");确保SDcard下面存在此张图片
        oks.setImageUrl("https://lanre.smartemple.cn/image/share.png");
        // url在微信、微博,Facebook等平台中使用
        oks.setUrl("http://sharesdk.cn");
        // comment是我对这条分享的评论,仅在人人网使用
        oks.setComment("我是测试评论文本");/*      //onekeyshare默认提供了默认的分享回调Toast提示,如果想要自己定义调用setCallback即可,不需要自定义的可以忽略,值得一提的是callback回调是子线程,需要传到主线程之后去操作后续内容哦;    
        oks.setCallback(new PlatformActionListener() {      
            @Override
            public void onError(Platform arg0, int arg1, Throwable arg2) {
                // TODO Auto-generated method stub              
            }           
            @Override
            public void onComplete(Platform arg0, int arg1, HashMap<String, Object> arg2) {
                // TODO Auto-generated method stub          
            }
            
            @Override
            public void onCancel(Platform arg0, int arg1) {
                // TODO Auto-generated method stub              
            }
        });*/
        // 启动分享GUI
        oks.show(this);
    }

  值得一提的是,onekeyshare的分享是根据调用的分享的方法自动适配分享类型,每个平台分享的方法不同,具体可以点击这里去看ShareSDK的文档说明

   下面我们就可以去测试了,在监听按钮下调用
showShare(null);

效果如下:

Android4
此时点击平台跳转分享即可;

   如果不想用OneKeyShare的界面很简单,很多小伙伴肯定也发现了刚才我的方法中private void showShare(String platformToShare) 有一个参数,如果想单独调用修改这个参数即可,比如,我想单独跳转QQ,则在这个方法里面传QQ.NAME即可,其他的平台名称看ShareSDK的快速集成文档即可,效果如下

Android5
Demo下载地址:链接:https://pan.baidu.com/s/1nxh2Bqh 密码:j4c3
常见问题说明:
1、微信分享提示分享失败:检查分享内容,特别是图片是否有效,或者只分享文字测试
2、微信分享闪一下调用不起来微信客户端:检查微信后台配置的包名是否与配置的applicationId一致;检查微信后台配置的应用签名是否与您的app的应用签名一致;
3、新浪微博客户端分享提示分享成功,但是会保存到草稿箱发送不出去,检查微博后台配置的包名和签名,与您的app的不一致导致的
4、QQ分享不需要审核通过即可分享,but,需要配置一些基本的信息,IOS与android平台可以共用一套key,但是别忘了两个平台的基本信息都要配置下;
5、微信是通过审核之后才会给我们appid的,所以必须要通过审核才可以正式分享,并且必须保证微信后台配置的包名和应用签名与我们的app的包名和应用签名一致,否则无法正分享,做微信第三方登录的小伙伴,别忘了去申请权限还要每年300块哦;
6、新浪微博、申请的时候就会给我们appkey和appsecret了,但是别忘了配置回调地址,不知道回调地址怎么配置都可以点击这里进行查看,新浪微博和微信一样都需要配置包名和应用签名,这一点需要注意,如果包名和签名不一致客户端分享会报错的哦;

目录
相关文章
|
Android开发
Android开发之社会化分享功能集成
现在越来越多的应用都集成了社交分享功能,国内用的比较多的就是 友盟和Mob 分享,今天以Mob分享为例,来完整介绍一个集成的案例。 1. 获取ShareSDK的AppKey,去官方添加一个Project就得到了 2.
1085 0
|
29天前
|
缓存 搜索推荐 Android开发
安卓开发中的自定义控件实践
【10月更文挑战第4天】在安卓开发的海洋中,自定义控件是那片璀璨的星辰。它不仅让应用界面设计变得丰富多彩,还提升了用户体验。本文将带你探索自定义控件的核心概念、实现过程以及优化技巧,让你的应用在众多竞争者中脱颖而出。
|
6天前
|
编解码 Java Android开发
通义灵码:在安卓开发中提升工作效率的真实应用案例
本文介绍了通义灵码在安卓开发中的应用。作为一名97年的聋人开发者,我在2024年Google Gemma竞赛中获得了冠军,拿下了很多项目竞赛奖励,通义灵码成为我的得力助手。文章详细展示了如何安装通义灵码插件,并通过多个实例说明其在适配国际语言、多种分辨率、业务逻辑开发和编程语言转换等方面的应用,显著提高了开发效率和准确性。
|
5天前
|
Android开发 开发者 UED
安卓开发中自定义View的实现与性能优化
【10月更文挑战第28天】在安卓开发领域,自定义View是提升应用界面独特性和用户体验的重要手段。本文将深入探讨如何高效地创建和管理自定义View,以及如何通过代码和性能调优来确保流畅的交互体验。我们将一起学习自定义View的生命周期、绘图基础和事件处理,进而探索内存和布局优化技巧,最终实现既美观又高效的安卓界面。
18 5
|
3天前
|
JSON Java Android开发
探索安卓开发之旅:打造你的第一个天气应用
【10月更文挑战第30天】在这个数字时代,掌握移动应用开发技能无疑是进入IT行业的敲门砖。本文将引导你开启安卓开发的奇妙之旅,通过构建一个简易的天气应用来实践你的编程技能。无论你是初学者还是有一定经验的开发者,这篇文章都将成为你宝贵的学习资源。我们将一步步地深入到安卓开发的世界中,从搭建开发环境到实现核心功能,每个环节都充满了发现和创造的乐趣。让我们开始吧,一起在代码的海洋中航行!
|
5天前
|
缓存 数据库 Android开发
安卓开发中的性能优化技巧
【10月更文挑战第29天】在移动应用的海洋中,性能是船只能否破浪前行的关键。本文将深入探讨安卓开发中的性能优化策略,从代码层面到系统层面,揭示如何让应用运行得更快、更流畅。我们将以实际案例和最佳实践为灯塔,引领开发者避开性能瓶颈的暗礁。
16 3
|
7天前
|
存储 IDE 开发工具
探索Android开发之旅:从新手到专家
【10月更文挑战第26天】在这篇文章中,我们将一起踏上一段激动人心的旅程,探索如何在Android平台上从零开始,最终成为一名熟练的开发者。通过简单易懂的语言和实际代码示例,本文将引导你了解Android开发的基础知识、关键概念以及如何实现一个基本的应用程序。无论你是编程新手还是希望扩展你的技术栈,这篇文章都将为你提供价值和启发。让我们开始吧!
|
13天前
|
Java API Android开发
安卓应用程序开发的新手指南:从零开始构建你的第一个应用
【10月更文挑战第20天】在这个数字技术不断进步的时代,掌握移动应用开发技能无疑打开了一扇通往创新世界的大门。对于初学者来说,了解并学习如何从无到有构建一个安卓应用是至关重要的第一步。本文将为你提供一份详尽的入门指南,帮助你理解安卓开发的基础知识,并通过实际示例引导你完成第一个简单的应用项目。无论你是编程新手还是希望扩展你的技能集,这份指南都将是你宝贵的资源。
42 5