中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#調用微信接口的相關代碼

發布時間:2020-10-01 20:20:03 來源:腳本之家 閱讀:177 作者:小熊吉米 欄目:編程語言

調用微信接口前需要準備的內容。

  1.微信公眾平臺的appid

  2.微信公眾平臺的secret

  3..獲取tokenid

  4.獲取ticket

  5.生成簽名的隨機串

  6.生成簽名的時間戳

  7.生成簽名

具體內容:

1.微信公眾平臺的appid

2.微信公眾平臺的secret

這兩者需要登錄到申請的微信公眾平臺中去獲取,建議寫在配置文件中

3.獲取tokenid

public static string GetWxTokenId()
    {
      string token = "";
      string url = string.Format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", appid, secret);
      //向上面的地址發起httpget請求
      //這里是封裝的一個http請求的類
      string content = HttpHelper.HttpGet(url);
      if (!string.IsNullOrEmpty(content))
      {
        var obj = JsonConvert.DeserializeObject<TokenResult>(content);
        if (!obj.errcode.HasValue)
        {
          token = obj.access_token;
        }
      }
      return token;
    }

這里是獲取微信tokenid的返回對象

private class TokenResult
    {
      public string access_token { get; set; }
      public string expires_in { get; set; }
      public int? errcode { get; set; }
      public string errmsg { get; set; }
    }


注意:在每個微信公眾號中獲取tokenid的次數是有限的,所以應該將獲取到的tokenid儲存起來,以便后續使用。我使用的方法是將tokenid存儲在數據庫中,所以在每次使用之前都要做判斷處理

/*tokenid保存方式說明:
*可在數據庫中創建表:SysConfig(用戶存儲項目中的配置數據)
* 字段:
* ConfigKey:用于查詢該條數據的key,做為主鍵
* ConfigValue:存儲數據的值
* TypeName:該條配置數據的名稱
* Description:說明
* CreateTime:創建時間
* LastModifyTime:上次修改的時間
* AllowEdit:是否可編輯
* LastValue:上一次的值
* tokenid的有效時間是兩個小時=7200秒,每重新獲取一次就更新一次LastModifyTime的值,將LastModifyTime和當前時間進行比對,如果小于7200秒則可以不用再次獲取,反之則需要再次從微信獲取。
*/

===================================================================================================

4.獲取ticket。需要上一步中獲取到的tokenid。

/// <summary>
 /// 獲取ticket
 /// </summary>
 /// <param name="token">獲取到的tokenid</param>
 /// <returns>strticket</returns>
 public static string GetTicket(string token)
 {
      string getticketurl = string.Format("https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token={0}&type=jsapi", token);
      string content = HttpHelper.HttpGet(getticketurl);
      JsApiTicket obj = JsonConvert.DeserializeObject<JsApiTicket>(content);
      return obj.ticket;
 }

5.生成簽名的隨機串

//生成簽名的隨機串
string noncestr = Guid.NewGuid().ToString().Replace("-", "");

6.生成簽名的時間戳

TimeSpan ts = DateTime.UtcNow - new DateTime(1970, 1, 1, 0, 0, 0, 0);
string timestamp = Convert.ToInt64(ts.TotalSeconds).ToString();

7.生成簽名

string signature = MakeSha1Sign(string.Format("jsapi_ticket={0}&noncestr={1}&timestamp={2}&url={3}", jsapi_ticket, noncestr, timestamp, url));
/// <summary>
    /// SDK生成簽名
    /// 注意:需要引用System.Security.dll
    /// </summary>
    /// <param name="str"></param>
    /// <returns>str簽名</returns>
    public static string MakeSha1Sign(string str)
    {
      byte[] StrRes = Encoding.Default.GetBytes(str);
      HashAlgorithm iSHA = new SHA1CryptoServiceProvider();
      StrRes = iSHA.ComputeHash(StrRes);
      StringBuilder EnText = new StringBuilder();
      foreach (byte iByte in StrRes)
      {
        EnText.AppendFormat("{0:x2}", iByte);
      }
      return EnText.ToString();
    }

最后可以將這些步驟封裝在一個方法中

/// <summary>
    /// 獲取調用微信接口用的SDKConfig
    /// </summary>
    /// <param name="url"></param>
    /// <returns>SDKConfig整個對象</returns>
    public static JsApiConfig GetJsSdkConfig(string url)
    {
      //獲取tokenid
      string access_token = GetWxTokenId();
      //獲取ticket
      string jsapi_ticket = GetTicket(access_token);
      //生成簽名的隨機串
      string noncestr = Guid.NewGuid().ToString().Replace("-", "");
      //生成簽名的時間戳
      TimeSpan ts = DateTime.UtcNow - new DateTime(1970, 1, 1, 0, 0, 0, 0);
      string timestamp = Convert.ToInt64(ts.TotalSeconds).ToString();
      //簽名
      string signature = MakeSha1Sign(string.Format("jsapi_ticket={0}&noncestr={1}&timestamp={2}&url={3}", jsapi_ticket, noncestr, timestamp, url));

      JsApiConfig config = new JsApiConfig()
      {
        appId = appid,
        debug = false,
        nonceStr = noncestr,
        timestamp = timestamp,
        signature = signature,
        ticket = jsapi_ticket,
        //需要使用的JS接口列表
        jsApiList = new string[] { "chooseImage", "previewImage", "uploadImage", "downloadImage" }

      };
      return config;


    }

頁面上面調用我們上面配置好的內容

$.post('/WapCardInfo/GetSDKConfig', { url: location.href.split('#')[0] }, function (data) {
  var configObj = data;

      wx.config({
        debug: false, // 開啟調試模式,調用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數,可以在pc端打開,參數信息會通過log打出,僅在pc端時才會打印。
        appId: configObj.appId, // 必填,公眾號的唯一標識
        timestamp: configObj.timestamp, // 必填,生成簽名的時間戳
        nonceStr: configObj.nonceStr, // 必填,生成簽名的隨機串
        signature: configObj.signature, // 必填,簽名,見附錄1
        jsApiList: [
                'checkJsApi',
                'onMenuShareTimeline',
                'onMenuShareAppMessage',
                'onMenuShareQQ',
                'onMenuShareWeibo',
                'onMenuShareQZone'
        ] // 必填,需要使用的JS接口列表,所有JS接口列表見附錄2
      });
});

請求的后臺代碼

[HttpPost]
    public JsonResult GetSDKConfig(string url)
    {
      try
      {
  //這里就是調用上面封裝的方法
        JsSdkApi.jsapiConfig model = JsSdkApi.GetJsSdkConfig(url);
        return Json(model);
      }
      catch (Exception ex)
      {
        LogHelper.Error("獲取wxconfig出現異常:" + ex.Message.Replace("'", "\""));
        return Json(new JsSdkApi.jsapiConfig());
      }
    }

至于需要的接口就去微信公眾平臺開發者文檔中去查看啦。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

鄂温| 玉山县| 广灵县| 那坡县| 襄樊市| 长兴县| 乌鲁木齐县| 施秉县| 古丈县| 蕲春县| 广宗县| 普兰县| 丹东市| 壤塘县| 长海县| 旺苍县| 梨树县| 凤庆县| 堆龙德庆县| 迁西县| 吉安县| 刚察县| 石狮市| 体育| 化隆| 太原市| 惠来县| 延边| 双桥区| 贡觉县| 宝清县| 客服| 黄陵县| 泽库县| 成武县| 封丘县| 杂多县| 綦江县| 彭水| 安阳市| 合作市|