我们有一个通过网络公开的加密服务。tcp。大多数时候,该服务用于加密/解密字符串。但是,我们时不时地需要对大型文档(pdf、JPG、bmp 等)进行加密。
对于这样的场景,最好的端点设置是什么?我应该接受/返回流吗?我已经阅读了很多关于这方面的内容,但是没有人给出当大文件不经常出现时该怎么做的指导。
我们有一个通过网络公开的加密服务。tcp。大多数时候,该服务用于加密/解密字符串。但是,我们时不时地需要对大型文档(pdf、JPG、bmp 等)进行加密。
对于这样的场景,最好的端点设置是什么?我应该接受/返回流吗?我已经阅读了很多关于这方面的内容,但是没有人给出当大文件不经常出现时该怎么做的指导。
MSDN 描述了如何很好地通过 WCF 启用流式传输。
请注意,如果客户端和服务器之间的链接需要加密,那么您需要“滚动自己的”加密机制。默认net.tcp
加密需要 X.509 证书,它不适用于流,因为这种加密需要一次性处理整个消息而不是字节流。
反过来,这意味着您将无法使用默认的 WCF 安全机制对客户端进行身份验证,因为身份验证需要加密。我知道的唯一解决方法是在客户端和服务器上实现您自己的自定义行为扩展来处理身份验证。
关于如何添加自定义行为扩展的一个非常好的参考在这里:这个文档也记录了如何提供自定义配置(我认为目前 MSDN 文档中没有讨论过这一点)。
您可以遵循的一种模式是使用异步服务来处理共享文件系统位置上的文件: