真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些

這篇文章給大家分享的是有關C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)公司是專業(yè)的子洲網(wǎng)站建設公司,子洲接單;提供網(wǎng)站設計、成都網(wǎng)站設計,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行子洲網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

1、微信自定義菜單的分類

微信對自定義菜單的要求:目前自定義菜單最多包括3個一級菜單,每個一級菜單最多包含5個二級菜單。一級菜單最多4個漢字,二級菜單最多7個漢字,多出來的部分將會以“...”代替。

根據(jù)菜單的分類,我們可以把它通過圖形進行分類展示:

C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些

我對各種微信公眾號進行了解,發(fā)現(xiàn)多數(shù)賬號采用的都是普通的View類型的菜單鏈接方式,通過它們鏈接到自己的微網(wǎng)站上,但也有一些做的好的,如省立中山圖書館,就能通過重定向的方式,提供一個綁定圖書館用戶和微信OpenID的入口,綁定后,用戶就可以查看借閱的書籍,然后可以通過一鍵續(xù)借功能實現(xiàn)圖書的快速續(xù)借功能。

對于這種重定向類型的Url菜單事件,微信的說明如下:

如果用戶在微信中(Web微信除外)訪問公眾號的第三方網(wǎng)頁,公眾號開發(fā)者可以通過此接口獲取當前用戶基本信息(包括昵稱、性別、城市、國家)。利用用戶信息,可以實現(xiàn)體驗優(yōu)化、用戶來源統(tǒng)計、帳號綁定、用戶身份鑒權等功能。請注意,“獲取用戶基本信息接口是在用戶和公眾號產(chǎn)生消息交互時,才能根據(jù)用戶OpenID獲取用戶基本信息,而網(wǎng)頁授權的方式獲取用戶基本信息,則無需消息交互,只是用戶進入到公眾號的網(wǎng)頁,就可彈出請求用戶授權的界面,用戶授權后,就可獲得其基本信息(此過程甚至不需要用戶已經(jīng)關注公眾號。)”

C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些

2、重定向類型菜單的URL

上面說了,重定向類型的菜單分為了兩種,其實他們也僅僅是參數(shù)Scope類型的不同,其他部分也還是一樣的。

為了展示,我們在假設用戶單擊菜單的時候,切換到http://www.iqidi.com/testwx.ashx這個頁面,并帶過來當前用戶的OpenID等參數(shù)信息

對于scope=snsapi_base方式的鏈接如下:

https://open.weixin.qq.com/connect/oauth3/authorize?appid=wx3d81fc2886d86526&redirect_uri=http%3A%2F%2Fwww.iqidi.com%2Ftestwx.ashx&response_type=code&scope=snsapi_base&state=123#wechat_redirect

而對于scope=snsapi_userinfo方式的鏈接如下:

https://open.weixin.qq.com/connect/oauth3/authorize?appid=wx3d81fc2886d86526&redirect_uri=http%3A%2F%2Fwww.iqidi.com%2Ftestwx.ashx&response_type=code&scope=snsapi_userinfo&state=123#wechat_redirect

不過他們給手機客戶端的體驗是不同的,第一種可以平滑切換,但是第二種會彈出一個對話框供用戶確認才能繼續(xù)。

C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些

為了演示上面兩種獲取數(shù)據(jù)的不同,我把他們傳過來的code的值,用戶換取OpenID后進行用戶信息的解析,他們兩者的結果都是一樣了。具體測試界面如下所示。

C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些

