angularjs POST映像到WCF RESTful

时间:2016-07-25 08:59:25

标签: angularjs wcf image-uploading

这个问题已经被问了很多,我已经彻底搜索了谷歌(主要是堆栈溢出),但没有一个解决方案适合我。

我正在尝试使用angularjs将图像(base64)上传到我的WCF服务。

响应错误:

  

POST http://localhost:8080/Service.svc/Method 413(请求实体也是   大)

大多数问题的主要解决方案是在webconfig

中允许更大的请求
  <bindings>
      <basicHttpsBinding>
         <binding  maxBufferPoolSize="2147483647" 
      maxReceivedMessageSize="2147483647" 
      maxBufferSize="2147483647" transferMode="Streamed">
        <readerQuotas 
             maxDepth="2147483647" 
             maxStringContentLength="2147483647" 
             maxArrayLength="2147483647"
             maxBytesPerRead="2147483647" 
             maxNameTableCharCount="2147483647" />
        </binding>
      </basicHttpsBinding>
    </bindings>

但这对我来说仍然不起作用。

我不确定问题是否是由应用的$http请求引起的:

的Base64

var a = '';

$ HTTP

 $http({
    method: 'POST',
    url: ' http://localhost:8080/Service.svc/Method',
    data: "message=" + a,
    headers: {'Content-Type': 'application/x-www-form-urlencoded'}
})
              .success(function(data) {
              console.log(data);
            })

          .error(function(data) {
              console.log("failure");
              })    

       };

1 个答案:

答案 0 :(得分:0)

  

这是我找到的最佳解决方案,效果很好。

从客户端( Angularjs ),我查看了uncorkedstudios.com文章,其中介绍了如何使用 Multipart / form-data 上传图片。

然后,对于服务器端,请查看此问题stackoverflow.com/questions/1354749/wcf-service-to-accept-a-post-encoded-multipart-form-data它在接收来自客户端的请求时使用流来解释服务器端。

您的Method参数可能如下所示:{System.ServiceModel.Dispatcher.StreamFormatter.MessageBodyStream}

为此,我使用了multipartparser.codeplex.com上的课程。

下面的课程编码应该足以弄明白。

public string Upload(Stream stream)
{
MultipartParser parser = new MultipartParser(stream);

if(parser.Success)
{
// Save the file
SaveFile(parser.Filename, parser.ContentType, parser.FileContents);
}
else
{
throw new WebException(System.Net.HttpStatusCode.UnsupportedMediaType, "The posted file was not recognised.");
}
}

希望它有所帮助。