Nodejs服务器将Http响应代码400返回给Java

问题描述 投票:1回答:4

我有一个java代码,它向nodejs服务器发出http post请求。 nodejs服务器执行其请求正确的代码并发回响应。然而,java代码正在接收Http响应代码400。

这是我的java代码:

protected String httpPostRequest(URL postUrl, byte[] fields, String requestType) {
        try {
            HttpURLConnection conn = (HttpURLConnection) postUrl.openConnection();
            conn.setRequestMethod("POST");
            conn.setRequestProperty("Content-Type", requestType);
            conn.setRequestProperty("Content-Length", String.valueOf(fields.length));
            conn.setDoOutput(true);
            conn.getOutputStream().write(fields);
            Reader in = new BufferedReader(new InputStreamReader(conn.getInputStream(), StandardCharsets.UTF_8));
            StringBuilder sb = new StringBuilder();
            for (int c; (c = in.read()) >= 0;)
                sb.append((char) c);
            return sb.toString();
        } catch (ProtocolException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (Exception e){
            //e.printStackTrace();
        }
        return "";
    }

以下是nodejs代码的外观:

app.post("/test", function(req, res){
    res.send("File Created");
    //res.status(200)
    res.end();
});

我试过res.status(200).send(“something”),res.send(“something”),res.send(“something”)。end();但我仍然得到响应代码400。

编辑:详细错误:

java.io.IOException: Server returned HTTP response code: 400 for URL: http://localhost:3000/test
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1894)
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1492)
    at controller.utils.http.AbstractHttpClient.httpPostRequest(AbstractHttpClient.java:30)
    at controller.utils.http.HttpClient.callExternalUrl(HttpClient.java:35)
    at model.Project.<init>(Project.java:103)
    at controller.ProjectController.createProject(ProjectController.java:51)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at controller.AbstractApplicantzController.processRequest(AbstractApplicantzController.java:114)
    at view.AbstractWebApi.doRequestAction(AbstractWebApi.java:206)
    at view.AbstractWebApi.processRequest(AbstractWebApi.java:189)
    at view.AbstractWebApi.doPost(AbstractWebApi.java:66)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:647)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:936)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)
java node.js httpresponse
4个回答
0
投票

你不应该自己设置Content-Length标题。发生错误是因为Content-Length的值是错误的。

Java将缓冲您为您发送的任何内容,并为您设置此值。不要试图自己设置它。删除此行应该使它工作:

javaconn.setRequestProperty("Content-Length", String.valueOf(fields.length));

0
投票

我有类似的东西,尤其是POST请求。从Postman,尝试使用尾随'/'并且没有它来命中端点。如果你在没有尾部斜杠的情况下得到相同的400响应,那么你只需要确保你的Java代码在发送之前添加它,或者你的Node代码在路由之前添加它。


0
投票

您发布的代码在JDK1.8.0_191和Node v10.15.3中正常工作您的节点服务器看起来有问题检查您的快速服务器代码


0
投票

使用新规范HTTPbis,有一些状态的扩展定义。 HTTP 400现在不仅指不正确的请求形式,还指服务器处理它的能力。作为stated here

400(错误请求)状态代码表示服务器不能或不会处理请求,因为收到的语法无效,无意义或超出服务器愿意处理的某些限制。

因此,由于请求的负载,您的请求可能无法从您的节点服务器处理。尝试POST一个简单的“Hello World”,它应该可以工作。

© www.soinside.com 2019 - 2024. All rights reserved.