微信分享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 条评论
登录 后参与评论

相关文章

来自专栏C#

DotNet加密方式解析--非对称加密

    新年新气象,也希望新年可以挣大钱。不管今年年底会不会跟去年一样,满怀抱负却又壮志未酬。(不过没事,我已为各位卜上一卦,卦象显示各位都能挣钱...)...

4928
来自专栏转载gongluck的CSDN博客

cocos2dx 打灰机

#include "GamePlane.h" #include "PlaneSprite.h" #include "BulletNode.h" #include...

5556
来自专栏pangguoming

Spring Boot集成JasperReports生成PDF文档

由于工作需要,要实现后端根据模板动态填充数据生成PDF文档,通过技术选型,使用Ireport5.6来设计模板,结合JasperReports5.6工具库来调用渲...

1.2K7
来自专栏陈仁松博客

ASP.NET Core 'Microsoft.Win32.Registry' 错误修复

今天在发布Asp.net Core应用到Azure的时候出现错误InvalidOperationException: Cannot find compilati...

4868
来自专栏张善友的专栏

Silverlight + Model-View-ViewModel (MVVM)

     早在2005年,John Gossman写了一篇关于Model-View-ViewModel模式的博文,这种模式被他所在的微软的项目组用来创建Expr...

2988
来自专栏闻道于事

js登录滑动验证,不滑动无法登陆

js的判断这里是根据滑块的位置进行判断,应该是用一个flag判断 <%@ page language="java" contentType="text/html...

6948
来自专栏Ceph对象存储方案

Luminous版本PG 分布调优

Luminous版本开始新增的balancer模块在PG分布优化方面效果非常明显,操作也非常简便,强烈推荐各位在集群上线之前进行这一操作,能够极大的提升整个集群...

3185
来自专栏杨龙飞前端

scrollto 到指定位置

2524
来自专栏落花落雨不落叶

canvas画简单电路图

63111
来自专栏魂祭心

原 canvas绘制clock

4164

扫码关注云+社区