我正在开发一个 .NET CF 客户端应用程序并使用 Web 服务进行数据传输。我正在使用 SharpZipLib 压缩传输的数据集,因此我知道传输的字节数组的大小。
我想知道是否有一种简单的方法来确定完成单个调用的请求大小(html headerder、soap 信封和真实数据)。我真的想尽量减少 GPRS 连接成本。
谢谢...
我正在开发一个 .NET CF 客户端应用程序并使用 Web 服务进行数据传输。我正在使用 SharpZipLib 压缩传输的数据集,因此我知道传输的字节数组的大小。
我想知道是否有一种简单的方法来确定完成单个调用的请求大小(html headerder、soap 信封和真实数据)。我真的想尽量减少 GPRS 连接成本。
谢谢...
重新提出整体问题;对不起,我不知道使用网络跟踪器...
然而; 我可以谦虚地建议数据集和 SOAP 并不总是带宽受限设备的最佳选择吗?压缩做得很好,但并不总是理想的。除非您需要提供的功能,否则可以使用更简单的协议(例如 POX,可能使用内置协议压缩 (GZIP/Deflate))。
另一方面...如果您可以将事物表述为消息,那么像protobuf-net这样的序列化程序可能会很有用(结合原始二进制帖子);它们的数据非常密集(因此尝试使用压缩不可避免地会增加大小)。但是,您需要在客户端进行自己的数据/更改跟踪,并且 RPC 堆栈尚不完整(我有工作原型代码,但我还没有提交它,因为我还在单元测试它)。服务器也将有所不同(即不是 asmx 或其他任何东西 - 可能是操纵的处理程序或 MVC 控制器)。
作为另一种选择 - ADO.NET 数据服务可能会引起人们的兴趣,尤其是在 JSON 模式下(对于带宽,再次使用协议压缩)。
WCF 支持消息跟踪,可以让您查看生成的 SOAP+Message 的大小。您可以使用这些跟踪文件来确定您要查找的内容,尽管对您的通信进行压缩后发送的字节数将不那么明显。对于实际的电线尺寸,wireshark 将是一个不错的选择。或者,您可以压缩从 WCF 跟踪中提取的消息并大致了解一下。