mirror of
https://gitee.com/fudiwei/DotNetCore.SKIT.FlurlHttpClient.Wechat.git
synced 2025-09-20 02:29:40 +08:00
docs: 完善文档
This commit is contained in:
@@ -36,6 +36,16 @@ string msgType = xDoc.Root?.Element("MsgType")?.Value?.ToUpper();
|
||||
```csharp
|
||||
WechatApiEvent eventModel = client.DeserializeEventFromXml(callbackXml);
|
||||
string msgType = eventModel.MessageType?.ToUpper();
|
||||
|
||||
switch (msgType)
|
||||
{
|
||||
case "TEXT":
|
||||
{
|
||||
var callbackModel = client.DeserializeEventFromXml<Events.TextMessageEvent>(callbackXml);
|
||||
}
|
||||
break;
|
||||
// 省略其他情况
|
||||
}
|
||||
```
|
||||
|
||||
---
|
||||
@@ -59,7 +69,7 @@ var options = new WechatApiClientOptions()
|
||||
};
|
||||
var client = new WechatApiClient(options);
|
||||
|
||||
/* 如果是 XML 格式的加密通知内容 */
|
||||
/* 如果是 XML 格式的加密通知内容,以 text 事件为例 */
|
||||
string callbackXml = "<xml> <Encrypt>...</Encrypt> </xml>";
|
||||
var callbackModel = client.DeserializeEventFromXml<Events.TextMessageEvent>(callbackXml, safety: true);
|
||||
```
|
||||
|
@@ -18,8 +18,33 @@ var callbackModel = client.DeserializeEventFromXml<Events.TextMessageEvent>(call
|
||||
|
||||
---
|
||||
|
||||
### 事件类型:
|
||||
|
||||
由于企业微信会将全部事件推送到同一个回调通知地址上,开发者需要根据事件类型才能决定如何反序列化。
|
||||
|
||||
这里给出一种解决方案:
|
||||
|
||||
```csharp
|
||||
WechatApiEvent eventModel = client.DeserializeEventFromXml(callbackXml);
|
||||
string msgType = eventModel.MessageType?.ToUpper();
|
||||
|
||||
switch (msgType)
|
||||
{
|
||||
case "TEXT":
|
||||
{
|
||||
var callbackModel = client.DeserializeEventFromXml<Events.TextMessageEvent>(callbackXml);
|
||||
}
|
||||
break;
|
||||
// 省略其他情况
|
||||
}
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### 安全模式:
|
||||
|
||||
在安全模式下,微信公众平台使用了一种特殊的 AES 算法对回调通知事件加密。
|
||||
与微信公众号不同的是,企业微信默认启用了安全模式,且不支持切换至明文模式。
|
||||
|
||||
开发者可利用本库提供的 `WxBizMsgCryptor` 工具类自行解密相关字段。
|
||||
|
||||
上文提到的扩展方法,已自动做解密处理。
|
||||
|
Reference in New Issue
Block a user