2016-07-25 49 views
1

Diese Frage wurde schon oft gestellt, ich habe Google gründlich durchsucht (meist stack Überlauf), aber keine der Lösungen funktionierte für mich.angularjs POST Image to WCF RESTful

Ich versuche, ein Bild (base64) zu meinem WCF Service mit angularjs hochladen.

antwort:

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

Die Hauptlösung auf die meisten Fragen ist eine größere Anfrage in Ihrem webconfig erlaubt:

<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> 

Aber dies noch nicht für mich arbeiten.

Ich bin nicht sicher, ob das Problem durch meine $http Anfrage aus der App verursacht:

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

     }; 
+0

Ich denke, Sie müssen eine mehrteilige Anfrage anstelle einer einfachen Post versuchen – kukkuz

+0

Meinen Sie, die Zeichenfolge in Teile zu brechen und dann Stück für Stück zu senden? @kukkuz –

+0

nein .. benutze ''Content-Type': 'multipart/form-data'' und poste es auf den Server so wie du eine Datei hochlädst ... – kukkuz

Antwort

0

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

Von Client-Seite (Angularjs) folgte ich einem uncorkedstudios.com Artikel, es erklärt, wie ein Bild mit Multipart/Form-Daten hochladen.

Dann für Server-Seite siehe diese Frage stackoverflow.com/questions/1354749/wcf-service-to-accept-a-post-encoded-multipart-form-data Es erklärt die Server-Seite mit Stream beim Empfang einer Anfrage von Ihrem Client.

Ihre Methode Parameter wird wahrscheinlich so aussehen: {System.ServiceModel.Dispatcher.StreamFormatter.MessageBodyStream}

Dazu habe ich eine Klasse auf multipartparser.codeplex.com gefunden.

Die Codierung unten mit der Klasse sollte genug sein, um herauszufinden.

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

Ich hoffe, es hilft.