自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

微信企業(yè)號(hào)的配置和使用

開發(fā) 后端
企業(yè)號(hào)是繼公眾號(hào)、訂閱號(hào)的另外一種微信類型,它主要是面對(duì)企業(yè)的。企業(yè)號(hào)是微信為企業(yè)客戶提供的移動(dòng)應(yīng)用入口??梢詭椭髽I(yè)建立員工、上下游供應(yīng)鏈與企業(yè) IT 系統(tǒng)間的連接。利用 企業(yè)號(hào) ,企業(yè)或第三方合作伙伴可以幫助企業(yè)快速、低成本的實(shí)現(xiàn)高質(zhì)量的移動(dòng)輕應(yīng)用,實(shí)現(xiàn)生產(chǎn)、管理、協(xié)作、運(yùn)營的 移動(dòng)化 。

在本系列隨筆的前面,主要就是介紹微信公眾號(hào)的門戶應(yīng)用開發(fā),最近把整個(gè)微信框架進(jìn)行了擴(kuò)展補(bǔ)充,增加了***的企業(yè)號(hào)的API封裝和開發(fā),后續(xù)主要介紹如何利用C#進(jìn)行微信企業(yè)號(hào)的開發(fā)工作,本篇作為微信企業(yè)號(hào)的開發(fā)的起步篇,介紹微信企業(yè)號(hào)的配置和使用。

1、微信企業(yè)號(hào)的注冊(cè)和登陸

企業(yè)號(hào)是繼公眾號(hào)、訂閱號(hào)的另外一種微信類型,它主要是面對(duì)企業(yè)的。企業(yè)號(hào)是微信為企業(yè)客戶提供的移動(dòng)應(yīng)用入口??梢詭椭髽I(yè)建立員工、上下游供應(yīng)鏈與企業(yè) IT 系統(tǒng)間的連接。利用 企業(yè)號(hào) ,企業(yè)或第三方合作伙伴可以幫助企業(yè)快速、低成本的實(shí)現(xiàn)高質(zhì)量的移動(dòng)輕應(yīng)用,實(shí)現(xiàn)生產(chǎn)、管理、協(xié)作、運(yùn)營的 移動(dòng)化 。

個(gè)人覺得企業(yè)號(hào)***的亮點(diǎn)是可以不限數(shù)量的消息發(fā)送,也就是可以在企業(yè)員工之間暢通交流。相對(duì)于公眾號(hào)和訂閱號(hào),發(fā)送消息的謹(jǐn)慎程度,微信企業(yè)號(hào)可謂給人眼前一亮的感覺。不過微信企業(yè)號(hào)是需要內(nèi)部建立好通訊錄,關(guān)注者需要匹配通訊錄的微信號(hào)、郵箱、電話號(hào)碼任一個(gè)通過才可以關(guān)注,也就是可以防止其他外來人員的自由關(guān)注了,另外如果為了安全考慮,還可以設(shè)置二次驗(yàn)證,也就是一個(gè)審核過程。

企業(yè)號(hào)的認(rèn)證和公眾號(hào)一樣,需要提供相關(guān)的企業(yè)資質(zhì)文件,并且認(rèn)證每年都要收取費(fèi)用,否則可能有人員和功能的一些限制。覺得微信真是想著方法賺錢,目前已有的收費(fèi)模式有,訂閱號(hào)、公眾號(hào)、企業(yè)號(hào)、開放平臺(tái),好像都有認(rèn)證收費(fèi)的了,而且微信小店也還需要收2萬的押金,一切都是錢呀。

好了,其他不多說,微信的注冊(cè)地址是:https://qy.weixin.qq.com,一個(gè)郵箱不能同時(shí)注冊(cè)微信公眾號(hào)和微信企業(yè)號(hào)。

對(duì)于企業(yè)開通企業(yè)號(hào)并開始使用需要四步

1) 企業(yè)到微信官網(wǎng)( http://qy.weixin.qq.com )申請(qǐng)開通;

2) 開通后,企業(yè)在企業(yè)號(hào)管理后臺(tái)導(dǎo)入成員,發(fā)布二維碼;

3) 企業(yè)調(diào)用企業(yè)號(hào) api 與企業(yè)自有系統(tǒng)對(duì)接開發(fā);

4) 員工關(guān)注,收到微信信息,在微信中與企業(yè)交互

注冊(cè)好企業(yè)號(hào),就可以通過微信掃一掃,掃描企業(yè)二維碼進(jìn)行登錄了,掃描的時(shí)候,需要微信進(jìn)行確認(rèn),才可以繼續(xù)輸入密碼進(jìn)行登錄,操作界面如下所示(左邊是手機(jī)截圖,右邊是網(wǎng)頁截圖)。

 

登錄后我們就可以看到對(duì)應(yīng)的電腦端的管理界面了。

2、設(shè)置開發(fā)回調(diào)模式

