javax.servlet.http.HttpServletResponse 得到 status_code

javax.servlet.http.HttpServletResponse 得到 status_code

一) 在log4j的日志中需要输出应答的status_code,不用还真不知道,HttpServletResponse接口并没有getStatus()方法。

二) 自己动手,用一个Reponse的装饰器,解决这个问题。这算是一个过滤器和装饰器设计模式的典型应用吧

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import ying.car.shiro.ShiroUtils;

/**
* 记录http信息的Filter
*
*
*/
public class HttpInfoLoggingFilter implements Filter{

private static final Logger LOGGER = LoggerFactory.getLogger(HttpInfoLoggingFilter.class);

@Override
public void init(FilterConfig filterConfig) throws ServletException {
// 无配置
}

@Override
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) req;
StatusExposingServletResponse response = new StatusExposingServletResponse((HttpServletResponse) res);

Integer currentUserId = getCurrentUserId();
String ip = request.getRemoteAddr();
String method = request.getMethod();
String url = request.getRequestURI();
String characterEncoding = request.getCharacterEncoding();
String referer = request.getHeader("Referer");
chain.doFilter(request, response);
int status = response.getStatus();
LOGGER.info("{}, {}, {}, {}, {}, {}, {}", currentUserId, ip, method, characterEncoding, referer, url, status);
}

@Override
public void destroy() {
// 无动作
}

private Integer getCurrentUserId() {
Integer currentUserId = 0;
try { currentUserId = ShiroUtils.getPrincipalDomainId(); } catch (Exception e) {} // apache-shiro框架
return currentUserId;
}

//~ ============================================================================================================================
public static class StatusExposingServletResponse extends HttpServletResponseWrapper implements HttpServletResponse {

private int status = 200;

public StatusExposingServletResponse(HttpServletResponse response) {
super(response);
}

@Override
public void setStatus(int sc) {
this.status = sc;
super.setStatus(sc);
}

public int getStatus() {
return status;
}
}
}


web.xml

<!-- apache-shiro 核心拦截器 -->
<filter>
<filter-name>shiroFilter</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
<filter-name>shiroFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

<!-- http信息日志过滤器 -->
<filter>
<filter-name>httpInfoLoggingFilter</filter-name>
<filter-class>ying.car.filter.HttpInfoLoggingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>httpInfoLoggingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!下面是一个使用Java代码在Eclipse创建网页的示例,该网页可以根据输入的车牌号显示金额: ```java import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class TruckParkTimeServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String truckNo = request.getParameter("truckNo"); String apiUrl = "http://10.198.8.102:8081/TruckParkTime?Token=Parking2023&TruckNo=" + truckNo; // 发送HTTP GET请求获取接口返回结果 URL url = new URL(apiUrl); HttpURLConnection connection = (HttpURLConnection) url.openConnection(); connection.setRequestMethod("GET"); int responseCode = connection.getResponseCode(); if (responseCode == HttpURLConnection.HTTP_OK) { BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream())); StringBuilder responseBuilder = new StringBuilder(); String line; while ((line = reader.readLine()) != null) { responseBuilder.append(line); } reader.close(); String apiResponse = responseBuilder.toString(); // 解析接口返回结果 String money = ""; if (apiResponse.contains("\"Money\":")) { int startIndex = apiResponse.indexOf("\"Money\":") + "\"Money\":".length(); int endIndex = apiResponse.indexOf("\"", startIndex); money = apiResponse.substring(startIndex, endIndex); } // 构建HTML响应 response.setContentType("text/html"); response.setCharacterEncoding("UTF-8"); response.getWriter().println("<html>"); response.getWriter().println("<body>"); response.getWriter().println("车牌号:" + truckNo); response.getWriter().println("<br>"); response.getWriter().println("金额:" + money); response.getWriter().println("</body>"); response.getWriter().println("</html>"); } else { // 处理请求失败的情况 response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR); } } } ``` 这是一个简单的Servlet,它接收GET请求并从指定的接口获取车辆信息。您可以将此代码添加到您的Java Web项目,并在Eclipse部署和运行该项目。请确保您的项目包含Servlet API库。 当您在浏览器访问此Servlet时,可以通过URL参数`truckNo`传递车牌号,然后它将从接口获取金额并将其显示在生成的网页上。 请注意,这只是一个简单的示例,您可能需要根据实际需求进行修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值