C#開發(fā)微信門戶及應(yīng)用(11)--微信菜單的多種表現(xiàn)方式介紹
當(dāng)前位置:點(diǎn)晴教程→知識管理交流
→『 技術(shù)文檔交流 』
在前面一系列文章中,我們可以看到微信自定義菜單的重要性,可以說微信公眾號賬號中,菜單是用戶的第一印象,我們要規(guī)劃好這些菜單的內(nèi)容,布局等信息。根據(jù)微信菜單的定義,我們可以看到,一般菜單主要分為兩種,一種是普通的Url菜單(類型為View的菜單),一種是事件菜單(類型為Click的菜單),一般情況下,微信的Url菜單,是無法獲得用戶的任何信息的,但微信用戶信息非常重要,因此也提供了另外一種方式(類似重定向的方式)來給我們使用,本篇主要介紹這種重新定向的方式菜單的使用,以使我們能夠盡可能和用戶進(jìn)行交互。 1、微信自定義菜單的分類微信對自定義菜單的要求:目前自定義菜單最多包括3個一級菜單,每個一級菜單最多包含5個二級菜單。一級菜單最多4個漢字,二級菜單最多7個漢字,多出來的部分將會以“...”代替。 根據(jù)菜單的分類,我們可以把它通過圖形進(jìn)行分類展示: 我對各種微信公眾號進(jìn)行了解,發(fā)現(xiàn)多數(shù)賬號采用的都是普通的View類型的菜單鏈接方式,通過它們鏈接到自己的微網(wǎng)站上,但也有一些做的好的,如省立中山圖書館,就能通過重定向的方式,提供一個綁定圖書館用戶和微信OpenID的入口,綁定后,用戶就可以查看借閱的書籍,然后可以通過一鍵續(xù)借功能實(shí)現(xiàn)圖書的快速續(xù)借功能。 對于這種重定向類型的Url菜單事件,微信的說明如下: 如果用戶在微信中(Web微信除外)訪問公眾號的第三方網(wǎng)頁,公眾號開發(fā)者可以通過此接口獲取當(dāng)前用戶基本信息(包括昵稱、性別、城市、國家)。利用用戶信息,可以實(shí)現(xiàn)體驗(yàn)優(yōu)化、用戶來源統(tǒng)計(jì)、帳號綁定、用戶身份鑒權(quán)等功能。請注意,“獲取用戶基本信息接口是在用戶和公眾號產(chǎn)生消息交互時,才能根據(jù)用戶OpenID獲取用戶基本信息,而網(wǎng)頁授權(quán)的方式獲取用戶基本信息,則無需消息交互,只是用戶進(jìn)入到公眾號的網(wǎng)頁,就可彈出請求用戶授權(quán)的界面,用戶授權(quán)后,就可獲得其基本信息(此過程甚至不需要用戶已經(jīng)關(guān)注公眾號。)” 2、重定向類型菜單的URL上面說了,重定向類型的菜單分為了兩種,其實(shí)他們也僅僅是參數(shù)Scope類型的不同,其他部分也還是一樣的。 為了展示,我們在假設(shè)用戶單擊菜單的時候,切換到http://www.iqidi.com/testwx.ashx這個頁面,并帶過來當(dāng)前用戶的OpenID等參數(shù)信息 對于scope=snsapi_base方式的鏈接如下: https://open.weixin.qq.com/connect/oauth2/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/oauth2/authorize?appid=wx3d81fc2886d86526&redirect_uri=http%3A%2F%2Fwww.iqidi.com%2Ftestwx.ashx&response_type=code&scope=snsapi_userinfo&state=123#wechat_redirect 不過他們給手機(jī)客戶端的體驗(yàn)是不同的,第一種可以平滑切換,但是第二種會彈出一個對話框供用戶確認(rèn)才能繼續(xù)。 為了演示上面兩種獲取數(shù)據(jù)的不同,我把他們傳過來的code的值,用戶換取OpenID后進(jìn)行用戶信息的解析,他們兩者的結(jié)果都是一樣了。具體測試界面如下所示。 其中TestWX.ashx的頁面后臺代碼如下所示: /// <summary> 在上面的代碼中,我主要分為幾步,一個是打印當(dāng)前用戶重定向過來的鏈接的參數(shù)信息,代碼如下。 NameValueCollection list = HttpUtility.ParseQueryString(context.Request.Url.Query); 然后獲取到Code參數(shù)后,通過API接口,獲取AccessTokenResult的數(shù)據(jù),這里面有用戶的OpenID AccessTokenResult result = api.GetAccessToken(appId, appSecret, code); 當(dāng)正常調(diào)用后,我們把用戶標(biāo)識的OpenID進(jìn)一步進(jìn)行解析,調(diào)用API獲取用戶的詳細(xì)信息,具體代碼如下所示。 UserJson userDetail = userApi.GetUserDetail(token, result.openid); 當(dāng)我們把用戶的相關(guān)信息獲取到了,就可以做各種用戶信息的展示了,如下代碼所示。 if (userDetail != null) 3、重定向鏈接菜單的用途這種菜單就是需要指定域名,在微信后臺中進(jìn)行設(shè)置,重定向的鏈接必須屬于這個域名之中,否則不會轉(zhuǎn)到你希望的鏈接。 這個方式,讓我們的微信應(yīng)用程序后臺可以獲得用戶的標(biāo)識、用戶詳細(xì)信息等,我們就可以用來綁定和用戶相關(guān)的業(yè)務(wù)信息了,如上面提到的圖書館借閱信息,送水客戶的信息,客戶的積分信息,或者可以和后臺賬號進(jìn)行關(guān)聯(lián)實(shí)現(xiàn)更加復(fù)雜的應(yīng)用等。用戶的身份信息如此重要,如果結(jié)合到我們的CRM系統(tǒng)、業(yè)務(wù)管理系統(tǒng),就可以發(fā)揮用戶信息應(yīng)用的作用了。 以上就是我對這個類型菜單鏈接的應(yīng)用了解,具體還需要進(jìn)一步深化其應(yīng)用,希望和大家共同探討這方面的應(yīng)用場景。
如果對這個《C#開發(fā)微信門戶及應(yīng)用》系列感興趣,可以關(guān)注我的其他文章,系列隨筆如下所示: C#開發(fā)微信門戶及應(yīng)用(20)-微信企業(yè)號的菜單管理 C#開發(fā)微信門戶及應(yīng)用(19)-微信企業(yè)號的消息發(fā)送(文本、圖片、文件、語音、視頻、圖文消息等) C#開發(fā)微信門戶及應(yīng)用(18)-微信企業(yè)號的通訊錄管理開發(fā)之成員管理 C#開發(fā)微信門戶及應(yīng)用(17)-微信企業(yè)號的通訊錄管理開發(fā)之部門管理 C#開發(fā)微信門戶及應(yīng)用(16)-微信企業(yè)號的配置和使用 C#開發(fā)微信門戶及應(yīng)用(15)-微信菜單增加掃一掃、發(fā)圖片、發(fā)地理位置功能 C#開發(fā)微信門戶及應(yīng)用(14)-在微信菜單中采用重定向獲取用戶數(shù)據(jù) C#開發(fā)微信門戶及應(yīng)用(13)-使用地理位置擴(kuò)展相關(guān)應(yīng)用 C#開發(fā)微信門戶及應(yīng)用(12)-使用語音處理 C#開發(fā)微信門戶及應(yīng)用(11)--微信菜單的多種表現(xiàn)方式介紹 C#開發(fā)微信門戶及應(yīng)用(10)--在管理系統(tǒng)中同步微信用戶分組信息 C#開發(fā)微信門戶及應(yīng)用(9)-微信門戶菜單管理及提交到微信服務(wù)器 C#開發(fā)微信門戶及應(yīng)用(8)-微信門戶應(yīng)用管理系統(tǒng)功能介紹 C#開發(fā)微信門戶及應(yīng)用(7)-微信多客服功能及開發(fā)集成 C#開發(fā)微信門戶及應(yīng)用(6)--微信門戶菜單的管理操作 C#開發(fā)微信門戶及應(yīng)用(5)--用戶分組信息管理 C#開發(fā)微信門戶及應(yīng)用(4)--關(guān)注用戶列表及詳細(xì)信息管理 C#開發(fā)微信門戶及應(yīng)用(3)--文本消息和圖文消息的應(yīng)答 C#開發(fā)微信門戶及應(yīng)用(2)--微信消息的處理和應(yīng)答 C#開發(fā)微信門戶及應(yīng)用(1)--開始使用微信接口
主要研究技術(shù):代碼生成工具、Visio二次開發(fā)、客戶關(guān)系管理軟件、送水管理軟件等共享軟件開發(fā) 專注于Winform開發(fā)框架、Web開發(fā)框架、WCF開發(fā)框架的研究及應(yīng)用。 轉(zhuǎn)載請注明出處: 撰寫人:伍華聰 http://www.iqidi.com 該文章在 2014/12/2 1:05:08 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |