微信分享H5自定义标题描述和图片

前言

哎呀,为啥人家分享的H5页面这么绚丽,有头有尾有妹子,唯独自己的又老有丑又难啃,自己都看不下去,千万不要给领导看见。然而,最终还是领导发话了这个必须得改。

永远不要指望微信给的案例能让你迅速解决问题,打开一看你会发现都TM是PHP的DEMO,Java的代码那叫一个惨啊。

效果展示

来、来、来,我们先尝试先跟朋友拉一个仇恨。

啧、啧、啧,然后再跟朋友圈拉仇恨,可别像我这样藏起来自己玩。

开发环境

  • SpringBoot 1.5.10
  • JDK 7
  • Tomcat 8
  • Nginx
  • 备案域名
  • 认证公众号

注意事项

  • 必须是认证公众号,订阅号是没有接口分享权限滴
  • 配置IP白名单,基本配置-公众号开发信息-IP白名单
  • 备案域名需要在公众号后台授权认证,公众号设置-功能设置-JS接口安全域名

代码案例

本来想把记仇前后端以及微信分享认证上传到码云,想想天色已晚,有需要的直接联系我吧,或者抽空上传。

前端代码,处理分享逻辑:

<!-- 微信分享、部分代码 -->
<script th:src="@{/js/jquery-1.10.2.min.js}"></script>
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
<script type="text/javascript">
    var jssdk = null;
    var data = {'href':location.href};
    $.ajax({
        url:'/signature',
        type: 'POST',
        async:false,
        data:data,
        success:function(result){
            jssdk = result;
        },
        error:function(){

        }
    });
    // 配置功能
    wx.config({
        debug: false,
        appId: jssdk.appId,
        timestamp: parseInt(jssdk.timestamp),
        nonceStr: jssdk.nonceStr,
        signature: jssdk.signature,
        jsApiList: [
            "onMenuShareTimeline",//分享给好友
            "onMenuShareAppMessage"//分享到朋友圈
        ]
    });
    wx.ready(function () {
        wx.onMenuShareTimeline({
            title: "今天这个仇先记下来", // 分享标题
            desc: " 主角们的记仇表情包,如果谁要不带你打游戏,你就挑一张发他",
            link: location.href, // 分享链接
            imgUrl: "http://jichou.52itstyle.com/jichou.png", // 分享图标
            success: function () {
                //alert("成功");
            },
            cancel: function () {
                // alert("失败")
            }
        });
        wx.onMenuShareAppMessage({
            title: "今天这个仇先记下来", // 分享标题
            desc: " 主角们的记仇表情包,如果谁要不带你打游戏,你就挑一张发他",
            link: location.href, // 分享链接
            imgUrl: "http://jichou.52itstyle.com/jichou.png", // 分享图标
            success: function () {
                //alert("成功");
            },
            cancel: function () {
                //alert("失败")
            }
        });
    });
</script>

基本的WechatController,获取签名:

@Controller
@RequestMapping
public class WechatController {
    private static final Logger logger = LoggerFactory.getLogger(WechatController.class);
    
    @RequestMapping(value="index.html",method=RequestMethod.GET)
    public String index() {
        return "index";
    }
    
    @RequestMapping(value="signature",method=RequestMethod.POST)
    public @ResponseBody Map<String, String> signature(String href) {
        logger.info("获取signature");
        Map<String, String> map = WxUtil.getSign(href);
        return map;
    }
}

然后就是一些获取Ticket、Token、计算失效时间以及签名认证等等,代码很长这里就不一一罗列了。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏架构师之旅

《干货系列》如何修炼成为一名高级程序猿?

每个人都有大梦想,作为程序员当然是想做一个程序大牛,毕竟不想当将军的厨子不是好裁缝!那么要想成为好裁缝,不好程序员,应该需要哪些知识呢?小编搜罗了一下,还真不少...

22190
来自专栏java达人

武林外传—一灯大师与众弟子漫谈Api网关选型

南帝段王爷隐居桃源后,潜心研究,构筑了一套武林秘籍访问系统,系统是微服务部署的,拆分为多个模块,每个模块只做一件事情。系统刚上线的时候非常顺利,但随着访问量的增...

16660
来自专栏杨建荣的学习笔记

Oracle闪回原理测试(三)(r12笔记第16天)

对于Oracle的闪回,很多朋友也问过问,到底是怎么玩的?如果自己做过一些闪回数据库的操作,就会发现这个功能非常强悍。 Flashback DML的操作...

35550
来自专栏java工会

Java程序员新手老手都离不开八大开发工具

现在有很多库、实用工具和程序任Java开发人员选择。每个工具都有其优点,但其中有一些因它的知名度、多功能性和有效性从众多选项中脱颖而出。 以下这8个工具,从代码...

21720
来自专栏叁金大数据

Hadoop的数据采集框架

问题导读: Hadoop数据采集框架都有哪些? Hadoop数据采集框架异同及适用场景?

34920
来自专栏技术沉淀

很赞的开源小工具

14620
来自专栏java系列博客

java面试要点

17230
来自专栏Albert陈凯

2018-04-16 Java面试通关要点汇总集2018年最新 Java面试通关要点汇总集

2018年最新 Java面试通关要点汇总集 基础篇 基本功 面向对象的特征 final, finally, finalize 的区别 int 和 Integ...

30760
来自专栏java工会

Java程序员新手老手都离不开八大开发工具

现在有很多库、实用工具和程序任Java开发人员选择。每个工具都有其优点,但其中有一些因它的知名度、多功能性和有效性从众多选项中脱颖而出。 以下这8个工具,从代码...

15200
来自专栏架构师小秘圈

利用顶层框架,秒变微服务专家

jHipster(J潮客)其亮点: 风头超劲,席卷欧美,最新全能Java Web开发程式产生器 (java web generator)。 由Java专...

41160

扫码关注云+社区

领取腾讯云代金券