每个网页或请求都是一个url地址,一般,这个地址可能是.do .action .php之类的并加上'?'号、'&'号查询串等构成的一个长长的的url。不利于阅读,同时将实际的地址暴露给用户,容易遭到攻击。
一般的url----------------------------------------------------------较好的 url
http://www.xxx.net/user/profile.do?id=20001 ====> http://www.xxx.net/user/20001
http://www.xxx.net/forum/board.do?name=java ====> http://www.xxx.net/forum/java
http://www.xxx.net/forum/thread.do?id=29923 ====> http://www.xxx.net/thread/29923
后者明显较为直观和漂亮。
使用url rewrite可以很好的改善这个状况。网站url rewrite应用是非常广泛的,良好的url设计给用户带来的非常好的体验,同时也能吸引搜索引擎的注意。
一种rewrite称为一个规则,上面的例子就是3个规则。Apache HTTP Server 2.x的mod_rewrite提供了不错的Rewrite处理方法,java中有 http://tuckey.org/urlrewrite/。
下面我们用一个Filter来模拟实现。
public class RewriteFilter implements Filter {
private ServletContext ctx;
private List<RewriteEntry> entries = new ArrayList<RewriteEntry>();
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain nextFilter) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest) request;
HttpServletResponse resp = (HttpServletResponse) response;
String url = req.getRequestURI();
for (RewriteEntry entry : entries) {
Matcher matcher = entry.getPattern().matcher(url);
if (!matcher.find(0))
continue;
String replacement = replace(matcher, entry.getTarget());
String query = req.getQueryString();
if (query != null) {
if (replacement.indexOf("?") > 0)
replacement = replacement + "&" + query;
else
replacement = replacement + "?" + query;
}
if (replacement.startsWith("/")) {
RequestDispatcher dispatcher = ctx.getRequestDispatcher(replacement);
dispatcher.forward(request, response);
return;
} else {
resp.sendRedirect(resp.encodeRedirectURL(replacement));
return;
}
}
// TODO 只有不匹配的情况下,程序才能运行到这里
// 这样必须把RewriteFilter配置到Filter顺序的最后
nextFilter.doFilter(request, response);
}
private String replace(Matcher matcher, String target) {
StringBuffer cb = new StringBuffer(512);
int length = target.length();
for (int i = 0; i < length; i++) {
char ch = target.charAt(i);
// target : /index.jsp?id=$1
if (ch != '$' || i == length - 1)
cb.append(ch);
else {
ch = target.charAt(i + 1);
if (ch >= '0' && ch <= '9') {
int group = ch - '0';
cb.append(matcher.group(group));
i++;
} else if (ch == '$') {
cb.append('$');
i++;
} else
cb.append('$');
}
}
return cb.toString();
}
/**
* 解析rewrite.properties文件,生辰需要rewrite的Bean
*/
public void init(FilterConfig filterConfig) throws ServletException {
ctx = filterConfig.getServletContext();
File cfgFile = new File(ctx.getRealPath("/WEB-INF/rewrite.properties"));
BufferedReader reader = null;
try {
reader = new BufferedReader(new FileReader(cfgFile));
String line = null;
while ((line = reader.readLine()) != null) {
if (line.trim().equals("") || line.trim().startsWith("#"))
continue;
String[] temp = line.split(" ", 2);
entries.add(new RewriteEntry(temp[0], temp[1]));
}
} catch (IOException e) {
throw new RuntimeException(e);
} finally {
if (reader != null) {
try {
reader.close();
} catch (IOException e) {
}
}
}
}
public static class RewriteEntry {
private Pattern pattern;
private String target;
public RewriteEntry(String pattern, String target) {
this.pattern = Pattern.compile(pattern);
this.target = target;
}
public Pattern getPattern() {
return pattern;
}
public String getTarget() {
return target;
}
}
}
web.xml文件
<web-app>
<filter>
<filter-name>rewriteFilter</filter-name>
<filter-class>demo.RewriteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>rewriteFilter</filter-name>
<url-pattern>*.html</url-pattern>
</filter-mapping>
</web-app>
/WEB-INF/rewrite.properties文件
引用
^\/index\/(.*)\.html$ /index.jsp?id=$1
^\/hello\/(.*)\.html$ /hello.jsp?name=$1
hello.jsp
<h3>Hello, <%=request.getParameter("name")%>!</h3>
index.jsp
<h3>URL: <%=request.getRequestURI()%></h3>
<h3>Query: <%=request.getQueryString()%></h3>
我们运行页面,输入
http://localhost:8888/index/xace.html
输出:
URL: /index.jsp
Query: id=xace
http://localhost:8888/hello/xace.html
输出:
Hello, xace!
分享到:
相关推荐
URLWriter 是一种用于实现 URL 重写的工具,它能够帮助开发者在不改变服务器端原有资源的情况下,对客户端显示的 URL 进行自定义设置,从而实现更加友好和易于理解的 URL 结构。本教程将详细介绍如何在项目中使用 ...
`Urlwriter` 提供了许多高级功能,如条件、拦截器、自定义函数等,可以实现复杂的需求。例如,你可以根据用户的角色或请求的参数来决定是否执行重写,或者在 URL 重写前后执行自定义逻辑。 条件可以用来进一步细化...
通过上述分析可以看出,`yuMatlabFilter` 函数成功地在C++中实现了MATLAB的 `filter` 功能。此实现不仅遵循了MATLAB中的算法逻辑,而且针对C++的特点进行了适当的调整。这种方法可以应用于多种信号处理场景,具有较...
本文将详细探讨如何通过`Filter`实现权限控制,以及与RBAC(Role-Based Access Control,基于角色的访问控制)的关系。首先,让我们理解`Filter`的概念。 `Filter`是Java Servlet API中的一个重要组件,它允许我们...
`Filter`通过实现`javax.servlet.Filter`接口并重写`doFilter()`方法来定义其功能。 2. **配置Filter**:在`web.xml`中配置`Filter`,包括定义`<filter>`、`<filter-mapping>`元素,指定过滤器的类名以及需要拦截的...
KalmanFilter,KalmanFilter3,Kalman...一共7种,以上三种实现保证可用,其余待调试,调试函数写好,直接运行即可 KalmanFilter KalmanFilter2 KalmanFilter3 KalmanFilter4 KalmanFilter5 KalmanFilter6 KalmanFilter7
通过上述的Cookie和Filter实现,我们可以理解SSO的基本工作流程。但要注意,这只是最基础的实现方式,实际部署时需要考虑更多的安全性和扩展性因素。对于大型企业或复杂网络环境,通常会采用更为成熟和安全的SSO解决...
标题中的“通过filter实现对输出内容的压缩处理”是指在编程中使用过滤器(Filter)技术来对输出数据进行压缩,以减少网络传输的数据量,提高传输效率,节省带宽资源。这种技术常见于Web开发中,如Java的Servlet ...
因为需要使用filter函数(MATLAB内置函数),曾在网上copy过一段代码,但是那个算法实现的不全,没有计算zf,所以我自己结合MATLAB帮助重写了一下,测试结果OK
`highpass_filter.py`文件可能包含了这样的实现,通过定义滤波器的截止频率和其他参数来定制滤波效果。 Python中实现高通滤波的一个常见库是`scipy.signal`,它提供了丰富的滤波器设计和应用函数。例如,可以使用`...
利用java filter 实现业务异常拦截 跳转到错误信息提示页面 我们在做项目中肯定都会遇到自定义业务异常 ,然后将业务异常信息跳转的统一的信息提示页面的情况,比如我们在struts的时候我们会用到struts的异常处理...
【Java通过Filter实现允许服务跨域请求的方法】 在Web开发中,浏览器的同源策略是一项安全机制,限制了JavaScript只能发起与当前页面同源(协议、域名和端口相同)的HTTP请求。然而,随着前后端分离的发展,跨域...
- **创建Filter配置**:首先,你需要为想要过滤的列定义过滤器配置,这可以通过`filterable: true`属性实现,并且可以通过`filters`配置项来指定具体的过滤类型。 - **添加Filter UI**:在列头显示过滤器图标,可以...
在Web开发中,验证登录...通过以上步骤,我们可以创建一个基本的`LoginFilter`来实现登录验证。在实际项目中,还需要考虑更多细节,如错误处理、会话超时、记住我功能等。同时,确保遵循最佳实践,以提高系统的安全性。
在这个“Filter实现自动登录”的场景中,我们通常会利用`Filter`来实现用户登录状态的检查和维持,以达到无感知的自动登录效果。下面将详细介绍这个主题。 1. **Filter的基本原理**: `Filter`是JavaWeb中的一种...
- 可以通过多个Filter组合实现复杂的拦截逻辑,例如先进行身份验证,再进行权限检查。 - 为Filter提供明确的名称和合理的URL映射,以便于理解和维护。 通过以上讲解,你应该对使用Servlet Filter实现权限拦截有了...
自定义Filter通常需要继承Spring Security的已有Filter或实现其接口。例如,如果你想要实现自定义的登录认证,可以扩展`AbstractAuthenticationProcessingFilter`。这个类提供了处理登录请求的基本结构,包括解析...
总结起来,Filter是Java Web中一个强大的工具,通过它可以实现数据预处理、后处理等多种功能。通过合理配置和使用,可以极大地提高应用程序的安全性和效率。在实际项目中,Filter常用于处理全局性的问题,如统一字符...
为了实现过滤脏话的功能,开发者通过JSP中的`Filter`类来完成。具体来说,是将一些敏感词汇封装在一个文本文件中,当用户提交的内容中包含这些敏感词汇时,通过过滤器时这些词汇将会被替换为星号“*”。 #### 代码...