H5网页实现微信分享,分享朋友圈功能(分享带图片,附源码)

您所在的位置:网站首页 微信公众号怎样转发链接 H5网页实现微信分享,分享朋友圈功能(分享带图片,附源码)

H5网页实现微信分享,分享朋友圈功能(分享带图片,附源码)

2024-06-29 12:15| 来源: 网络整理| 查看: 265

H5网页实现微信分享,分享朋友圈功能,网上的代码基本上都过期了,特基于最新的jweixin-1.6.0版本的微信分享实现,以作备忘。

目 录

1.微信分享文档及配置

1.1微信分享官网文档

1.2 appid对应的公众号是否有分享接口权限

 1.3设置白名单和绑定域名

2 代码实现

2.1后端Java代码

2.2前端代码

2.1 idea完整项目下载

3.常见问题及解决方法

3.1wx.config初始化失败

3.2分享接口没有权限

3.3H5页面看不到“分享朋友圈”和“转发朋友”功能

1.微信分享文档及配置 1.1微信分享官网文档

地址概述 | 微信开放文档

 需要注意一下,即将废弃接口,建议不要再调用了。

1.2 appid对应的公众号是否有分享接口权限

登录公众号后,接口状态为已获得,表示有权限。如下图

 1.3设置白名单和绑定域名

分享的服务器外网ip地址,需要添加到白名单中,如下图

 绑定域名

先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。

备注:登录后可在“开发者中心”查看对应的接口权限。

2 代码实现 2.1后端Java代码

获取参数工具类

import org.json.JSONObject; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Formatter; import java.util.HashMap; import java.util.Map; import java.util.UUID; public class SignUtil { public static String APP_ID="";//在controller中初始化 public static String APP_SECRET=""; public static void main(String[] args) { String url = "https://www.**.com/share"; System.out.println(getResult(url)); }; public static Map getResult(String url){ Map ret = sign(getTicket(), url); ret.put("appId", getAppId()); return ret; } private static String getAppId(){ return APP_ID; } private static String getToken(){ String accessToken = ""; String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="+getAppId()+"&secret="+APP_SECRET; try { String resultString =HttpUtil.get(url); if (null != resultString && !"".equals(resultString)) { System.out.println(resultString); JSONObject json = new JSONObject(resultString); accessToken = json.get("access_token").toString(); }else{ System.out.println("返回值为空,请检查请求报文或者请求地址是否正确"); } } catch (Exception e) { e.printStackTrace(); } return accessToken; } private static String getTicket(){ String ticket = ""; String url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token="+getToken()+"&type=jsapi"; try { String resultString =HttpUtil.get(url); if (null != resultString && !"".equals(resultString)) { System.out.println(resultString); JSONObject json = new JSONObject(resultString); ticket = json.getString("ticket"); }else{ System.out.println("返回值为空,请检查请求报文或者请求地址是否正确"); } } catch (Exception e) { e.printStackTrace(); } return ticket; } public static Map sign(String jsapi_ticket, String url) { Map ret = new HashMap(); String nonce_str = create_nonce_str(); String timestamp = create_timestamp(); String string1; String signature = ""; //注意这里参数名必须全部小写,且必须有序 string1 = "jsapi_ticket=" + jsapi_ticket + "&noncestr=" + nonce_str + "×tamp=" + timestamp + "&url=" + url; System.out.println(string1); try { MessageDigest crypt = MessageDigest.getInstance("SHA-1"); crypt.reset(); crypt.update(string1.getBytes("UTF-8")); signature = byteToHex(crypt.digest()); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } ret.put("url", url); ret.put("jsapi_ticket", jsapi_ticket); ret.put("nonceStr", nonce_str); ret.put("timestamp", timestamp); ret.put("signature", signature); return ret; } private static String byteToHex(final byte[] hash) { Formatter formatter = new Formatter(); for (byte b : hash) { formatter.format("%02x", b); } String result = formatter.toString(); formatter.close(); return result; } private static String create_nonce_str() { return UUID.randomUUID().toString().replace("-",""); } private static String create_timestamp() { return Long.toString(System.currentTimeMillis() / 1000); } }

controller实现

@Controller public class ShareController { @Value("${wx.appid}") private String appid; @Value("${wx.appsecret}") private String appsecret; @RequestMapping("/index") public ModelAndView show(){ SignUtil.APP_ID=appid; SignUtil.APP_SECRET=appsecret; ModelAndView mv=new ModelAndView(); String url="http://localhost:8080/index"; mv.addObject("share",SignUtil.getResult(url)); mv.setViewName("/index"); return mv; } } 2.2前端代码 分享 // 微信分享默认调用接口 var $appid,$timestamp,$noncestr,$signature,$description,$title1; //获取当前页面的url var linkUrl = window.location.href; var data = "${share}"; console.log(data); $appid = "${share.appId}"; // appid $timestamp = "${share.timestamp}"; // timestamp $noncestr = "${share.nonceStr}"; // noncestr $signature = "${share.signature}"; // signature $description = "分享描述"; // share_desc $title1 = "分享标题";// share_title //**配置微信信息** wx.config ({ debug : true, appId : $appid, timestamp : $timestamp, nonceStr : $noncestr, signature : $signature, jsApiList : [ // 所有要调用的 API 都要加到这个列表中 'updateTimelineShareData', 'updateAppMessageShareData', 'onMenuShareWeibo' ] }); wx.ready (function () { // 微信分享的数据 var shareData = { "imgUrl" : "static/image/demo.png", "link" : linkUrl, "desc" : $description, "title" : $title1, success : function () { // 分享成功可以做相应的数据处理 } }; //分享微信朋友圈 wx.updateTimelineShareData (shareData); //分享给朋友 wx.updateAppMessageShareData({ title: $title1, // 分享标题 desc: $description, // 分享描述 link: linkUrl, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致 imgUrl: 'static/image/demo.png', // 分享图标 success: function () { // 设置成功 } }); //分享到微博 wx.onMenuShareWeibo (shareData); }); 2.1 idea完整项目下载

基于jweixin-1.6.0.js最新版本,搭建springbootweb项目,实现微信分享,分享朋友圈,完整idea源码_H5网页实现微信分享功能-Java文档类资源-CSDN下载

3.常见问题及解决方法 3.1wx.config初始化失败

情况有很多种,主要如下:

1.Java后台前面的url与分享的url不一致,需要完全一致。例如后台是http,分享地址是https

2.参数不对

3.2分享接口没有权限

这错误有2种情况,1是参数不对;2是公众号中分享接口的状态为未获得。

3.3H5页面看不到“分享朋友圈”和“转发朋友”功能

这个是由于微信官方在2021年9月份,做了调整,只能把H5页面加在公众号中(例如加到公众号菜单中)进行访问时,才可以分享朋友圈和转发给微信朋友。

有问题,欢迎大家留言沟通。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3