1

This Question has been asked quite a lot, I have searched Google thoroughly (mostly stackoverflow), but none of the solutions worked for me.

I am trying to upload an image (base64) to my WCF Service with angularjs.

response error:

POST http://localhost:8080/Service.svc/Method 413 (Request Entity Too Large)

The main solution on most questions is allowing a bigger request in your 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>

But this still did not work for me.

I am not sure if the issue is caused by my $http request from the app:

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");
              })    

       };
  • i think you must try a multipart request instead of a simple post – kukkuz Jul 25 '16 at 09:08
  • Do you mean to break the string up in parts and then sending it piece by piece? @kukkuz –  Jul 25 '16 at 09:46
  • nope.. using `'Content-Type': 'multipart/form-data'` and post it to server just like you upload a file... – kukkuz Jul 25 '16 at 09:54
  • unfortunately I am still getting the same error –  Jul 25 '16 at 09:57
  • changing content-type alone will not work... you have to configure your /Service.svc/Method endpoint to receive a "Multipart" file and then... – kukkuz Jul 25 '16 at 09:58
  • I followed [this](http://stackoverflow.com/questions/1354749/wcf-service-to-accept-a-post-encoded-multipart-form-data) link it also did not make a difference is this all the appropriate steps to follow? –  Jul 25 '16 at 10:13
  • Let us [continue this discussion in chat](http://chat.stackoverflow.com/rooms/118211/discussion-between-kukkuz-and-tjapple). – kukkuz Jul 25 '16 at 10:21

1 Answers1

0

This is the best solution I have found and it works perfectly.

From Client side (Angularjs), I followed a uncorkedstudios.com article, it explains how to upload an image using Multipart/form-data.

Then for Server side see this question stackoverflow.com/questions/1354749/wcf-service-to-accept-a-post-encoded-multipart-form-data It explains the sever side by using stream when receiving a request from your client.

Your Method parameter will probably look like this: {System.ServiceModel.Dispatcher.StreamFormatter.MessageBodyStream}

For this I used a class found on multipartparser.codeplex.com.

The coding below with the class should be enough to figure out.

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.");
}
}

Hope it helps.

Community
  • 1
  • 1