gpt4 book ai didi

java - 从tomcat中的Filter类方法响应servlet客户端时如何设置http状态代码

转载 作者:行者123 更新时间:2023-11-28 22:04:12 24 4
gpt4 key购买 nike

我正在用 spring 编写一个 web 服务(这个问题不是关于 spring ...),它实现了一个(希望)restful api。据我了解,所有响应都应采用 xml 或 json 格式。在大多数情况下,这并不是什么大问题。但在一种情况下,这似乎是不可能的。我正在使用 tomcat 中涉及 servlet 的工具。出于某种原因我必须使用过滤器(这个原因是身份验证)。由于我是 servlet 的新手,我的理解最终不是很好,但对我来说它看起来像这样

我的过滤器类派生自 javax.servlet.filter,我在 doFilter 方法中编写代码:

@Override
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException { // ... }

在某些时候,我意识到我必须使用 http 状态代码 401 响应客户端,并且还想向他提供有关所发生情况的 xml 或 json 信息。现在对我来说似乎我也可以

1) 使用 ServletResponse:这允许我获得一个 OutputStream 并写出我的 xml/json。但是我根本无法设置 http 状态代码。到达客户端的最终响应确实包含一些 http header 。

2) 将 ServletResponse 转换为 HttpServletResponse:这允许我设置状态代码,但我似乎无法设置响应主体,但让 tomcat 处理响应主体。

这两种方式似乎都不完整。如果我使用 ServletResponse 写入 OutputStream,然后转换为 HttpServletResponse,然后调用 sendError(401) - 希望我写入 OutputStream 的任何内容都能到达客户端 - 我的响应不包含 http“状态行”。然而,http header 的存在类似于“服务器:Apache-Coyote/1.1”

欢迎任何帮助...

最佳答案

我很快就实现了一个身份验证过滤器。我编写了类似这样的代码:

public void doFilter(ServletRequest req, ServletResponse resp,
FilterChain chain)
{
HttpServletResponse response=(HttpServletResponse) resp;

boolean authenticated=false;
// perform authentication

if (authenticated)
{
chain.doFilter(req, response);
}
else
{
// don't continue the chain
response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
response.setHeader("WWW-Authenticate", "BASIC realm=\"Your realm\"");

response.setContentType("what you need");
PrintWriter writer=response.getWriter();

// don't set content length , don't close
}
}

关于java - 从tomcat中的Filter类方法响应servlet客户端时如何设置http状态代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35767502/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com