收藏
回答

h5页面无法打开微信实现分享功能,怎办?

AppID
wxdb3337d1f8618294
@Component
@ConfigurationProperties(prefix = "weixin")
@Data
public class WXUnitl {
    private String weixinAppId;
    private String weixinSecret;
    public static WinXinEntity getWinXinEntity(String url) {
        WinXinEntity wx = new WinXinEntity();
        String access_token = getAccessToken();  //同类的  上面的获取token的方法
        String ticket = getTicket(access_token);  //同类的  上面的获取ticket的方法
        Map<String, String> ret = sign(ticket, url);
        wx.setTicket(ret.get("jsapi_ticket"));
        wx.setSignature(ret.get("signature"));
        wx.setNoncestr(ret.get("nonceStr"));
        wx.setTimestamp(ret.get("timestamp"));
        return wx;
    }
    // 生成签名
    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;
    }
    // 获取ticket
    private static String getTicket(String access_token) {
        String ticket = null;
        String url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=" + access_token + "&type=jsapi";// 这个url链接和参数不能变
        try {
            URL urlGet = new URL(url);
            HttpURLConnection http = (HttpURLConnection) urlGet.openConnection();
            http.setRequestMethod("GET"); // 必须是get方式请求
            http.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
            http.setDoOutput(true);
            http.setDoInput(true);
            System.setProperty("sun.net.client.defaultConnectTimeout", "30000");// 连接超时30秒
            System.setProperty("sun.net.client.defaultReadTimeout", "30000"); // 读取超时30秒
            http.connect();
            InputStream is = http.getInputStream();
            int size = is.available();
            byte[] jsonBytes = new byte[size];
            is.read(jsonBytes);
            String message = new String(jsonBytes, "UTF-8");
            JSONObject demoJson = JSONObject.parseObject(message);
            System.out.println("获取ticket:"+demoJson);
            ticket = demoJson.getString("ticket");
            is.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        System.out.println("ticket:"+ticket);
        return ticket;
    }
    // 获取token
    private static String getAccessToken() {
        String access_token = "";
        String grant_type = "client_credential";//获取access_token填写client_credential
        String AppId=weixinAppId;//第三方用户唯一凭证,你自己的公众号appid
        String secret=weixinSecret;//第三方用户唯一凭证密钥,即appsecret 公众号 秘钥
        //这个url链接地址和参数皆不能变  这个token是需要进行缓存的,因为它的调用次数每日是有限的。
        String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type="+grant_type+"&appid="+AppId+"&secret="+secret;  //访问链接
        try {
            URL urlGet = new URL(url);
            HttpURLConnection http = (HttpURLConnection) urlGet.openConnection();
            http.setRequestMethod("GET"); // 必须是get方式请求
            http.setRequestProperty("Content-Type","application/x-www-form-urlencoded");
            http.setDoOutput(true);
            http.setDoInput(true);
            http.connect();
            InputStream is = http.getInputStream();
            int size = is.available();
            byte[] jsonBytes = new byte[size];
            is.read(jsonBytes);
            String message = new String(jsonBytes);
            JSONObject demoJson = JSONObject.parseObject(message);
            System.out.println("获取token:"+demoJson);
            access_token = demoJson.getString("access_token");
            is.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return access_token;
    }
    public static Map<String, String> sign(String jsapi_ticket, String url) {
        Map<String, String> ret = new HashMap<String, String>();
        String nonce_str = create_nonce_str();  //生成随机串
        String timestamp = create_timestamp();   //生成当前时间戳
        String string1;
        String signature = "";
        // 注意这里参数名必须全部小写,且必须有序
        string1 = "jsapi_ticket=" + jsapi_ticket + "&noncestr=" + nonce_str + "&timestamp=" + timestamp + "&url=" + url;
        System.out.println("string1:"+string1);
        try {
            MessageDigest crypt = MessageDigest.getInstance("SHA-1");
            crypt.reset();
            crypt.update(string1.getBytes("UTF-8"));
            signature = byteToHex(crypt.digest());
            System.out.println("获取signature:"+signature);
        } 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;
    }
    // 生成nonce_str
    private static String create_nonce_str() {
        return UUID.randomUUID().toString();
    }
    // 生成timestamp
    private static String create_timestamp() {
        return Long.toString(System.currentTimeMillis() / 1000);
    }
}
    @ApiOperation("获取微信签名")
    @RequestMapping(value = "/getWxSg", method = RequestMethod.GET)
    public Map<String, Object> sgture(HttpServletRequest request) {
        String strUrl=request.getParameter("url");
        logger.info("===前====url========="+strUrl);
        WinXinEntity wx = WXUnitl.getWinXinEntity(strUrl);
        // 将wx的信息到给页面
        Map<String, Object> map = new HashMap<String, Object>();
        map.put("signature", wx.getSignature().trim());//签名sgture.trim()
        map.put("timestamp", wx.getTimestamp().trim());//时间戳
        map.put("noncestr",  wx.getNoncestr().trim());//随即串
        map.put("appId","wxdb3337d1f8618294");//你的公众号APPID,写你自己的appid
        return map;
    }

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>websocket-demo</title>
  <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js" type="text/javascript"></script>
  <script src="https://res2.wx.qq.com/open/js/jweixin-1.6.0.js" type="text/javascript"></script>
</head>
<body>
<div style="font-size: 100px; background-color: yellow;" onclick="getShareConfig()">
  点击开始分享
</div>
</body>
<script type="text/javascript" charset="utf-8">
  // 使用 AJAX 发送 GET 请求
  function getShareConfig() {
    $.get("http://www.lifeiyu.icu:9055/video/video/getWxSg", {url: window.location.href}, function (res) {
      jWeixin.config({
        debug: true, // 是否打开调试
        appId: res.appId, // 必填,公众号的唯一标识
        timestamp: res.timestamp, // 必填,生成签名的时间戳
        nonceStr: res.noncestr, // 必填,生成签名的随机串
        signature: res.signature, // 必填,签名
        jsApiList: ["updateAppMessageShareData", "updateTimelineShareData"]
      });
	jWeixin.showMenuItems({
	  menuList: ['updateAppMessageShareData', 'updateTimelineShareData']
	});
	jWeixin.error((err) => {
	  console.error('Config error:', err);
	});
    jWeixin.ready(() => {
        // 分享给朋友
        jWeixin.updateAppMessageShareData({
          title: "分享标题", // 分享标题
          desc: "分享描述", // 分享描述
          link: window.location.href, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
          imgUrl: "http://www.lifeiyu.icu:9000/video/images/2024/08/03/17226921293788661.jpeg", // 分享图标
          success() { // 分享成功回调
            alert("分享给朋友成功");
          },
          cancel() { // 取消分享回调
            alert("分享给朋友取消");
          }
        });
      });
    });
  }
</script>
</html>


回答关注问题邀请回答
收藏

1 个回答

  • Hlxuan.
    Hlxuan.
    2024-08-08

    updateAppMessageShareData 接口仅用于设置分享内容,是不能唤起分享的,目前是只能点击右上角菜单操作分享。

    2024-08-08
    有用 1
    回复
登录 后发表内容
问题标签