我与Spring Boot项目一起工作,我希望在程序启动后执行多个POST
请求,而不是之后手动使用cURL。目的是在存储器中存储一些数据,并使平台为进一步操作做好准备。我使用的原始cURL
命令(效果很好)
$ curl -i -X POST -H "Content-Type:application/json" -d "{\"name_of_doctor\" : \"Monika2\", \"price\": \"12.5\"}" http://localhost:8080/api/v1/appointments/createAppointment
接受它的API
@PostMapping(value = "/createAppointment", consumes = "application/json;charset=UTF-8", produces = "application/json;charset=UTF-8")
public ResponseEntity<Appointment> create(@RequestBody Appointment appointment) {
java.sql.Date date = new java.sql.Date(Calendar.getInstance().getTime().getTime());
java.sql.Time time = new java.sql.Time(Calendar.getInstance().getTime().getTime());
appointment.setAppointment_date(date);
appointment.setCraeted_at(time);
// we create the appointment, because, the doctor is available
appointment.setStatus(new Status(true));
// appointment.setStatus(true);
service.save(appointment);
return ResponseEntity.status(HttpStatus.CREATED).body(appointment);
}
现在,我在Spring Boot加载后立即完成
@SpringBootApplication
@EnableTransactionManagement
public class AppointmentApplication {
public static void main(String[] args) {
System.out.println("\n\nAppointment Manager\n\n");
SpringApplication.run(AppointmentApplication.class, args);
HttpClient client = HttpClientBuilder.create().build();
HttpPost post = new HttpPost("http://localhost:8080/api/v1/appointments/createAppointment");
List<NameValuePair> arguments = new ArrayList<>(2);
arguments.add(new BasicNameValuePair("name_of_doctor", "Monika"));
arguments.add(new BasicNameValuePair("price", "12.5"));
try {
post.setEntity(new UrlEncodedFormEntity(arguments));
//post.addHeader("content-type", "application/x-www-form-urlencoded");
post.setHeader("Accept", "application/json");
post.setHeader("Content-type", "application/json");
HttpResponse response = client.execute(post);
System.out.println(EntityUtils.toString(response.getEntity()));
} catch (IOException e) {
e.printStackTrace();
}
}
}
我收到以下错误消息,
{"timestamp":"2019-02-09T06:45:36.393+0000","status":400,"error":"Bad Request","message":"JSON parse error: Unrecognized token 'name_of_doctor': was expecting 'null', 'true', 'false' or NaN; nested exception is com.fasterxml.jackson.core.JsonParseException: Unrecognized token 'name_of_doctor': was expecting 'null', 'true', 'false' or NaN\n at [Source: (PushbackInputStream); line: 1, column: 16]","path":"/api/v1/appointments/createAppointment"}
在这种情况下,如何为POST调用正确设置媒体数据?
答案 0 :(得分:2)
以下代码将值添加为请求参数。
post.setEntity(new UrlEncodedFormEntity(arguments));
考虑到您的API期望请求正文中包含JSON
内容,您需要使用StringEntity
而不是UrlEncodedFormEntity
post.setEntity(new StringEntity("{ \"name_of_doctor\": \"\", \"price\": \"12.5\" }", Charset.forName("UTF-8")));