vue调用微信jssdk实现分享等功能

1,首先需要有微信开发者账号

2,测试号配置说明

image-20210917132925577.png
  • JS接口安全域名。配置你服务器的域名,不加http(s)://这些,例如www.baidu.com详见开发文档

    image-20210917134206088.png

  • 测试号二维码,自己微信关注就好了,微信号列就是对应的openId
    image-20210917134410465.png
  • 体验接口权限表。有的接口需要手动设置或者开启,关注一下。
    image-20210917134457417.png
  • 注意,如果后期过渡到服务号真实开发实现功能,还需要配置JS安全域名里的服务器秘钥
    image-20210917134714898.png

以及配置ip白名单
image-20210917134756726.png

测试号不需要设置。

3,找到微信jssdk开发文档

4,引入微信的JS文件

  • 可以直接引用
    image-20210917135040815.png
  • vue中也可以npm install weixin-js-sdk --save 然后在页面中引用
    image-20210917135227455.png

5,后端业务逻辑

  • 部分后端处理代码
  //前端请求的url
  JSONObject reqJson = JSONObject.fromObject(reqStr);
  String accessToken = WeixinUtil.getAccessToken();
  String ticket =  WeixinUtil.getJSAPITicket(accessToken);
  Map<String, String> result = JSSign.sign(ticket,
 JSONObject.fromObject(reqJson.getString("config")).getString("url")); 
  respJson.put("appId",Config.getWxConfig().getAppId());
  respJson.put("nonceStr",result.get("nonceStr"));
  respJson.put("signature",result.get("signature"));
  respJson.put("timestamp",result.get("timestamp"));
  respJson.put(ConstantUtil.RESP_CODE, ConstantUtil.RespCode.SUCC);
private static ConcurrentHashMap<String, String> TICKET_MAP = new ConcurrentHashMap<>();
     private static final String JSAPI_TICKET = "jsapi_ticket";
     private static final String EXPIRES_IN = "expires_in";
     private static ConcurrentHashMap<String, String> ACCESS_TOKEN_MAP = new ConcurrentHashMap<>();
     private static final String ACCESS_TOKEN = "access_token";

     /**
     * 获取微信access_token
     * @return
     * @throws Exception
     */
     public static String getAccessToken() throws Exception{
     String accessToken = null;
     String response = null;
     if (ACCESS_TOKEN_MAP.get(ACCESS_TOKEN) != null && Integer.parseInt(ACCESS_TOKEN_MAP.get(EXPIRES_IN)) > Utility.getCurrentTimeStamp()) {
     accessToken = ACCESS_TOKEN_MAP.get(ACCESS_TOKEN);
     log.info("getWxToken() end, access-token from redis, expires_in, accessToken={}"+accessToken);
     return accessToken;
     }
     try {
     //assessTokenUrl:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=SECRET
     response = sendGET(Config.getWxConfig().getAccessTokeUrl().replace("APPID", appid).replace("SECRET", secret),null);
     } catch (Exception e) {
     log.error("getWxToken() exception. ", e);
     }
     if (response != null) {
     JSONObject jsonObject = JSONObject.fromObject(response);
     accessToken = jsonObject.getString("access_token");
     Integer expiresIn = Integer.parseInt(jsonObject.getString("expires_in"));
     ACCESS_TOKEN_MAP.put(ACCESS_TOKEN, accessToken);
     ACCESS_TOKEN_MAP.put(EXPIRES_IN, String.valueOf(expiresIn + Utility.getCurrentTimeStamp() - 600));
     }
     return accessToken;
     }
    
     /**
     * 获取jsapiticket
     * @return
     * @throws Exception
     */
     public static String getJSAPITicket(String token) throws Exception{
    
     String JsApiTicket = null;
     String response = null;
     if (TICKET_MAP.get(JSAPI_TICKET) != null && Integer.parseInt(TICKET_MAP.get(EXPIRES_IN)) > Utility.getCurrentTimeStamp()) {
     JsApiTicket = TICKET_MAP.get(JSAPI_TICKET);
     log.info("getJSAPITicket() end, js_api_ticket from redis, expires_in, accessToken={}"+JsApiTicket);
     return JsApiTicket;
     }
    
     try {
     //jsapiticket:https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=jsapi
     response = sendGET(Config.getWxConfig().getJsapiTicketUrl().replace("ACCESS_TOKEN", token),null);
     } catch (Exception e) {
     log.error("getWxToken() exception. ", e);
     }
     if (response != null) {
     JSONObject jsonObject = JSONObject.fromObject(response);
     JsApiTicket = jsonObject.getString("ticket");
     Integer expiresIn = Integer.parseInt(jsonObject.getString("expires_in"));
     TICKET_MAP.put(JSAPI_TICKET, JsApiTicket);
     TICKET_MAP.put(EXPIRES_IN, String.valueOf(expiresIn + Utility.getCurrentTimeStamp() - 600));
     }
     return JsApiTicket;
     }

