Ich habe multipart/form-data
, die ich /data/upload
, Form Markup unter einem ausdrücklichen Endpunkt bin Entsendung:Piping Strom von busboy zu beantragen Post
form(enctype="multipart/form-data", action="/data/upload", method="post")
input(type="file", name="data")
ich busboy
bin mit dem Datei-Stream zu lesen, was in Ordnung arbeitet. Von dort möchte ich den Strom wieder als multipart/form-data
zu einem zweiten Java-Backend senden, mit dem request
Npm-Modul. JS Client/Java-Server-Code unten:
req.busboy.on('file', function (fieldName, fileStream, fileName, encoding, mimeType) {
var reqBody = {
url: server.baseURL + 'api/data',
headers: {
'Connection': 'keep-alive',
'Content-Type': 'multipart/form-data'
},
formData: {
file: fileStream
}
};
request.post(reqBody, function (err, r, body) {
// Do rendering stuff, handle callback
});
});
Java-Endpunkt (api/Daten)
@POST
@Consumes(MediaType.MULTIPART_FORM_DATA)
public void addData(FormDataMultiPart formDataMultiPart) {
// Handle multipart data here
}
Ich glaube nicht, daß ich die Datei korrekt als multipart/form-data
Senden hier ... aber Ich habe eine harte Zeit herauszufinden, wie im Wesentlichen der Stream von busboy
direkt zu request
ohne Lesen/Schreiben von einer temporären Datei auf der Client-Seite. Irgendwelche Ideen?
Java-Stack-Trace:
Apr 27, 2016 5:07:12 PM org.glassfish.jersey.filter.LoggingFilter log
INFO: 3 * Server has received a request on thread qtp1631904921-24
3 > POST http://localhost:8080/api/data
3 > Connection: keep-alive
3 > Content-Length: 199
3 > Content-Type: multipart/form-data; boundary=--------------------------331473417509479560313628
3 > Host: localhost:8080
Apr 27, 2016 5:07:12 PM org.glassfish.jersey.filter.LoggingFilter log
INFO: 3 * Server responded with a response on thread qtp1631904921-24
3 < 400
17:07:13.003 [qtp1631904921-24] WARN org.eclipse.jetty.http.HttpParser parseNext - bad HTTP parsed: 400 No URI for [email protected]{r=1,c=false,a=IDLE,uri=null}
Rahat empfohlenen Änderung:
31 var reqBody = {
32 url: server.baseURL + 'data',
33 headers: {
34 'Connection': 'keep-alive',
35 'Content-Type': 'multipart/form-data'
36 }
37 };
38
39 req.pipe(req.busboy.pipe(request.post(reqBody)));
Threw Fehler:
Error: Cannot pipe. Not readable.
at Busboy.Writable.pipe (_stream_writable.js:154:22)
Sie definieren 'req' neu. Ist das beabsichtigt? –
Es ist eine schlechte Wahl des Variablennamens, aber es ist kein Problem. Ich werde es in dem obigen Post ändern. –
Haben Sie schon einmal versucht, Ihren 'Busboy' an Ihren Java-Endpunkt anzuschließen? –