• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當前位置:雨林木風下載站 > 網絡軟件教程 > 詳細頁面

        微信分享技巧的開發

        微信分享技巧的開發

        更新時間:2025-09-20 文章作者:未知 信息來源:網絡 閱讀次數:

        微信(WeChat)是騰訊公司于2011年1月21日推出的一個為智能終端提供即時通訊服務的免費應用程序,由張小龍所帶領的騰訊廣州研發中心產品團隊打造 [2] 。微信支持跨通信運營商、跨操作系統平臺...
        微信(WeChat)是騰訊公司于2011年1月21日推出的一個為智能終端提供即時通訊服務的免費應用程序,由張小龍所帶領的騰訊廣州研發中心產品團隊打造 [2] 。微信支持跨通信運營商、跨操作系統平臺通過網絡快速發送免費(需消耗少量網絡流量)語音短信、視頻、圖片和文字,同時,也可以使用通過共享流媒體內容的資料和基于位置的社交插件“搖一搖”、“漂流瓶”、“朋友圈”、”公眾平臺“、”語音記事本“等服務插件。
        這次給大家帶來微信分享功能的開發,微信分享功能開發的注意事項有哪些,下面就是實戰案例,一起來看一下。

        內嵌在微信中的網頁,右上角都會有一個默認的分享功能。如下圖所示,第一個為自定義的效果,第二個為默認的效果。實現了自定義的分享鏈接是不是更讓人有點擊的欲望?下面講解下開發的過程。

        微信分享功能的開發

        一、準備,設置js接口安全域名

        這需要使用微信的jssdk,先需要在微信公眾號后臺進行設置:公眾號設置-->功能設置-->JS接口安全域名。打開這個頁面之后你會看到下面的提示。需要先下載這個文件并上傳到指定域名的根目錄。

        微信分享功能的開發

        這個文件里面是一個字符串,從名稱看是用來校驗用的。先上傳了這個文件,你才能保存成功。這樣你就可以使用jssdk了。

        二、前端配置

        首先要說明的是分享功能是一個配置功能,綁定在按鈕的click事件中是沒有效果的。也就是說只有點擊右上角的分享才有效果(有的文字內容分享不知道是怎么實現的)。官方的js有四個步驟,首先是引入jssdk:

        <script src="http://res.wx.qq.com/open/js/jweixin-1.1.0.js"></script>

        根據官方的配置參數,我們可以定義一個WXShareModel對象:

           public class WXShareModel
            {        public string appId { get; set; }        public string nonceStr { get; set; }        public long timestamp { get; set; }        public string signature { get; set; }        public string ticket { get; set; }        public string url { get; set; }        public void MakeSign()
                {             var string1Builder = new StringBuilder();
                     string1Builder.Append("jsapi_ticket=").Append(ticket).Append("&")
                                  .Append("noncestr=").Append(nonceStr).Append("&")
                                  .Append("timestamp=").Append(timestamp).Append("&")
                                  .Append("url=").Append(url.IndexOf("#") >= 0 ? url.Substring(0, url.IndexOf("#")) : url);            var string1 = string1Builder.ToString();
                    signature = Util.Sha1(string1, Encoding.Default);
                }
            }

        然后是進行配置:

        wx.config({
                debug: true, // 開啟調試模式,調用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數,可以在pc端打開,參數信息會通過log打出,僅在pc端時才會打印。
                appId: '@Model.appId', // 必填,公眾號的唯一標識
                timestamp: '@Model.timestamp', // 必填,生成簽名的時間戳
                nonceStr: '@Model.nonceStr', // 必填,生成簽名的隨機串
                signature: '@Model.signature',// 必填,簽名,見附錄1
                jsApiList: ["checkJsApi", "onMenuShareTimeline", "onMenuShareAppMessage", "onMenuShareQQ", "onMenuShareQZone"] // 必填,需要使用的JS接口列表,所有JS接口列表見附錄2    });
            wx.ready(function () {
                document.querySelector('#checkJsApi').onclick = function () {
                    wx.checkJsApi({
                        jsApiList: [            'getNetworkType',            'previewImage'
                        ],
                        success: function (res) {
                            alert(JSON.stringify(res));
                        }
                    });
                };
            //朋友圈        wx.onMenuShareTimeline({
                    title: '暖木科技', // 分享標題
                    link: 'http://www.warmwood.com/home/lampindex', // 分享鏈接
                    imgUrl: 'http://www.warmwood.com/images/s1.jpg',
                    success: function (res) {
                        alert('已分享');
                    },
                    cancel: function (res) {
                        alert('已取消');
                    },
                    fail: function (res) {
                        alert(JSON.stringify(res));
                    }
                });        //朋友        wx.onMenuShareAppMessage({
                    title: '暖木科技', // 分享標題
                    desc: '寶寶的睡眠很重要,你的睡眠也很重要', // 分享描述
                    link: 'http://www.warmwood.com/home/lampindex', // 分享鏈接
                    imgUrl: 'http://www.warmwood.com/images/s1.jpg', // 分享圖標
                    type: '', // 分享類型,music、video或link,不填默認為link
                    dataUrl: '', // 如果type是music或video,則要提供數據鏈接,默認為空
                    success: function () {                // 用戶確認分享后執行的回調函數
                        alert("分享");
                    },
                    cancel: function () {                // 用戶取消分享后執行的回調函數
                        alert("取消分享");
                    }
                });
            });

        然后剩下就是后端的事情了。后端的關鍵是獲取access_token和jsapi_ticket以及生成正確的簽名。另外如果要統計分享的數量,最好就是在success方法中進行統計了。

        三、生成簽名

        1.access_token

        獲取access_token方法全平臺都是一致的。

        public const string AccessTokenUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}";
         public TokenResult GetAccessToken()
                {            var url = string.Format(WxDeviceConfig.AccessTokenUrl, WxDeviceConfig.AppId, WxDeviceConfig.APPSECRET);            var res = SendHelp.Send<TokenResult>(null, url, null, CommonJsonSendType.GET);            return res;
                }

        access_token的超時時間是7200秒,所以先可以緩存起來。SendHelp文章末尾可下載

        2.獲取jsapi_ticket

        access_token的作用就是為了獲取jsapi_ticket。用get方式獲取,url:https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=jsapi,返回的JSON對象如下。

        {"errcode":0,"errmsg":"ok","ticket":"bxLdikRXVbTPdHSM05e5u5sUoXNKd8-41ZO3MhKoyN5OfkWITDGgnr2fwJ0m9E8NYzWKVZvdVtaUgWvsdshFKA","expires_in":7200}

        所以可以定義一個模型:

        public class jsapiTicketModel
            {        public string errcode { get; set; }        public string errmsg { get; set; }        public string ticket { get; set; }        public string expires_in { get; set; }
            }

        再完成獲取ticket的方法:

         public jsapiTicketModel GetJsApiTicket(string accessToken)
                {            var url = string.Format(WxPayConfig.Jsapi_ticketUrl, accessToken);            return SendHelp.Send<jsapiTicketModel>(accessToken, url, "", CommonJsonSendType.GET);
                }

        ticket過期時間也是7200秒,并且不能頻繁的請求,所以也需要再服務端緩存起來。

         private void setCacheTicket(string cache)
                {
                    _cacheManager.Set(tokenKey, cache, 7200);
                }

        MemoryCacheManager:

        View Code

        3.簽名

        終于到這一步了,然后你在文檔中看到讓你失望的一幕:

        微信分享功能的開發

        么有C#的demo,支付那邊都提供了,為啥jssdk沒有提供,好吧先不吐槽了。官方也說明白簽名的規則。一開始我使用的是https://github.com/night-king/weixinSDK中的簽名:

         public static string Sha1(string orgStr, string encode = "UTF-8")
                {            var sha1 = new SHA1Managed();            var sha1bytes = System.Text.Encoding.GetEncoding(encode).GetBytes(orgStr);            byte[] resultHash = sha1.ComputeHash(sha1bytes);            string sha1String = BitConverter.ToString(resultHash).ToLower();
                    sha1String = sha1String.Replace("-", "");            return sha1String;
                }//錯誤示例

        得出的結果和官方校驗的不一致,一直提示簽名錯誤。

        微信分享功能的開發

        正確的寫法是:

        public static string Sha1(string orgStr, Encoding encode)
                {
                    SHA1 sha1 = new SHA1CryptoServiceProvider();            byte[] bytes_in = encode.GetBytes(orgStr);            byte[] bytes_out = sha1.ComputeHash(bytes_in);
                    sha1.Dispose();            string result = BitConverter.ToString(bytes_out);
                    result = result.Replace("-", "");            return result;  
                }

        和官方校驗的結果一直后,就ok了(忽略大小寫)。另外一個需要注意的地方是簽名中的url。如果頁面有參數,model中的url也需要帶參數,#號后面的不要。不然也是會報簽名錯誤。

         public ActionResult H5Share()
                {            var model = new WXShareModel();
                    model.appId = WxPayConfig.APPID;
                    model.nonceStr = WxPayApi.GenerateNonceStr();
                    model.timestamp = Util.CreateTimestamp();
                    model.ticket = GetTicket();
                    model.url = "http://www.warmwood.com/AuthWeiXin/share";// domain + Request.Url.PathAndQuery;            model.MakeSign();
                    Logger.Debug("獲取到ticket:" + model.ticket);
                    Logger.Debug("獲取到簽名:" + model.signature);            return View(model);
                }

        四、小結

        wx.config中的debug為true會alert各種操作結果。參數正確之后界面會提示:

        微信分享功能的開發

        至此,分享的功能就ok了。也就打開了調用其他jssdk的大門。另外文中的SendHelp對象是用的Senparc (基于.net4.5)的dll。

        相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

        推薦閱讀:

        webpack自動刷新與解析的使用

        H5的緩存Manifest的使用

        以上就是微信分享功能的開發的詳細內容,更多請關注php中文網其它相關文章!


        微信提供公眾平臺、朋友圈、消息推送等功能,用戶可以通過“搖一搖”、“搜索號碼”、“附近的人”、掃二維碼方式添加好友和關注公眾平臺,同時微信將內容分享給好友以及將用戶看到的精彩內容分享到微信朋友圈。

        溫馨提示:喜歡本站的話,請收藏一下本站!

        本類教程下載

        系統下載排行

        主站蜘蛛池模板: 久久美女网站免费| 一级毛片在线播放免费| 男人的天堂网免费网站| 亚洲日韩国产一区二区三区| 羞羞视频免费网站日本| 日韩视频在线免费| 日韩精品无码人妻免费视频| 中文字幕无码精品亚洲资源网久久| 亚洲s码欧洲m码吹潮| 日本在线看片免费| 亚洲国产成人片在线观看| 亚洲欧洲无码AV不卡在线| 精品久久久久久久免费人妻| 亚洲精品成a人在线观看☆| 日本免费网站观看| 一级毛片在线播放免费| 亚洲精品无码乱码成人| 免费看又黄又无码的网站| 亚洲一级黄色大片| 日本a级片免费看| 国产成人无码免费网站| 久久久久亚洲av无码尤物| 国产AV无码专区亚洲AV麻豆丫| 久久成人免费播放网站| 亚洲视频在线观看地址| 国产成人免费爽爽爽视频| 337P日本欧洲亚洲大胆艺术图| 亚洲日韩人妻第一页| 日韩精品极品视频在线观看免费| 亚洲最大成人网色| 免费一区二区三区| 亚洲成人免费在线观看| 国产大片51精品免费观看| 好猛好深好爽好硬免费视频| 亚洲狠狠综合久久| 久久www免费人成精品香蕉| 亚洲视频在线播放| 国产在线a不卡免费视频| 毛片在线全部免费观看| 在线观看亚洲AV日韩A∨| 国产亚洲成归v人片在线观看|