【问题标题】:AngularJS + WCF REST File UploadAngularJS + WCF REST 文件上传
【发布时间】:2015-03-04 12:01:40
【问题描述】:

我有一个关于从 AngularJS 客户端应用程序将文件上传到 WCF REST 服务的问题。上传的文件随后应存储在 Azure Blob 存储中。 目前该实现适用于文本和 pdf 文件,但我没有使用图像文件。图片和其他类型的数据在实际上传后损坏。 因此,我想向您展示本准则的相关部分。在 AngularJS 应用程序中,我使用 HTML5 File-Api 来选择文件。之后我使用 AngularJS 服务,它获取文件并执行 Post-Request:

srv.uploadFile = function(id, file){
    return $http.post(DEV_ENV_CONFIG.BASE_SERVER_URL + '/xml' + '/fileUpload/' + file.name + '/' + id, file,
        {withCredentials: true, headers: {'Content-Type': undefined }, transformRequest: angular.identity}).then(function(response){

        });
};

在服务器端,我编写了一个 WCF REST 服务,它接受流:

[OperationContract]
    [WebInvoke(Method = "POST", ResponseFormat = WebMessageFormat.Xml, BodyStyle = WebMessageBodyStyle.Bare, UriTemplate = "xml/fileUpload/{fileName}/{expenseId}")]
    void FileUploadAsXml(string fileName, string expenseId, Stream Args);

后来我首先尝试通过 FileStream 将文件保存在服务器端文件系统上。问题正如我上面提到的,这种方法适用于 PDF 文件,但图像以及例如 Excel 文件已损坏且无法打开。 我还将 Web.config 中的绑定更改为以下内容:

<binding name="http"
             maxBufferSize="2147483647"
             maxBufferPoolSize="2147483647"
             maxReceivedMessageSize="2147483647"
             sendTimeout="00:05:00"
             transferMode="Streamed">
      <readerQuotas  maxDepth="2147483647"
                     maxStringContentLength="2147483647"
                     maxArrayLength="2147483647"
                     maxBytesPerRead="2147483647"
                     maxNameTableCharCount="2147483647"/>

      <security mode="None">
        <transport clientCredentialType="None"/>
      </security>
    </binding>

以便大文件的传输工作。所以我的问题是,为什么图像传输会导致文件损坏。你有什么主意吗?可能是因为请求的内容类型?

【问题讨论】:

    标签: c# angularjs wcf rest stream


    【解决方案1】:

    刚刚看到,我的问题仍未得到解答。对于那些面临同样问题的人,很可能您必须使用 Multipart-Parser 来获取实际的文件内容。如果通过 HTML File-API 选择,流还包含元数据,如内容类型、文件名等。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2011-06-11
      • 2015-04-13
      • 1970-01-01
      • 2014-04-19
      • 2015-04-10
      • 1970-01-01
      • 2012-11-24
      相关资源
      最近更新 更多