如果開發(fā)過微信公眾號(hào),那么我們就知道,如果需要在微信服務(wù)器和網(wǎng)站服務(wù)器之間建立連接關(guān)系,實(shí)現(xiàn)消息的轉(zhuǎn)發(fā)和處理,那么就應(yīng)該設(shè)置一個(gè)回調(diào)模式,需要配置好相關(guān)的參數(shù)。然后在自己 網(wǎng)站服務(wù)器里面建立一個(gè)處理微信服務(wù)器消息的入口。

 

進(jìn)入配置后,我們需要修改相關(guān)的URL、Token、EncodingAESKey等參數(shù),主要是URL,這個(gè)就是和公眾號(hào)的入口處理一樣的,需要我們發(fā)布到網(wǎng)站服務(wù)器上的處理入口。

Token和AESKey可以根據(jù)提示動(dòng)態(tài)生成一個(gè)即可,AESKey好像必須是23位的,所以這個(gè)一般是讓它自己生成的,這個(gè)主要用來加密解密使用的。

URL、Token、EncodingAESKey三個(gè)參數(shù)說明。

1)URL是企業(yè)應(yīng)用接收企業(yè)號(hào)推送請(qǐng)求的訪問協(xié)議和地址,支持http或https協(xié)議。

2)Token可由企業(yè)任意填寫,用于生成簽名。

3)EncodingAESKey用于消息體的加密,是AES密鑰的Base64編碼。

驗(yàn)證URL、Token以及加密的詳細(xì)處理請(qǐng)參考后續(xù) “接收消息時(shí)的加解密處理” 的部分。

我公司的企業(yè)號(hào)配置后的界面如下所示。

 這個(gè)URL里面指向的頁面功能,需要對(duì)數(shù)據(jù)進(jìn)行解析并返回給微信服務(wù)器,因此我們需要在服務(wù)器上預(yù)先部署好這個(gè)處理功能入口。

除了上面的幾個(gè)函數(shù),還有一個(gè)CorpID的參數(shù)需要使用,我們可以在后臺(tái)主界面-設(shè)置里面查看到。

然后我們?yōu)榱朔奖憔W(wǎng)站后臺(tái)使用,我們和公眾號(hào)的配置一樣,把它放到了Web.Config里面,如下所示。

3、實(shí)現(xiàn)回調(diào)頁面的功能開發(fā)

前面介紹了幾個(gè)配置項(xiàng),需要在回調(diào)頁面里面使用的,本小節(jié)繼續(xù)介紹如何實(shí)現(xiàn)企業(yè)號(hào)信息的回發(fā),使之通過回調(diào)測(cè)試的操作。

