官方文檔是微信JS-SDK的使用步驟http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html#JSSDK.E4.BD.BF.E7.94.A8.E6.AD.A5.E9.AA.A4html
,不少人在config接口注入權限驗證配置的時候出現signature(簽名無效),在這把本身開發的代碼分享一下jquery
1、驗證權限咱們須要獲取四個參數appId、timestamp、nonceStr、signature
參數獲取詳細見官方文檔:http://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html#.E9.99.84.E5.BD.951-JS-SDK.E4.BD.BF.E7.94.A8.E6.9D.83.E9.99.90.E7.AD.BE.E5.90.8D.E7.AE.97.E6.B3.95
注意:①access_token獲取方法見我以前的的文章http://www.cnblogs.com/net-xiejun/p/4422890.html
②jsapi_ticket獲取到jsapi_ticket有效時間爲7200s,由於天天獲取的jsapi_ticket數量有限,因此也必須緩存,方法見代碼
CS代碼:
1 #region 驗證JsApi權限配置 2 /// <summary> 3 /// 獲取JsApi權限配置的數組/四個參數 4 /// </summary> 5 /// <returns></returns> 6 public string GetJsApiInfo(string Appid, string Appsecret) 7 { 8 string timestamp = CommonMethod.ConvertDateTimeInt(DateTime.Now).ToString();//生成簽名的時間戳 9 string nonceStr = CommonMethod.GetRandCode(16);//生成簽名的隨機串 10 string url = System.Web.HttpContext.Current.Request.Url.AbsoluteUri.ToString();//當前的地址 11 string jsapi_ticket = ""; 12 //ticket 緩存7200秒 13 if (System.Web.HttpContext.Current.Session["jsapi_ticket"] == null) 14 { 15 jsapi_ticket = CommonMethod.WebRequestPostOrGet("https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=" + BasicApi.GetTokenSession(Appid, Appsecret) + "&type=jsapi", ""); 16 System.Web.HttpContext.Current.Session["jsapi_ticket"] = jsapi_ticket; 17 System.Web.HttpContext.Current.Session.Timeout = 7200; 18 } 19 else 20 { 21 jsapi_ticket = System.Web.HttpContext.Current.Session["jsapi_ticket"].ToString(); 22 } 23 Dictionary<string, object> respDic = (Dictionary<string, object>)Jss.DeserializeObject(jsapi_ticket); 24 jsapi_ticket = respDic["ticket"].ToString();//獲取ticket 25 string[] ArrayList = { "jsapi_ticket=" + jsapi_ticket, "timestamp=" + timestamp, "noncestr=" + nonceStr, "url=" + url }; 26 Array.Sort(ArrayList); 27 string signature = string.Join("&", ArrayList); 28 signature = FormsAuthentication.HashPasswordForStoringInConfigFile(signature, "SHA1").ToLower(); 29 return "{\"appId\":\"" + Appid + "\", \"timestamp\":" + timestamp + ",\"nonceStr\":\"" + nonceStr + "\",\"signature\":\"" + signature + "\"}"; 30 } 31 #endregion
1 /*! 2 * http://xxxxx.com/ 謝俊我的博客 3 * 使用前須要配置安全域名 在公衆號後臺微信功能設置 4 * 引用js文件 http://res.wx.qq.com/open/js/jweixin-1.0.0.js 還有 jquery.js 5 * Copyright 2015,謝俊 6 * 時間:2015年6月9號 10:18 7 */ 8 function wxconfig(data) { 9 wx.config({ 10 debug: false, // 開啓調試模式,調用的全部api的返回值會在客戶端alert出來,若要查看傳入的參數,能夠在pc端打開,參數信息會經過log打出,僅在pc端時纔會打印。 11 appId: data.appId, // 必填,公衆號的惟一標識 12 timestamp: data.timestamp, // 必填,生成簽名的時間戳 13 nonceStr: data.nonceStr, // 必填,生成簽名的隨機串 14 signature: data.signature,// 必填,簽名,見附錄1 15 jsApiList: [ 16 'checkJsApi', 17 'onMenuShareTimeline', 18 'onMenuShareAppMessage', 19 'onMenuShareQQ', 20 'onMenuShareWeibo', 21 'hideMenuItems', 22 'showMenuItems', 23 'hideAllNonBaseMenuItem', 24 'showAllNonBaseMenuItem', 25 'translateVoice', 26 'startRecord', 27 'stopRecord', 28 'onRecordEnd', 29 'playVoice', 30 'pauseVoice', 31 'stopVoice', 32 'uploadVoice', 33 'downloadVoice', 34 'chooseImage', 35 'previewImage', 36 'uploadImage', 37 'downloadImage', 38 'getNetworkType', 39 'openLocation', 40 'getLocation', 41 'hideOptionMenu', 42 'showOptionMenu', 43 'closeWindow', 44 'scanQRCode', 45 'chooseWXPay', 46 'openProductSpecificView', 47 'addCard', 48 'chooseCard', 49 'openCard' 50 ] // 必填,須要使用的JS接口列表,全部JS接口列表見附錄2 51 }); 52 } 53 54 wx.ready(function () { 55 //是否支持js接口 56 document.querySelector('#checkJsApi').onclick = function () { 57 wx.checkJsApi({ 58 jsApiList: [ 59 'onMenuShareTimeline', 60 'onMenuShareAppMessage', 61 'onMenuShareQQ', 62 'onMenuShareWeibo' 63 ], 64 success: function (res) { 65 alert(JSON.stringify(res)); 66 } 67 }); 68 }; 69 })
<script> var data = '@Html.Raw(ViewData["JsApiirray"].ToString())'; data = eval("(" + data + ")");//實例化 wxconfig(data); </script>
注:JsApiirray爲後臺調用GetJsApiInfo方法獲取的json格式的字符串"{\"appId\":\"" + Appid + "\", \"timestamp\":" + timestamp + ",\"nonceStr\":\"" + nonceStr + "\",\"signature\":\"" + signature + "\"}";git
源碼下載:https://github.com/xiejun-net/weixingithub
若有疑問加我qq諮詢405877988 json
本文版權歸做者(謝俊)和博客園全部,歡迎轉載,轉載請標明出處。api
原文地址:http://www.cnblogs.com/net-xiejun/數組
完整源碼下載:https://github.com/xiejun-net/weixin安全
我的公衆帳號:微信