2025-10-30 12:26:16

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

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前端代码

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<%

String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%>

分享

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页面加在公众号中(例如加到公众号菜单中)进行访问时,才可以分享朋友圈和转发给微信朋友。

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