其中TestWX.ashx的頁面后臺代碼如下所示:

    /// 
    /// TestWX 的摘要說明    /// 
    public class TestWX : IHttpHandler
    {        string appId = ""; //換成你的信息
        string appSecret = ""; //換成你的信息

        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";            string content = "";            if (context.Request != null && context.Request.Url != null)
            {
                NameValueCollection list = HttpUtility.ParseQueryString(context.Request.Url.Query);                foreach (string key in list.AllKeys)
                {
                    content += string.Format("{0}:{1} \r\n", key, list[key]);
                }
            }            string code = context.Request.QueryString["code"] ?? "";            if (!string.IsNullOrEmpty(code))
            {
                IBasicApi api = new BasicApi();                try
                {
                    AppConfig config = new AppConfig();
                    appId = config.AppConfigGet("AppId");//從配置中獲取微信程序ID
                    appSecret = config.AppConfigGet("AppSecret");//從配置中獲取微信程序秘鑰
                    AccessTokenResult result = api.GetAccessToken(appId, appSecret, code);                    if (result != null)
                    {
                        content += string.Format("openid:{0}\r\n", result.openid);                        string token = api.GetAccessToken(appId, appSecret);
                        IUserApi userApi = new UserApi();
                        UserJson userDetail = userApi.GetUserDetail(token, result.openid);                        if (userDetail != null)
                        {
                            content += string.Format("nickname:{0}  sex:{1}\r\n", userDetail.nickname, userDetail.sex);
                            content += string.Format("Location:{0} {1} {2} {3}\r\n", userDetail.country, userDetail.province, userDetail.city, userDetail.language);
                            content += string.Format("HeadUrl:{0} \r\n", userDetail.headimgurl);
                            content += string.Format("subscribe:{0},{1}\r\n", (userDetail.subscribe == 1) ? "已訂閱" : "未訂閱", userDetail.subscribe_time.GetDateTime());
                        }
                    }
                }                catch { }
            }

            context.Response.Write(content);
        }

在上面的代碼中,我主要分為幾步,一個是打印當前用戶重定向過來的鏈接的參數(shù)信息,代碼如下。

                NameValueCollection list = HttpUtility.ParseQueryString(context.Request.Url.Query);                foreach (string key in list.AllKeys)
                {
                    content += string.Format("{0}:{1} \r\n", key, list[key]);
                }

然后獲取到Code參數(shù)后,通過API接口,獲取AccessTokenResult的數(shù)據(jù),這里面有用戶的OpenID

AccessTokenResult result = api.GetAccessToken(appId, appSecret, code);

當正常調(diào)用后,我們把用戶標識的OpenID進一步進行解析,調(diào)用API獲取用戶的詳細信息,具體代碼如下所示。

UserJson userDetail = userApi.GetUserDetail(token, result.openid);

當我們把用戶的相關信息獲取到了,就可以做各種用戶信息的展示了,如下代碼所示。

                        if (userDetail != null)
                        {
                            content += string.Format("nickname:{0}  sex:{1}\r\n", userDetail.nickname, userDetail.sex);
                            content += string.Format("Location:{0} {1} {2} {3}\r\n", userDetail.country, userDetail.province, userDetail.city, userDetail.language);
                            content += string.Format("HeadUrl:{0} \r\n", userDetail.headimgurl);
                            content += string.Format("subscribe:{0},{1}\r\n", (userDetail.subscribe == 1) ? "已訂閱" : "未訂閱", userDetail.subscribe_time.GetDateTime());
                        }

3、重定向鏈接菜單的用途

這種菜單就是需要指定域名,在微信后臺中進行設置,重定向的鏈接必須屬于這個域名之中,否則不會轉(zhuǎn)到你希望的鏈接。

這個方式,讓我們的微信應用程序后臺可以獲得用戶的標識、用戶詳細信息等,我們就可以用來綁定和用戶相關的業(yè)務信息了,如上面提到的圖書館借閱信息,送水客戶的信息,客戶的積分信息,或者可以和后臺賬號進行關聯(lián)實現(xiàn)更加復雜的應用等。用戶的身份信息如此重要,如果結合到我們的CRM系統(tǒng)、業(yè)務管理系統(tǒng),就可以發(fā)揮用戶信息應用的作用了。

感謝各位的閱讀!關于“C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


網(wǎng)站欄目:C#如何實現(xiàn)微信菜單的表現(xiàn)形式有哪些
新聞來源:http://weahome.cn/article/jdicig.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部