下面发布的代码是一个客户端-服务器代码,它会抛出 http 500 错误,这是因为服务器抛出了一些异常。我实际上想将异常(在服务器端产生)发送到客户端,以便了解 http 500 错误的原因。为了发送堆栈跟踪,我使用此行 return Response.status(200).entity(err).build();
但客户端没有打印任何内容。请查看我的代码并告诉我如何从服务器获取抛出异常的堆栈跟踪?
ReactJS 客户端:
saveChanges(newRecordsArray) {
$.ajax({
type: "POST",
url: "http://localhost:8080/UserManagement/rest/myService/save",
dataType: "json",
contentType:'application/json',
data: newRecordsArray,
async: false
}).then((function(err) {
{console.log(err);}
}).bind(this));
}
Java 服务:
@POST
@Path("/save")
@Consumes(MediaType.APPLICATION_JSON)
public Response saveNewRecords(JSONArray newRecordsArray) {
try {
File recordsFile = new File("C:\\Users\\username\\Desktop\\myJSON.txt");
FileWriter fileWriter = new FileWriter(recordsFile);
fileWriter.write(newRecordsArray.toString());
fileWriter.close();
}
catch (Exception e) {
String err = e.getClass().toString();
return Response.status(200).entity(err).build();
}
return Response.status(200).entity(newRecordsArray.toString()).build();
}
最佳答案
您只收到异常消息的原因是因为 Response.status(200).entity(err).build()
调用了 toString()
方法你的异常对象。
如果您想以字符串形式获取完整的堆栈跟踪,那么我建议您使用外部库来帮助您完成这项工作。
Apache Commons Lang 库可能是一个完美的选择。这是您需要使用的静态方法:
org.apache.commons.lang.exception.ExceptionUtils.getFullStackTrace(e)
您可以找到有关此方法的更多详细信息here .
我建议您发回 HTTP500 而不是 HTTP200:
String exceptionString = ExceptionUtils.getFullStackTrace(e);
Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(exceptionString).build();
关于java - 客户端无法从服务器接收异常的堆栈跟踪,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46783176/