java - Java:如果 doOutput=false,则无法写入 URLConnection - 调用 setDoOutput(true)
问题描述
我是一名 QA,希望了解更多关于 Java 编程的信息,我遇到的问题是:我正在尝试将员工数据发布到一些假 Rest API 的数据库中,但我得到了
如果 doOutput=false,则无法写入 URLConnection - 调用 setDoOutput(true)"
到目前为止,我尝试了 StackOverflow 的一些想法,但由于我缺乏经验,我很容易陷入更深的问题。所以 URL 是:http ://dummy.restapiexample.com/api/v1/create首先我创建了一个 Employee 类的 json 对象:
public class Main {
public static void main(String[] args) {
new Main();
}
public Main() {
Employees em = new Employees();
em.setEmployeeName("Alex");
em.setEmployeeSalary("1234");
em.setEmployeeAge("28");
try{
URL url = new URL("http://dummy.restapiexample.com/api/v1/create");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("POST");
conn.setRequestProperty("Accept", "application/json");
if (conn.getResponseCode() != 200) {
throw new RuntimeException("Unsuccessful call: HTTP error : "
+ conn.getResponseCode());
}
// URLConnection urlc = url.openConnection();
// urlc.setDoOutput(true);
PrintWriter pw = new PrintWriter(conn.getOutputStream());
pw.print(new Gson().toJson(em));
pw.close();
pw.flush();
BufferedReader br = new BufferedReader(
new InputStreamReader(conn.getInputStream())
);
String json = "";
String output;
while ((output = br.readLine()) != null) {
json += output;
}
conn.disconnect();
System.out.println("Employee name: " + em.getEmployeeName());
}
catch (MalformedURLException e) {
e.printStackTrace();
}
catch (IOException e) {
e.printStackTrace();
}
}
}
好吧,使用您的一个想法并添加下一行代码(在上面的代码中进行了注释):
URLConnection urlc = url.openConnection();
urlc.setDoOutput(true);
所以代码看起来像:
公共类主要{
public static void main(String[] args) { new Main(); } public Main() { Employees em = new Employees(); em.setEmployeeName("Alex"); em.setEmployeeSalary("1234"); em.setEmployeeAge("28"); try{ URL url = new URL("http://dummy.restapiexample.com/api/v1/create"); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("POST"); conn.setRequestProperty("Accept", "application/json"); if (conn.getResponseCode() != 200) { throw new RuntimeException("Unsuccessful call: HTTP error : " + conn.getResponseCode()); } URLConnection urlc = url.openConnection(); urlc.setDoOutput(true); PrintWriter pw = new PrintWriter(urlc.getOutputStream()); pw.print(new Gson().toJson(em)); pw.close(); pw.flush(); BufferedReader br = new BufferedReader(new InputStreamReader( (urlc.getInputStream()))); String json = ""; String output; while ((output = br.readLine()) != null) { json += output; } conn.disconnect(); System.out.println("Employee name: " + em.getEmployeeName()); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } }}
使用第二个代码,我没有收到该错误,但没有插入数据库(使用邮递员检查,使用 GET 方法)...
好吧,我错过了什么?我想,我错过了一些基本的东西......
解决方案
使用 url.openConnection 两次意味着您获得了两个不同的连接。您将请求发送到第二个连接,并尝试从第一个连接读取响应。您应该在最初打开的连接上调用 doOutput。
第二个问题是您在发送请求之前调用 getResponseCode。在 http 中,请求必须在服务器发送响应之前完全发送。您应该在尝试检查响应代码的代码之前移动调用 doOutput 并写入请求正文的代码。
推荐阅读
- sql - 不正确的语法 - SQL
- konvajs - 如何使用 Konva 绘制多样式文本?
- php - 如何在 php 中创建自定义运输 shopify 应用程序?
- c++ - 标记颜色匹配系统中未定义的颜色和不存在样本
- node.js - IIS 和节点并排在同一 Windows 服务器上
- angularjs - Angular bootstrap uib-typeahead
- java - 为什么 Java DatagramSocket 没有收到客户端发送的所有 udp 数据包?
- postgresql - 多列索引和 ORDER BY
- angular - 无法获得嵌套的 formControlName 离子
- javascript - 如何替换图像中的特定颜色范围?