日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

瀏覽:151日期:2022-06-10 18:53:07

1.如果只使用config配置的相關js接口 可采用如下方式引入

執(zhí)行 npm weixin-sdk-js --save

局部引入 在vue頁面中 import wx from ’weixin-sdk-js’;

全局引入 在vue 的main.js 頁面中 引入后編寫到vue原型鏈上,然后全局調(diào)用

import wx from 'weixin-sdk-js';

Vue.prototype.$wx = wx;

2.如果要使用agentConfig配置的相關接口 一定不要執(zhí)行npm命令引入,如果執(zhí)行了npm 命令,請執(zhí)行卸載指令 npm uninstall weixin-sdk-js --save ,然后在vue項目中的index.html頁面中引入官網(wǎng)相關sdk-js的js

原因:因為agentConfig 使用的js 沒有npm對應的指令(只是因為我沒找到..)。

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

說明: 第一個js(上面的js)鏈接為config配置用到的js

第二個js(下面的js)鏈接為agentconfig配置用的到js

3.引入sdk-js中的wx 使用相關方法 引入方式分全局引入和局部引入

a.局部引入 在要想調(diào)用 wx sdk相關接口的頁面 (本人使用的局部,因為就一個頁面使用)

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

b.全局引入 在main.js文件中引入 寫入到vue原型鏈上 方便全局調(diào)用

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

然后再要使用的頁面的script區(qū)域代碼中使用 this.$wx 即可 調(diào)用 ($wx 為你自定義的變量名)

4.config配置驗證 參照官網(wǎng)例子自行設置相關參數(shù) (如果是全局配置的 wx用this.$wx 代替)

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

設置了相關參數(shù),如果驗證通過會立即執(zhí)行wx.ready()方法了。這時整個頁面就可以調(diào)用jsApiList中的相關接口方法了。

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

5.agentConfig 配置驗證 參數(shù)自行設置

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

注入相關配置參數(shù),執(zhí)行邏輯同config一樣

需要注意的是如果想使用有agentConfig驗證的相關接口方法,最好在config配置認證通過后的ready()函數(shù)中執(zhí)行agentConfig 配置認證 這樣做的原因:

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

然后整個頁面也就可以調(diào)用agentConfig配置中jsApiList 里的所有接口方法了。

注意:jsApiList中的方法不一定可用,因為跟后臺配置有一定關系。詳情參考官網(wǎng)說明。所以最好是校驗一下jsApiList中哪些方法是可用的.

vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解

6. 附上本人編寫的前端代碼,以及后端獲取相關配置參數(shù)的java代碼

前端 vue :

