Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 502|回复: 0

一处折腾笔记:Android内嵌html5加入原生微信分享的解决的方法

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-19 10:19:46 | 显示全部楼层 |阅读模式
    有一段时间没有瞎折腾了。

    这周一刚上班萌主过来反映说:微信里面打开聚客宝。分享功能是能够的(这里是用微信自身的js-sdk实现的)。可是在android应用里面打开点击就没反应了;接下来狡猾的丁丁在产品群里AT我说:偶们的产品设计不是一直都被技术给反压制住么?真是气死,呵呵。自己刚好有空又有兴趣,于是研究了下。没曾想竟也研究出来了。事后我对整个操作过程整理了下,方便他人也提升自己。

    废话少扯。以下上干货。

    我的思路是:在点击h5上的分享图标时。触发js事件,在这里面能够对当前设备的操作系统和浏览器类型做推断,然后运行不同的操作。

    假设是在android操作系统下而且是在微信浏览器的,就运行原本微信自带的js-sdk分享;假设是在android操作系统下可是不在微信浏览器的,就运行原生的微信分享。

    在js里面我们能够通过android与js之间的js交互接口,将js请求传递给android的代码中,这个请求至少须要传递分享的图文的链接地址、分享的缩略图的网址、分享窗体的标题、分享的内容四个參数,android那边接到请求后。获取到这四个參数。并运行弹出分享窗体的操作。我们在这个操作里面仅仅管调用方法和对參数赋值。至于剩下的实现细节则交给微信去处理,我们不用关心。



    一、在微信开放平台新建应用,获取AppId和AppSecret
    1、创建应用
    进入微信开放平台的官网(open.weixin.qq.com),选择首页左下角的“移动应用开发”;

    进入移动应用开发页面后,选择“创建应用”操作。

    在创建应用页面,我们须要填写应用的信息。必填的包含移动应用名称(你的应用的名称,比如腾讯新闻,并且微信平台里面填写的这个应用不能和已有的反复。

    比方别人叫“腾讯新闻”的申请过了,即便你的应用也叫“腾讯新闻”,你也无法申请这个名字,另一点这个名字是能够在微信分享的时候显示在左下角的,相当于是应用的标识)、移动应用简单介绍(写一段简短的语句介绍你的应用。无实际意义可是必填)、移动应用的图片将准备的28*28和108*108的logo图片上传上去(这个小图片也是在分享的时候能够显示在左下角的);


    2、填写平台信息
    在填写平台信息页面。须要填写应用的官网(填写公司的网址就可以)、应用平台(开发语言,这里我选android)、应用签名、应用包名。

    这里注意,应用签名和应用包名非常重要!千万不要写错。



    3、等待审核
    提交完成后就等待微信的审核了,页面提示的是7天内。实际我仅仅等了1个小时就审核通过了(预计是微信的工作人员心情好~)


    4、获取AppId和AppSecret
    审核通过后。我们就能看到AppId和AppSecret了,这里我们保存下来,后面会用到。

    二、在mob上新建应用,获取分享所需的sdk
    mob.com是全球最大的移动开发服务平台,里面的sharesdk包括了全球大多数全部的应用分享功能,在使用时我们能够依据须要,灵活地选择我们所须要的平台。
    1、创建账号和应用
    进入mob.com新建账号,创建应用,创建应用过程跟上面的一致且步骤简单,此处不再赘述。进去之后能够熟悉下里面的菜单。

    这里我们记录下生成的应用的AppKey。后面会用到。


    2、获取sdk
    在“下载sdk”--“社会化分享sdk”中选择android图标。点击“下载sdk”button,在下载页面我们能够选择我们所须要的分享平台和官方的demo。


    三、代码集成
    在mob官网获取sdk和demo后。能够參考说明文档。将代码嵌入进我们的应用代码中

    将由mob提供的QuickIntegrater.jar生成的代码拷贝到相应的目录以下(即下图红框部分的代码)。另外加入配置信息到相关的配置文件、清单文件里,加入jar包支持


    微信弹出分享窗体的核心代码例如以下:
    /**
    	 * 弹出微信分享的窗体
    	 * @param shareUrl       分享的图文链接的地址
    	 * @param shareImageUrl  分享的缩略图的地址
    	 * @param shareTitle     分享的窗体标题
    	 * @param shareContent   分享的文字内容
    	 */
    	private void showShare(String shareUrl,String shareImageUrl,String shareTitle,String shareContent) {
    		 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));
    		 oks.setTitle(shareTitle);
    		 // titleUrl是标题的网络链接。仅在人人网和QQ空间使用
    		 oks.setTitleUrl(shareUrl);
    		 // text是分享文本。全部平台都须要这个字段
    		 oks.setText(shareContent);
    		 // imagePath是图片的本地路径。Linked-In以外的平台都支持此參数
    		 //oks.setImagePath("/sdcard/test.jpg");//确保SDcard以下存在此张图片
    		 //oks.setImagePath(shareImageUrl);//当分享的图片是来自互联网的时候,这一行代码要凝视掉,否则会被覆盖掉--yuxinwei
    		 oks.setImageUrl(shareImageUrl);
    
    		 // url仅在微信(包含好友和朋友圈)中使用
    		 oks.setUrl(shareUrl);
    		 // comment是我对这条分享的评论,仅在人人网和QQ空间使用
    		 oks.setComment("");
    		 // site是分享此内容的站点名称,仅在QQ空间使用
    		 oks.setSite(getString(R.string.app_name));
    		 
    		// 启动分享GUI
    		 oks.show(this);
    		 }


    另外须要将我们申请到的微信开放平台里面的AppId和AppSecret、mob里面新建的应用的AppKey配置到ShareSDK.xml中(这里为了保护隐私,代码中我的应用的key和secret我做了脱敏处理,仅作为演示样例)
    <ShareSDK AppKey = "725ba30XXXXX"/> <!-- 改动成你在mob后台注冊的应用的appkey"-->

    <Wechat
            Id="4"
            SortId="4"
            AppId="wxd39f588142bXXXXX"
            AppSecret="c362a62161fc87b12a5d23477a2XXXXX"
            BypassApproval="false"
            Enable="true" />
        
        <WechatMoments
            Id="5"
            SortId="5"
            AppId="wxd39f588142bXXXXX"
            AppSecret="c362a62161fc87b12a5d23477a2XXXXX"
            BypassApproval="false"
            Enable="true" />

    调试时候显示的效果基本例如以下图所看到的




    到此,整个操作过程基本结束
    剩下的就是不停地调试和測试了。


    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 21:42 , Processed in 0.075717 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表