6,前端业务逻辑

<template>
     <div>
     <a @click="onShareClick">点击分享</a>
     </div>
    </template>
    
    <script>
     export default {
     name: "TestShare",
     created() {
    
     let loading = this.$loading({
     lock: true,
     text: '初始化中...',
     spinner: 'el-icon-loading',
     background: 'rgba(0, 0, 0, 0.7)'
     });
     let config = {
     url: location.href.split('#')[0]
     };
     //下单
     this.$post('api/Wx/getWxConfig.do', {
     config: config
     }).then((response) => {
     if (response.respCode == '00') {
     // // console.log("1111");
     config.nonceStr = response.nonceStr;
     config.signature = response.signature;
     config.timestamp = response.timestamp;
     config.appId = response.appId;
     config.debug = true;
     config.jsApiList = [ // 所有要调用的 API 都要加到这个列表中
     'checkJsApi',
     'updateAppMessageShareData',
     'updateTimelineShareData',
     ],
     wx.config(config);
     wx.ready(() => {
     this.wx = wx;
     wx.checkJsApi({
     jsApiList: ['updateAppMessageShareData'], // 需要检测的JS接口列表,所有JS接口列表见附录2,
     success: function(res) {
     // 以键值对的形式返回,可用的api值true,不可用为false
     // 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"}
     alert("success");
     }
     }); 
     });
     wx.error(function (res) {
     alert(res.errMsg);
     console.info('error 验证失败', res);
     });

     } else {
     this.$message.error('微信SDK初始化失败:' + response.respDesc);
     }
     loading.close();
     }).catch((e) => {
     this.$message.error('微信SDK初始化失败!'+e);
     loading.close();
     });
     },
     share() {
     wx.updateAppMessageShareData({
     title: "分享", // 分享标题
     desc: "分享", // 分享描述
     link: "", // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
     imgUrl: "", // 分享图标
     success: function() {
     alert("预分享成功");
     // 设置成功
     },
     });
     },
     }
    </script>

7,流程总结

  • 前端上送当前地址url,请求token和ticket获取签名(需要服务端缓存)。拿到签名。在前端wx.config中初始化jssdk。初始化成功后就可以正常调用jssdk的方法啦。

  • image-20210917142531769.png

    image-20210917143306319.png

8,注意事项

  • 目前分享接口仅支持预分享(分享后还需点击右上角三个点手动分享),不支持点击直接跳出好友列表(以前支持的已废弃)。优化处理可以使用https://blog.csdn.net/chuchenqian9735/article/details/101019938的方法。

  • 大坑!!!前端上送的当前页面url是 location.href.split('#')[0]。微信文档有的地方说需要加
    image-20210917141620782.png

但是实际签名中不需要加encodeURL():

image-20210917141707349.png

所以上送就直接送当前地址就好了,不需要转义。

  • ios设备真机调试时候会报签名失败,是因为ios设备在初始化config时只认第一次进入时的url(比如初始化的页面是http://xx/pay。但是发请求时候的地址是http://xx,所以导致上送签名的url和调用初始化的url不一致。可通过把初始化操作放在项目第一次进入的页面解决。android无此问题)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,636评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,890评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,680评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,766评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,665评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,045评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,515评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,182评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,334评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,274评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,319评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,002评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,599评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,675评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,917评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,309评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,885评论 2 341

推荐阅读更多精彩内容