`

Tomcat 7源码学习笔记 -6 encodeURL深度解析补充

阅读更多

之前提到调用response.encodeURL(String url)方法的时候,如果客户端支持cookie,那么不做任何处理,直接返回传进去的url,因为jsessionid可以写入cookie中,所以不需要url重写。其实所说的客户端支持cookie并不严谨,因为在客户端支持cookie的情况下,调用response.encodeURL(String url)方法,也会遇到对传进去的url进行重写的情况。那么什么情况下会出现这个问题呢?请看下面:

 

客户端支持cookie,第一次访问某个servlet,这时servlet接收到的request的cookie中没有jsessionid信息,这时encodeURL内部会认为客户端不支持cookie,所以会重写传进去的url,即使你在请求url中手动添加了正确的;jsessionid=30A7F107A1E5B1E7250622C158244032信息,也仍然会重写传进去的url。

 

由此可以得出encodeURL内部的具体的判定规则:

request的cookie中是否有正确的jsessionid信息。

有的话,就不重写传进去的url。否则符合重写url的条件(当然还有其他条件也必须符合)。

 

从代码中也可以得出相同的结论:

 

boolean isEncodeable(final String location)方法中

 

if (hreq.isRequestedSessionIdFromCookie()) {
        return (false);
}

 

isRequestedSessionIdFromCookie()方法如下:

public boolean isRequestedSessionIdFromCookie() {

        if (requestedSessionId == null) {
            return false;
        }

        return requestedSessionCookie;
}

 requestedSessionId是指从客户端得到的jsessionid的值,具体采用cookie传递还是url传递都没关系。

1.如果requestedSessionId为空,说明客户端没有传入jsessionid,当然cookie中也没有,所以符合url重写的条件。

2.如果requestedSessionId有值,再进一步判断这个jsessionid是否是从cookie中取到的,如果是那么就不用重写url,否则重写。

 

上面这些分析可以看出:

1.servlet或者说tomcat其实是无法准确地获知浏览器是否禁用了cookie。

2.即使浏览器禁用了cookie,只要servlet里面创建了session,那么jsessionid同样会写入response的cookie,并返回给客户端,只是浏览器不往本地cookie中写,直接忽略掉了。

3.只要在request的cookie中没有找到jsessionid,那么就可以进行url重写。

 

最后,顺便看一下HttpServletRequest中的下面这几个方法:

public String getRequestedSessionId() //获取客户端传过来的jsessionid的值

public boolean isRequestedSessionIdFromCookie() //request的cookie中是否有jsessionid

public boolean isRequestedSessionIdFromURL() //request url中是否有jsessionid

 

那么,有一个问题,如果客户端的cookie中含有jsessionid,同时request url中也含有jsessionid,这时候会怎么样呢?

 

答案是:使用cookie中的jsessionid

1.优先判断cookie中有没有,cookie中有的话,就使用cookie中的jsessionid

2.如果cookie中没有,再看request url中有没有

 

isRequestedSessionIdFromCookie()返回 true

isRequestedSessionIdFromURL()返回 false

 

分享到:
评论
1 楼 jacktao219 2016-01-06  
赞一个! 好文,但实际测试后发现第一次 浏览器也木有把url rewrite。。

相关推荐

    Tomcat_Session的持久化

    Tomcat_Session 的持久化 在 Web 应用程序中,Session 是一种用来跟踪用户状态的机制。Tomcat_Session 的持久化是指将 HttpSession 对象保存到文件系统或数据库中,以便在服务器关闭或重启时可以恢复 Session 数据...

    EncodeDecode经典加密解密+VB源码.rar

    EncodeDecode经典加密解密+VB源码.rarEncodeDecode经典加密解密+VB源码.rarEncodeDecode经典加密解密+VB源码.rarEncodeDecode经典加密解密+VB源码.rar

    php二维码扩展库exqrcode.zip

    $instance->setSize(7); //$instance->setDpi(72); $instance->encodeGeneral("hello world"); var_dump($instance->writeToFile("/tmp/qrgeneral.png")); $instance->encodeUrl("http://www.baidu.com"); ...

    comUtils前端代码常用工具类

    - `encodeURL`和`decodeURL`:对URL进行编码和解码。 - `parseQuery`:解析URL查询字符串为对象。 - `buildQuery`:将对象转换为URL查询字符串。 6. **DOM操作**: - `getElementById`、`...

    java练习题

    Java练习题,特别是针对J2EE的,是提升Java Web开发技能的重要途径。以下是一些相关的Java和J2EE知识点: 1. **Servlet生命周期**: - `init()` 方法:在Servlet...在学习和解答这些练习题时,理解这些概念至关重要。

    servlet学习笔记

    上某培训班的servlet笔记 Session 功能的实现依赖cookie URL 重写: 就是把原来送往客户端页面中的所有URL,重新编写. 怎么重新编写 String newURL=response.encodeURL(oldURL); 目的:保证session在...

    servlet2.4doc

    The default behavior of this method is to call encodeURL(String url) on the wrapped response object. encodeURL(String) - Method in interface javax.servlet.http.HttpServletResponse Encodes the ...

    JSP9大内置对象.pdf

    ##### 6. **out对象** - **定义**:`out`对象用于向客户端输出数据。 - **主要方法**: - `print(String text)`:向客户端输出文本。 - `println(String text)`:向客户端输出文本并换行。 ##### 7. **config...

    关于web回话跟踪session

    例如,在Servlet或JSP文件中,可以使用`HttpServletResponse`接口中的`encodeURL()`和`encodeRedirectURL()`方法来对URL进行编码。这两个方法的作用在于确保即使在没有Cookie的情况下,也能通过URL重写的方式维持...

    commons-codec-1.15-bin.rar

    2. **URL编码和解码**:在处理网络请求时,URL中可能包含特殊字符,这些字符需要进行编码以避免引起解析错误。通过HttpUtils类的encodeUrl()和decodeUrl()方法,开发者可以轻松地对URL进行编码和解码。 3. **HEX...

    用Java写的登录注册功能

    6. **Spring Boot集成**:现代Java Web开发往往使用Spring Boot,它简化了Spring应用的启动和配置,自动配置了许多常用组件,如数据源、Tomcat服务器等。 7. **前端交互**:虽然描述中未提及,但通常会结合HTML、...

    JAVA程序开发技术

    - **方法**:`response.encodeURL(url)`. **5.7 JSP及结构** **5.7.1 JSP的组成** - **组成部分**: - HTML标签; - JSP指令; - JSP动作; - 表达式; - Java脚本。 **5.7.2 JSP的隐含对象** - **常见对象*...

    JAVA jSOUP解析html

    public static String encodeUrl(String url) { // URL编码 } public static String decodeUrl(String encodedUrl) { // URL解码 } public static String buildUrl(String baseUrl, String path) { // ...

    JSR-168 Portlet指南.doc

    6. **处理portlet事件**:JSR-168允许portlet之间通过发布和订阅事件进行通信。开发者应充分利用这一特性来实现portlet间的协作和数据共享。 7. **安全考虑**:确保portlet遵循安全最佳实践,如使用安全的HTTP头,...

    Java Web应用开发 51 课堂案例-应用Servlet读取Session数据.docx

    - `res.encodeURL("Session")`:在链接中,Servlet会自动处理Session ID的编码,以确保在URL重写时正确地处理Session。 6. **Servlet生命周期方法**: - 代码7-38行重载了`doGet()`方法,这是Servlet处理HTTP GET...

    用JSP做的网上交友页面

    <a href="<%=response.encodeURL("showMember.jsp")%>">浏览会员| <a href="<%=response.encodeURL("register.jsp")%>">会员注册| <a href="<%=response.encodeURL("login.jsp")%>">会员登录| ...

    jsp基础

    - URL重写:`response.encodeURL()`,将session ID添加到URL中,以保持会话状态。 - 添加cookie:`response.addCookie()`,向响应中添加cookie。 #### 三、JSP页面构成与特性 JSP(JavaServer Pages)是一种简化...

    javax.servlet.http使用帮助.docx

    - **encodeURL(String url)**:对 URL 进行编码。 - **decodeURL(String url)**:对 URL 进行解码。 #### 三、示例代码 以下是一个简单的示例,展示了如何使用 `HttpServletRequest` 和 `HttpServletResponse` ...

    JSP面试经常问到的知识

    这允许JSP引擎将JSP代码解析并转换为Servlet。 2. **线程安全的JSP**: - 通过在JSP页面中添加`<%@ page isThreadSafe="false" %>`指令,可以确保JSP实例不被多个线程同时访问,从而实现线程安全。 3. **处理HTML...

Global site tag (gtag.js) - Google Analytics