在我明白Google对JSessionID的关注不多之前,我在Facelets应用程序中允许URL重写(默认的Tomcat行为)。对于那些不知道的人,谷歌不喜欢这个关于SEO(你的URL上的会话ID),我自从在web.xml中包含以下内容来纠正这个问题:
<session-config>
<tracking-mode>COOKIE</tracking-mode>
</session-config>
问题在于我有很多500
错误来自过时的链接,这些错误会损害我的搜索引擎优化,因为网站引用过时的链接与这些jsession ID,例如:
http://thejarbar.org/views/tutorials/linux/Netbeans-
Install.xhtml;jsessionid=8D0EF52E48E8BB8BF8A4D7E33F831EFF
通过创建重定向到更新链接的页面,我已经修复了几个带有html或xhtml后缀的页面名称的错误,但我遇到的问题是我无法创建一个带有会话ID后缀的文件名,因为这赢了没有Tomcat服务。
重定向死HTML链接就像在相关目录中创建普通(X)HTML页面一样简单,并包含如下的元标记(示例):
.../Maven-Setup.xhtml
Maven-Setup.xhtml
<meta http-equiv="REFRESH" content="0;url=http://thejarbar.org/views/tutorials/linux/Maven-
Setup-Tutorial-for-Linux-with-the-Jar-Bar-and-Yucca-Nel.xhtml"></meta>
如何根据会话ID的过时网址重定向请求?我显然赞成保留这些链接,因为他们可能(或可能不会)为我的网站带来流量,因此我想重定向。
更新我创建了一个redirect.jsp,目的是在web.xml中映射url-pattern,将所有包含jsessionid的请求转发到我的新“no jsession”网站:
<servlet>
<servlet-name>redirect</servlet-name>
<jsp-file>/redirect.jsp</jsp-file>
</servlet>
<servlet-mapping>
<servlet-name>redirect</servlet-name>
<url-pattern>/*jsessionid*</url-pattern>
</servlet-mapping>
这不是使用jsession id转发请求,而是我已经测试了redirect.jsp
正确转发。
更新按照Balusc的建议和另一个我发现here的过滤器,我想出了这个似乎不适用于重定向到我的新网站:
package org.thejarbar.web.filters;
import java.io.*;
import java.util.HashMap;
import java.util.Map;
import java.util.regex.Pattern;
import javax.servlet.*;
import javax.servlet.http.*;
public final class JSessionFilter implements Filter {
public void init(FilterConfig filterConfigObj) {
}
public void doFilter(ServletRequest _req, ServletResponse _res,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest) _req;
HttpServletResponse res = (HttpServletResponse) _res;
String url =req.getRequestURL().toString();
if(Pattern.compile(Pattern.quote(url), Pattern.CASE_INSENSITIVE).matcher("jsessionid").find()){
String redirectURL = "http://thejarbar.org";
res.setStatus(301);
res.setHeader("Location",redirectURL);
res.setHeader( "Connection", "close" );
res.sendRedirect(redirectURL);
}
chain.doFilter(req, res);
}
public void destroy() { }
}
答案 0 :(得分:0)
根据BalusC上面的回答和我发现的here
的帖子,我终于得到了一个过滤器来修复我的问题我的过滤器实现如下:
package org.thejarbar.web.filters;
import java.io.*;
import java.util.regex.Pattern;
import javax.servlet.*;
import javax.servlet.http.*;
public final class JSessionFilter implements Filter {
public void init(FilterConfig filterConfigObj) {
}
public void doFilter(ServletRequest _req, ServletResponse _res,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest) _req;
HttpServletResponse res = (HttpServletResponse) _res;
String url =req.getRequestURL().toString();
if(url.indexOf(";jsessionid=")>0 ||
url.indexOf("views/tutorials/linux/Maven-Setup.xhtml") > 0 ||
url.indexOf("views/tutorials/windows/VirtualBox-Setup.xhtml") > 0 ||
url.indexOf("views/tutorials/windows/Path-Setup.xhtml") > 0 ||
url.indexOf("views/tutorials/windows/PATH-Setup.xhtml") > 0 ||
url.indexOf("views/tutorials/linux/Netbeans-Install.xhtml") > 0) {
String redirectURL = "http://thejarbar.org";
res.setStatus(res.SC_MOVED_PERMANENTLY);
res.setHeader("Location",redirectURL);
res.setHeader( "Connection", "close" );
return;
}
chain.doFilter(req, res);
}
public void destroy() { }
}
这会将我过时的每个链接链接到更新的网站。