[英]BufferedReader + BufferedWriter RESTful web service in wildfly 19
我有一段代码
@RequestScoped
@Path("test")
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.APPLICATION_XML)
public class Test {
private static final Logger LOG = Logger.getLogger(Test.class.toString());
@POST
public Response createRequest(InputStream request) throws IOException {
char[] buff = new char[1024];
int in = 0;
BufferedReader reader = new BufferedReader(new InputStreamReader(request));
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(System.out, "UTF-8"));
try {
while ((in = reader.read(buff)) != -1) {
//writer.write(buff);
writer.write(buff, 0, in);
}
} finally {
writer.flush();
writer.close();
reader.close();
}
return Response.ok().build();
}
}
问题是这个服务写入输出不完整的xml,即
输入
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
输出
04:55:44,190 INFO [stdout] (default task-1) <note>
04:55:44,191 INFO [stdout] (default task-1) <to>Tove</to>
04:55:44,191 INFO [stdout] (default task-1) <from>Jani</from>
04:55:44,198 INFO [stdout] (default task-1) <heading>Reminder</heading>
04:55:44,198 INFO [stdout] (default task-1) <body>Don't forget me this weekend!</body>
一个失踪
</note>
... 为什么?
当我第二次尝试发送请求时,控制台为空,我需要重新启动 Wildfly 才能将不完整的 xml 输入输出......为什么?
笔记:
我没有错误到控制台
好吧,经过长时间的失败,我找到了它不工作的原因......这有点令人不安......
所以......工作示例
@RequestScoped
@Path("test")
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.APPLICATION_XML)
public class ConnectorResourceV1 {
private static final Logger LOG = Logger.getLogger(ConnectorResourceV1.class.toString());
@POST
public Response test(InputStream request) throws IOException {
char[] buff = new char[16 * 1024];
int in = 0;
int lastIn = 0;
BufferedReader read = new BufferedReader(new InputStreamReader(request));
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(System.out));
while ((in = read.read(buff)) != -1) {
writer.write(buff, lastIn, in);
if (in < buff.length) {
if (in == 0) {
lastIn = in;
} else {
lastIn = lastIn + in;
}
}
}
writer.write("\r\n");
writer.flush();
return Response.ok().build();
}
}
注意writer.write("\\r\\n"); 它必须在这里,而且它似乎是一个流终止表达式??
另外,因为我使用 System.out 作为我的输出,所以我不需要关闭它,否则您将不会在控制台会话中看到输出。
一个非常令人不安的经历...
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.