总述
在一个sevlet中请求了另一个servlet并将其结果写出, 类似于代理
使用printwirter写出内容, postman请求无输出内容, 等待几秒后报错, 控制台提示
十二月 21, 2020 2:51:57 下午 org.apache.catalina.connector.CoyoteAdapter checkRecycled 信息: Encountered a non-recycled response and recycled it forcedly. org.apache.catalina.connector.CoyoteAdapter$RecycleRequiredException at org.apache.catalina.connector.CoyoteAdapter.checkRecycled(CoyoteAdapter.java:632)
处理: 在写出servlet响应前再次调用resp.getWriter();
现象
简化代码:
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.alibaba.fastjson.JSONObject;
public class TestServlet extends HttpServlet {
PrintWriter pw;
private static final long serialVersionUID = 1L;
@Override
public void init() throws ServletException {}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
pw = resp.getWriter();
pw.write("{\"a\":\"3\"}");
System.out.println(pw);
if (!"xx".equals(req.getHeader("mark"))) { // 是否代理的标志
String _url = "本机接口地址";
System.out.println("转发>>>");
JSONObject r = NetUtils.doRequest(_url, "{}"); // 里面添加了header:mark=xx
// pw = resp.getWriter(); // 引用1(后面描述用)
pw.write("{\"a\":\"4\"}");
pw.flush();
pw.close();
return;
}
pw.flush();
pw.close();
}
}
目的: 检测请求头中是否有mark, 如果有则正常处理, 如果没有则添加mark并转发, 将请求的结果写出;
代码中"引用1"的位置:
如果注释, 则会提示前面描述的错误, 并且输出只有{"a":"3"}
,
如果不注释, 则不会提示错误, 并且输出为{"a":"3"}{"a":"4"}
原因未知.