以下过程均基于chatgpt的回答进行操作
首先写一个过滤器,我这里是用"asoul"作为额外字符串,过滤器代码如下
import jakarta.servlet.*;
import jakarta.servlet.annotation.WebFilter;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebFilter("/*")
public class UserAgentFilter implements Filter {
public void init(FilterConfig config) throws ServletException {
// 初始化过滤器
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest) request;
HttpServletResponse httpResponse = (HttpServletResponse) response;
String userAgent = httpRequest.getHeader("User-Agent");
if (userAgent != null && userAgent.contains("asoul")) {
// User-Agent 中包含 "asoul",可以访问资源
chain.doFilter(request, response);
} else {
// User-Agent 中不包含 "asoul",拒绝访问
httpResponse.setContentType("text/plain");
httpResponse.setCharacterEncoding("UTF-8");
httpResponse.getWriter().write("推荐不要查看本文件详细内容.若要查看请把 User-Agent 加上 'asoul'");
}
}
public void destroy() {
// 销毁过滤器
}
}
然后让其编译成.class文件,接着把java文件和class文件都放进同一个文件夹
之后把tomcat/webapps/example里面的WEB-INF文件夹复制到想要限制访问的文件夹里(也是在webapps目录下)
接着把上述的java文件和class文件复制到WEB-INF\classes里面,就实现了Tomcat限制含有某字符串的user-agent才能访问资源的需求
复盘很简单,过程很艰难,绕了好多弯路,花了四五个小时,chatgpt能描述的再清楚一点就好了😭