日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

如何在WCF中用TcpTrace工具查看发送和接收的SOAP消息

發布時間:2025/5/22 编程问答 16 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何在WCF中用TcpTrace工具查看发送和接收的SOAP消息 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

WCF對消息加密(只對消息加密,不考慮Authorize)其實很簡單,只要在server和client端的binding加入security mode為Message(還有Transport,?TransportWithMessageCredential,關于他們的不同之處,請參考MSDN)即可。

以一個簡單的例子說明,這個例子只有一個Greeting方法,回顯客戶端的輸入,如客戶端輸入"WCF",調用service的Greeting方法后回顯"Hello,WCF!"。我這里server端的配置文件如下:

Client端沒有使用配置文件,直接在代碼中編寫,但要與server端一致:

var binding = new WSHttpBinding();
binding.Security.Mode
= SecurityMode.Message;

當我們對消息加密后,如果想查看一下是否真的加密,就要用到一個工具TcpTrace,這是一個可以跟蹤SOAP消息的很好用的工具。也可以應用于web service的消息查看,因為都是SOAP消息格式。這個工具的官方網站下載地址:http://www.tcptrace.org/download.html。不需要安裝,下載后直接運行。

這個工具的原理就是開一個偵聽端口,用于偵聽Client端發送的數據,當Client發出一個Soap消息后,先把Soap攔截下來,進行Soap跟蹤處理(如顯示Soap消息,或記入log等)之后再把Soap消息傳到真正的Service。所以我們需要配置兩個port,一個是偵聽端口,一個是目標端口,也就是service端口。如下圖:

點擊OK就進入工作狀態了。

?

但是為了能讓TcpTrace偵聽到Client端發出的消息,我們要在Client端做些工作,需要一個特殊的Client端的Endpoint Behavior:ClientViaBehavior。假設tcpTrace進行監聽的Port為8081, 那么Client實現了ClientViaBehavior的代碼如下,當然也可以在配置文件中直接添加。

var binding = new WSHttpBinding();
binding.Security.Mode
= SecurityMode.Message;

//Encrypt, can check with Tcp Trace
binding.Security.Mode = SecurityMode.Message;
//Not encrypt
//binding.Security.Mode = SecurityMode.None;

var factory
= new ChannelFactory<IHelloService>(
binding,
new EndpointAddress("http://localhost:8080/HelloService"));

//Add listening port only at client.
Uri tcpTraceUri = new Uri("http://localhost:8081/HelloService");
factory.Endpoint.Behaviors.Add(
new ClientViaBehavior(tcpTraceUri));

var proxy
= factory.CreateChannel();
var result
= proxy.Greeting("WCF Message");

?

注意代碼中的8081端口,作為behavior加入到endpoint中。這個behavior只在Client端的endpoint中加,server端不需要。

?

然后就可以啟動TcpTrace了,界面如下:

我們先來看一下TcpTrace跟蹤的不加密的Soap消息,即Client端的binding?SecurityMode為None的情況:

可見消息是明碼的。我們再來看一下加密后的情況,即Client端的binding?SecurityMode為Message的情況:

可見消息都是加密過的,從而保證了消息的安全性。當然還可以加入用戶認證,交換證書等安全性機制,這個例子只是說明如何使用TcpTrace來跟蹤Soap消息,所以只做了加密部分。

例子代碼請到我的個人網站下載:http://www.vczx.com/article/show.php?id=1011812

歡迎大家提出任何意見或建議!

總結

以上是生活随笔為你收集整理的如何在WCF中用TcpTrace工具查看发送和接收的SOAP消息的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。