<script>import axios from 'axios';let wx = window.wx;export default { name: 'Home', data() { return { config: '', agent_config: '' }; }, methods: { //獲取相關驗證配置信息 getConfig(type) { let url = '獲取config或agentConfig配置的參數(shù)接口'; //該paramUrl 為你使用微信sdk-js相關接口的頁面地址 該地址需要配置到應用后臺的可信域名下 let paramUrl = window.location.href.split('#')[0]; let that = this; let param = { url: paramUrl }; if (type === 'agent_config') { param.type = type; } axios .get(url, { params: param }) .then(function (rsp) { if (rsp.data.success) { that[type] = rsp.data.data; if (type === 'config') { that.companyConfigInit(that[type]); } else { that.appConfigInit(that[type]); } } }) .catch(function (err) { console.log(err); }); }, //企業(yè)驗證配置 companyConfigInit(config) { let that = this; wx.config({ beta: true, // 必須這么寫,否則wx.invoke調(diào)用形式的jsapi會有問題 debug: false, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數(shù),可以在pc端打開,參數(shù)信息會通過log打出,僅在pc端時才會打印。 appId: config.appId, // 必填,企業(yè)微信的corpID timestamp: config.timestamp, // 必填,生成簽名的時間戳 nonceStr: config.nonceStr, // 必填,生成簽名的隨機串 signature: config.signature, // 必填,簽名,見 附錄-JS-SDK使用權限簽名算法 jsApiList: [], //你要調(diào)用的sdk接口必填,需要使用的JS接口列表,凡是要調(diào)用的接口都需要傳進來 }); // config信息驗證后會執(zhí)行ready方法,所有接口調(diào)用都必須在config接口獲得結果之后, // config是一個客戶端的異步操作,所以如果需要在頁面加載時就調(diào)用相關接口, // 則須把相關接口放在ready函數(shù)中調(diào)用來確保正確執(zhí)行。 // 對于用戶觸發(fā)時才調(diào)用的接口,則可以直接調(diào)用,不需要放在ready函數(shù)中。 wx.ready(function () {//執(zhí)行你的業(yè)務邏輯代碼 //...... //如果要使用到agent_config相關接口 初始化agentConfig配置 that.getConfig('agent_config'); }); wx.error(function (res) { console.log(res); // config信息驗證失敗會執(zhí)行error函數(shù),如簽名過期導致驗證失敗 // ,具體錯誤信息可以打開config的debug模式查看,也可以在返回的res參數(shù)中查看, // 對于SPA可以在這里更新簽名。 }); }, //應用驗證配置 appConfigInit(config) { let that = this; wx.agentConfig({ corpid: config.corpid, // 必填,企業(yè)微信的corpid,必須與當前登錄的企業(yè)一致 agentid: config.agentid, // 必填,企業(yè)微信的應用id (e.g. 1000247) timestamp: config.timestamp, // 必填,生成簽名的時間戳 nonceStr: config.nonceStr, // 必填,生成簽名的隨機串 signature: config.signature, // 必填,簽名,見附錄-JS-SDK使用權限簽名算法 jsApiList: [], //你要調(diào)用的sdk接口必填 success: function () { //查看相關接口是否可以調(diào)用 //that.checkJsApi(); }, fail: function (res) { if (res.errMsg.indexOf('function not exist') > -1) { alert('版本過低請升級'); } }, }); }, //查看可調(diào)用的接口 checkJsApi() { wx.checkJsApi({ jsApiList: [ ], // 需要檢測的JS接口列表 success: function (res) { // 以鍵值對的形式返回,可用的api值true,不可用為false // 如:{'checkResult':{'chooseImage':true},'errMsg':'checkJsApi:ok'} let obj = res.checkResult; alert( obj['getCurExternalContact'] + ',' + obj['getContext'] + ',' + obj['agentConfig'] + ',' + obj['selectExternalContact'] + ',' ); }, }); } }, created() { this.getConfig('config'); },};</script>

后端java代碼 controller :

Logger logger = LoggerFactory.getLogger(this.getClass());/** * 應用secret */private final String secretId = '';/** * 應用ID */private final String agentId = '';/** * 企業(yè)ID */private final String corpId = ''@GetMapping(value = '/getConfig')public Result getWeiXinPermissionsValidationConfig(@RequestParam('url') String url, @RequestParam(value = 'type', required = false) String type) { if (StringUtils.isEmpty(url)) { return new Result().fail().put('msg', '參數(shù)非法'); } Map<String, Object> data = new HashMap<>(); //臨時票據(jù) String ticket; if (ObjectUtils.isEmpty(type)) { ticket = WeChatApiUtil.getJsApiTicket(secretId, null); data.put('appId', corpId); logger.info('get company temp ticket is :'+ticket); } else { ticket = WeChatApiUtil.getJsApiTicket(secretId, type); data.put('agentid', agentId); data.put('corpid', corpId); logger.info('get app temp ticket is :'+ticket); } if (StringUtils.isEmpty(ticket)) { return new Result().fail().put('msg', '獲取臨時票據(jù)失敗!'); } //當前時間戳 轉(zhuǎn)成秒 long timestamp = System.currentTimeMillis() / 1000; //隨機字符串 String nonceStr = 'Wm3WZYTPz0wzccnW'; String signature = getSignature(ticket, nonceStr, timestamp, url); data.put('timestamp', timestamp); data.put('nonceStr', nonceStr); data.put('signature', signature); return new Result().put('data', data);}private String getSignature(String ticket, String nonceStr, long timestamp, String url) { try { String unEncryptStr = 'jsapi_ticket=' + ticket + '&noncestr=' + nonceStr + '&timestamp=' + timestamp + '&url=' + url; MessageDigest sha = MessageDigest.getInstance('SHA'); // 調(diào)用digest方法,進行加密操作 byte[] cipherBytes = sha.digest(unEncryptStr.getBytes()); String encryptStr = Hex.encodeHexString(cipherBytes); return encryptStr; } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } return null;}WeChatApiUtil工具類獲取ticket /** * 存放ticket的容器 */private static Map<String, Ticket> ticketMap = new HashMap<>();@Dataprivate static class Ticket { private String ticket; private Long valid;}/** * 獲取ticket * @paran type * @param accessToken * @return */public static String getJsApiTicket(String secretId,String type) { //getAccessToken()獲取accessToken 請參考官網(wǎng)自行實現(xiàn)就不貼代碼了 // https://work.weixin.qq.com/api/doc/90000/90135/91039 String accessToken = getAccessToken(secretId); String key =accessToken; if (!StringUtils.isEmpty(accessToken)) { if ('agent_config'.equals(type)){ key=type+'_'+accessToken; } Ticket ticket = ticketMap.get(key); long now = Calendar.getInstance().getTime().getTime(); if (!ObjectUtils.isEmpty(ticket)) { Long valid = ticket.getValid(); //有效期內(nèi)的ticket 直接返回 if (valid - now > 0) {return ticket.getTicket(); } } ticket = getJsApiTicketFromWeChatPlatform(accessToken,type); if (ticket != null) { ticketMap.put(key, ticket); return ticket.getTicket(); } } return null;}public static Ticket getJsApiTicketFromWeChatPlatform(String accessToken, String type) { String url; if ('agent_config'.equals(type)) { url = 'https://qyapi.weixin.qq.com/cgi-bin/ticket/get?access_token=' + accessToken+ '&type=' + type; } else { url = 'https://qyapi.weixin.qq.com/cgi-bin/get_jsapi_ticket?access_token=' + accessToken; } Long now = System.currentTimeMillis(); if (!StringUtils.isEmpty(accessToken)) { String body = HttpUtil.doGet(url); if (!StringUtils.isEmpty(body)) { JSONObject object = JSON.parseObject(body); if (object.getIntValue('errcode') == 0) {Ticket ticket = new Ticket();ticket.setTicket(object.getString('ticket'));ticket.setValid(now + 7200L);return ticket; } } } return null;}HttpUtil工具類/** * 發(fā)起get請求 * @param url * @return */public static String doGet(String url) { CloseableHttpClient httpClient = null; CloseableHttpResponse response = null; String body = ''; try { // 通過址默認配置創(chuàng)建一個httpClient實例 httpClient = HttpClients.createDefault(); // 創(chuàng)建httpGet遠程連接實例 URL newUrl = new URL(url); HttpGet httpGet = new HttpGet(String.valueOf(newUrl)); // 設置請求頭信息,鑒權 httpGet.setHeader('Authorization', 'Bearer da3efcbf-0845-4fe3-8aba-ee040be542c0') // 設置配置請求參數(shù) RequestConfig requestConfig = RequestConfig.custom()// 連接主機服務超時時間.setConnectTimeout(35000)// 請求超時時間.setConnectionRequestTimeout(35000)// 數(shù)據(jù)讀取超時時間.setSocketTimeout(60000).build(); // 為httpGet實例設置配置 httpGet.setConfig(requestConfig); // 執(zhí)行get請求得到返回對象 response = httpClient.execute(httpGet); // 通過返回對象獲取返回數(shù)據(jù) HttpEntity entity = response.getEntity(); // 通過EntityUtils中的toString方法將結果轉(zhuǎn)換為字符串 if (entity != null) { //按指定編碼轉(zhuǎn)換結果實體為String類型 body = EntityUtils.toString(entity,'utf-8'); } } catch (Exception e) { e.printStackTrace(); } finally { close(response, httpClient); } return body;}

到此這篇關于vue項目中企業(yè)微信使用js-sdk時config和agentConfig配置方式詳解的文章就介紹到這了,更多相關vue項目企業(yè)微信使用js-sdk時config和agentConfig配置內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: 微信
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
色综合www| 日韩成人精品一区二区三区| 国产人成精品一区二区三| 中文字幕av一区二区三区人| 国产99精品一区| 亚洲午夜av| 午夜欧美精品| 日韩一级精品| 最新国产精品视频| 欧美日韩a区| 国产精品久久久一区二区| 国产精品一区二区精品| 国产情侣一区在线| 国产成人免费视频网站视频社区| 国产一区2区| 天堂日韩电影| 免费日韩一区二区| 日韩精品视频网站| 国产欧美一级| 黑人精品一区| 欧美久久天堂| 欧美日韩黑人| 亚洲欧美日韩精品一区二区| 美女被久久久| 日韩黄色免费网站| 久久97久久97精品免视看秋霞| 欧美sm一区| 蜜臀av一区二区三区| 国产精品黄网站| 亚洲黄色免费看| 中文不卡在线| 亚洲精品永久免费视频| 亚洲欧美专区| 九色porny丨国产首页在线| 亚洲专区视频| 麻豆成人在线观看| 免费精品视频| 精品欧美日韩精品| 中文精品在线| 91福利精品在线观看| 欧美日韩在线网站| 国产欧美一级| 日韩午夜精品| 国产伦久视频在线观看| 午夜精品影视国产一区在线麻豆| 国产精品99一区二区三区| 丝袜美腿一区二区三区| 国产成人免费精品| 日韩精品导航| 国产一区日韩一区| 国产亚洲人成a在线v网站| 精品欧美久久| 国产一区二区亚洲| 日韩高清不卡在线| 国产精品日本欧美一区二区三区| 精品99久久| 91精品一区| 亚洲综合精品| 欧美手机在线| 不卡一二三区| 国产精品视频一区二区三区四蜜臂 | 欧美黄页在线免费观看| 欧美特黄一级| 麻豆国产在线| 国产日韩高清一区二区三区在线| 午夜久久黄色| 久久国产欧美| 福利在线免费视频| 久久香蕉精品香蕉| 亚洲v天堂v手机在线| 91久久视频| 99久久精品网| 国产成年精品| 麻豆成人91精品二区三区| 日韩精品中文字幕吗一区二区| 亚州av乱码久久精品蜜桃| 狠狠久久伊人| 国产精品白丝一区二区三区| 亚洲精品自拍| 中文无码久久精品| 中国女人久久久| 欧美日韩国产一区精品一区| 欧美一区二区三区高清视频| 最近高清中文在线字幕在线观看1| 精品黄色一级片| 国产麻豆精品久久| 欧美日韩亚洲一区| 国产精品亚洲综合在线观看| 国产精品一线| 麻豆国产精品一区二区三区| 欧美极品一区二区三区| 国产精品日本一区二区不卡视频 | 香蕉久久一区| 日韩一区免费| 四虎在线精品| 欧美一级网站| 欧美极品中文字幕| 精品国产一区二区三区2021| 欧美国产极品| 精品三级久久久| 日本一区二区高清不卡| 日韩一区电影| 91精品久久久久久久久久不卡| 九色porny丨国产首页在线| 999久久久免费精品国产| 午夜国产精品视频| 亚洲人成毛片在线播放女女| 日韩av中文字幕一区二区三区| 国产精成人品2018| 国产一区福利| 久久九九精品| 亚洲专区一区| 国产一卡不卡| 久久精品国产99国产| 日韩精品影视| 91久久视频| 亚洲精品第一| 久久不见久久见免费视频7| 91一区二区| 亚洲中字黄色| 国产欧美日韩一区二区三区在线| 国产专区精品| 免费毛片在线不卡| 亚洲免费专区| 精品免费av| 一区在线视频观看| 久久国产日韩欧美精品| 日韩免费在线| 蜜臀av性久久久久蜜臀aⅴ流畅| 日韩av网站在线免费观看| 国产精品magnet| 欧美日韩视频网站| 亚洲深深色噜噜狠狠爱网站 | 日本欧洲一区二区| 国产精久久一区二区| 99久久精品网| 亚洲啊v在线免费视频| 成人在线丰满少妇av| 国产精品老牛| 卡一精品卡二卡三网站乱码| 999国产精品999久久久久久| 久久不射网站| 国产日韩三级| 免费精品国产| 国产精品中文字幕制服诱惑| 欧美手机在线| 国产精品美女午夜爽爽| 在线精品小视频| 精品国产一区二区三区2021| 亚洲精选91| 精品国产午夜| 综合日韩在线| 久久久久蜜桃| 国产精品巨作av| 香蕉久久国产| 亚洲一区资源| 国产三级一区| 国产精品97| 久久99高清| 日韩精品一区二区三区免费视频| 三级小说欧洲区亚洲区| 国产精品一二| 一二三区精品| 五月天久久网站| 黄色在线观看www| 国产欧美三级| 亚洲精品自拍| 欧美专区18| 女人av一区| 一区二区精品伦理...| 国产精品一区二区av交换| 中文精品电影| 久久久噜噜噜| 精品久久久网| 日韩福利视频一区| 亚洲欧美日韩精品一区二区| 久久久久久久久久久9不雅视频| 国产精品二区影院| 综合欧美精品| 久热综合在线亚洲精品| 午夜久久黄色| 精品国模一区二区三区| 国产精东传媒成人av电影| 婷婷五月色综合香五月| 伊人久久成人| 亚州av乱码久久精品蜜桃| 丝袜诱惑一区二区| 国产精品一页| 国产欧美三级| 欧美日本久久| 欧美亚洲一级| 97久久亚洲| 亚欧洲精品视频在线观看| 中文字幕亚洲精品乱码| 免费看精品久久片| 日韩一区精品字幕| 美女久久网站| 中文一区一区三区免费在线观 | 国产美女视频一区二区| 欧美亚洲tv|