由于回調(diào)測(cè)試的數(shù)據(jù)是通過Get方式發(fā)送的,因此我們的處理邏輯代碼如下所示,和公眾號(hào)的類似處理,只是實(shí)現(xiàn)部分不太一樣而已。

  1. /// <summary>  
  2.     /// 企業(yè)號(hào)回調(diào)信息接口。統(tǒng)一接收并處理信息的入口。  
  3.     /// </summary>  
  4.     public class corpapi : IHttpHandler  
  5.     {  
  6.         /// <summary>  
  7.         /// 處理企業(yè)號(hào)的信息  
  8.         /// </summary>  
  9.         /// <param name="context"></param>  
  10.         public void ProcessRequest(HttpContext context)  
  11.         {  
  12.             string postString = string.Empty;  
  13.             if (HttpContext.Current.Request.HttpMethod.ToUpper() == "POST")  
  14.             {  
  15.                 using (Stream stream = HttpContext.Current.Request.InputStream)  
  16.                 {  
  17.                     Byte[] postBytes = new Byte[stream.Length];  
  18.                     stream.Read(postBytes, 0, (Int32)stream.Length);  
  19.                     postString = Encoding.UTF8.GetString(postBytes);  
  20.                 }  
  21.  
  22.                 if (!string.IsNullOrEmpty(postString))  
  23.                 {  
  24.                     Execute(postString);  
  25.                 }  
  26.             }  
  27.             else 
  28.             {  
  29.                 Auth();  
  30.             }  
  31.         }  
  32.  
  33.         /// <summary>  
  34.         /// 成為開發(fā)者的***步,驗(yàn)證并相應(yīng)服務(wù)器的數(shù)據(jù)  
  35.         /// </summary>  
  36.         private void Auth()  
  37.         {  
  38.             #region 獲取關(guān)鍵參數(shù)  
  39.             string token = ConfigurationManager.AppSettings["CorpToken"];//從配置文件獲取Token  
  40.             if (string.IsNullOrEmpty(token))  
  41.             {  
  42.                 LogTextHelper.Error(string.Format("CorpToken 配置項(xiàng)沒有配置!"));  
  43.             }  
  44.             string encodingAESKey = ConfigurationManager.AppSettings["EncodingAESKey"];//從配置文件獲取EncodingAESKey  
  45.             if (string.IsNullOrEmpty(encodingAESKey))  
  46.             {  
  47.                 LogTextHelper.Error(string.Format("EncodingAESKey 配置項(xiàng)沒有配置!"));  
  48.             }  
  49.             string corpId = ConfigurationManager.AppSettings["CorpId"];//從配置文件獲取corpId  
  50.             if (string.IsNullOrEmpty(corpId))  
  51.             {  
  52.                 LogTextHelper.Error(string.Format("CorpId 配置項(xiàng)沒有配置!"));  
  53.             }   
  54.             #endregion  
  55.  
  56.             string echoString = HttpContext.Current.Request.QueryString["echoStr"];  
  57.             string signature = HttpContext.Current.Request.QueryString["msg_signature"];//企業(yè)號(hào)的 msg_signature  
  58.             string timestamp = HttpContext.Current.Request.QueryString["timestamp"];  
  59.             string nonce = HttpContext.Current.Request.QueryString["nonce"];  
  60.  
  61.             string decryptEchoString = "";  
  62.             if (new CorpBasicApi().CheckSignature(token, signature, timestamp, nonce, corpId, encodingAESKey, echoString, ref decryptEchoString))  
  63.             {  
  64.                 if (!string.IsNullOrEmpty(decryptEchoString))  
  65.                 {  
  66.                     HttpContext.Current.Response.Write(decryptEchoString);  
  67.                     HttpContext.Current.Response.End();  
  68.                 }  
  69.             }  
  70.         } 

具體的處理代碼如下所示,里面的一個(gè)加解密處理的類是微信企業(yè)號(hào)附錄里面提供的,我使用了C#版本的SDK而已。

  1. /// <summary>  
  2.     /// 企業(yè)號(hào)基礎(chǔ)操作API實(shí)現(xiàn)  
  3.     /// </summary>  
  4.     public class CorpBasicApi : ICorpBasicApi  
  5.     {  
  6.         /// <summary>  
  7.         /// 驗(yàn)證企業(yè)號(hào)簽名  
  8.         /// </summary>  
  9.         /// <param name="token">企業(yè)號(hào)配置的Token</param>  
  10.         /// <param name="signature">簽名內(nèi)容</param>  
  11.         /// <param name="timestamp">時(shí)間戳</param>  
  12.         /// <param name="nonce">nonce參數(shù)</param>  
  13.         /// <param name="corpId">企業(yè)號(hào)ID標(biāo)識(shí)</param>  
  14.         /// <param name="encodingAESKey">加密鍵</param>  
  15.         /// <param name="echostr">內(nèi)容字符串</param>  
  16.         /// <param name="retEchostr">返回的字符串</param>  
  17.         /// <returns></returns>  
  18.         public bool CheckSignature(string token, string signature, string timestamp, string nonce, string corpId, string encodingAESKey, string echostr, ref string retEchostr)  
  19.         {  
  20.             WXBizMsgCrypt wxcpt = new WXBizMsgCrypt(token, encodingAESKey, corpId);  
  21.             int result = wxcpt.VerifyURL(signature, timestamp, nonce, echostr, ref retEchostr);  
  22.             if (result != 0)  
  23.             {  
  24.                 LogTextHelper.Error("ERR: VerifyURL fail, ret: " + result);  
  25.                 return false;  
  26.             }  
  27.  
  28.             return true;  
  29.  
  30.             //ret==0表示驗(yàn)證成功,retEchostr參數(shù)表示明文,用戶需要將retEchostr作為get請(qǐng)求的返回參數(shù),返回給企業(yè)號(hào)。  
  31.             // HttpUtils.SetResponse(retEchostr);  
  32.         } 

原文出自:http://www.cnblogs.com/wuhuacong/p/3991735.html

責(zé)任編輯:林師授 來源: 伍華聰?shù)牟┛?/span>
相關(guān)推薦

2014-09-28 22:38:21

微信企業(yè)號(hào)

2014-09-24 13:11:34

信企業(yè)號(hào)

2014-09-25 15:27:28

微信企業(yè)號(hào)注冊(cè)流程

2014-10-21 15:42:30

微信企業(yè)號(hào)企業(yè)移動(dòng)平臺(tái)

2014-09-25 13:40:52

微信企業(yè)號(hào)圖解

2014-09-25 15:48:51

微信企業(yè)號(hào)申請(qǐng)認(rèn)證

2014-09-25 15:51:07

微信企業(yè)號(hào)認(rèn)證審核

2014-09-23 16:37:39

微信企業(yè)號(hào)移動(dòng)應(yīng)用入口

2014-09-25 14:19:00

微信企業(yè)號(hào)案例

2014-09-24 11:45:15

微信企業(yè)號(hào)開發(fā)

2014-09-25 14:05:15

微信企業(yè)號(hào)案例

2014-09-24 11:32:21

微信企業(yè)號(hào)開發(fā)

2014-09-24 09:59:23

微信企業(yè)號(hào)開發(fā)

2014-09-25 14:08:58

微信企業(yè)號(hào)案例

2014-09-24 13:04:13

微信企業(yè)號(hào)

2014-09-24 11:11:08

微信企業(yè)號(hào)開發(fā)

2021-03-05 06:25:19

fiddler微信公眾號(hào)小程序

2022-01-11 20:50:12

微信企業(yè)微信移動(dòng)應(yīng)用

2014-09-25 14:10:36

微信企業(yè)號(hào)案例

2014-09-25 13:19:35

微信企業(yè)號(hào)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)