javaWeb---jsp和cookie

一、jsp
1、JSP(Java Server Pages)是JavaWeb服务器端的动态资源。它与html页面的作用是相同的,显示数据和获取数据。JSP = html + Java脚本(代码片段) + JSP动态标签
2、JSP脚本就是Java代码片段,它分为三种:
<%…%>:Java语句;
<%=…%>:Java表达式;
<%!…%>:Java定义类成员;
3、JSP是一种特殊的Servlet,当JSP页面首次被访问时,容器(Tomcat)会先把JSP编译成Servlet,然后再去执行Servlet。所以JSP其实就是一个Servlet!即JSP是需要先编译成.java,再编译成.class的。
jsp原理(理解)
* jsp其实是一种特殊的Servlet
当jsp页面第一次被访问时,服务器会把jsp编译成java文件(这个java其实是一个servlet类)(第一次惩罚)
然后再把java编译成.class
然后创建该类对象
最后调用它的service()方法
第二次请求同一jsp时,直接调用service()方法。
jsp注释
* <%– … –%>:当服务器把jsp编译成java文件时已经忽略了注释部分!
:html注释
二、什么是会话跟踪技术
我们需要先了解一下什么是会话!可以把会话理解为客户端与服务器之间的一次会晤,在一次会晤中可能会包含多次请求和响应。例如你给10086打个电话,你就是客户端,而10086服务人员就是服务器了。从双方接通电话那一刻起,会话就开始了,到某一方挂断电话表示会话结束。在通话过程中,你会向10086发出多个请求,那么这多个请求都在一个会话中。
在JavaWeb中,客户向某一服务器发出第一个请求开始,会话就开始了,直到客户关闭了浏览器会话结束。
会话路径技术使用Cookie或session完成
我们知道HTTP协议是无状态协议,也就是说每个请求都是独立的!无法记录前一次请求的状态。但HTTP协议中可以使用Cookie来完成会话跟踪!
在JavaWeb中,使用session来完成会话跟踪,session底层依赖Cookie技术。
三、Cookie(是服务器保存到客户端的东西)
1. Http协议与Cookie(了解)
* Cookie是HTTP协议制定的!先由服务器保存Cookie到浏览器,再下次浏览器请求服务器时把上一次请求得到Cookie再归还给服务器
* 由服务器创建保存到客户端浏览器的一个键值对!服务器保存Cookie的响应头:Set-Cookie: aaa=AAA Set-Cookie: bbb=BBB
response.addHeader(“Set-Cookie”, “aaa=AAA”);response.addHeader(“Set-Cookie”, “bbb=BBB”);
* 当浏览器请求服务器时,会把该服务器保存的Cookie随请求发送给服务器。浏览器归还Cookie的请求头:Cookie: aaa=AAA; bbb=BBB
* 如果服务器端发送重复的Cookie那么会覆盖原有的Cookie,例如客户端的第一个请求服务器端发送的Cookie是:Set-Cookie: a=A;第二请求服务器端发送的是:Set-Cookie: a=AA,那么客户端只留下一个Cookie,即:a=AA。
* Http协议规定(保证不给浏览器太大压力):

1个Cookie最大4KB
1个服务器最多向1个浏览器保存20个Cookie
1个浏览器最多可以保存300个Cookie
* 浏览器大战:因为浏览器竞争很激励,所以很多浏览器都会在一定范围内违反HTTP规定,但也不会让一个Cookie为4GB!

  1. Cookie的用途

    • 服务器使用Cookie来跟踪客户端状态!
    • 保存购物车(购物车中的商品不能使用request保存,因为它是一个用户向服务器发送的多个请求信息)
    • 显示上次登录名(也是一个用户多个请求)

    *****Cookie是不能跨浏览器的!******

  2. JavaWeb中使用Cookie

    • 原始方式(了解):

    使用response发送Set-Cookie响应头
    使用request获取Cookie请求头

  3. 便捷方式(精通):
    使用repsonse.addCookie()方法向浏览器保存Cookie
    使用request.getCookies()方法获取浏览器归还的Cookie,没有就返回null,所以得到他之后要进行判断是否为空
 <h1>保存cookie</h1>
    <%
    Cookie cookie1 = new Cookie("aaa","AAA");
    response.addCookie(cookie1);
    Cookie cookie2 = new Cookie("bbb","BBB");
    response.addCookie(cookie2);
    %>
<h1>获取cookie</h1>
    <%
    Cookie[] cookies = request.getCookies();
    //一定要判断是否为null
    if(cookies!=null){
        for(Cookie c:cookies){
            out.print(c.getName()+"----"+c.getValue());
        }
    }
    %>

Cookie详解
* Cookie不只有name和value两个属性
* Cookie的maxAge(掌握):Cookie的最大生命,即Cookie可保存的最大时长。以秒为单位,例如:cookie.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘上60秒

maxAge>0:浏览器会把Cookie保存到客户机硬盘上,有效时长为maxAge的值决定。
maxAge<0:Cookie只在浏览器内存中存在,当用户关闭浏览器时,浏览器进程结束,同时Cookie也就死亡了。
maxAge=0:浏览器会马上删除这个Cookie!如果重新发送一个cookie与之前的同名,会把之前的也给删除。

  • Cookie的path(理解):
    Cookie的path并不是设置这个Cookie在客户端的保存路径!!!
    Cookie的path由服务器创建Cookie时设置
    当浏览器访问服务器某个路径时,需要归还哪些Cookie给服务器呢?这由Cookie的path决定。
    浏览器访问服务器的路径,如果包含某个Cookie的路径,那么就会归还这个Cookie。

    例如:
    aCookie.path=/day11_1/; bCookie.path=/day11_1/jsps/; cCookie.path=/day11_1/jsps/cookie/;
    访问:/day11_1/index.jsp时,归还:aCookie
    访问:/day11_1/jsps/a.jsp时,归还:aCookie、bCookie
    访问:/day11_1/jsps/cookie/b.jsp时,归还:aCookie、bCookie、cCookie

    Cookie的path默认值:当前访问路径的父路径。例如在访问/day11_1/jsps/a.jsp时,响应的cookie,那么这个cookie的默认path为/day11_1/jsps/

猜你喜欢

转载自blog.csdn.net/ilikejj0/article/details/80166796
今日推荐