会话技术: Cookie Session JSP

##  Cookie

A..概念:客户端会话技术,将数据保存到客户端

B.使用步骤:

1.创建Cookie对象,绑定数据

new Cookie(String  name, String value)

2.发送Cookie对象

response.addCookie(Cookie cookie)

  1. 获取Cookie,拿到数据

request.Cookie[]getCookies

`      C.实现原理

基于相应头set-cookie和请求头cookie实现

D.cookie的细节

1.一次可不可以发送多个cookie?

# 可以,创建多个cookie对象,使用response调用多次addCookie方法发送Cookie

2.cookie在浏览器中保存多久

1.默认情况下,当浏览器关闭,Cookie数据被销毁

2.持久化存储:

setMaxAge(int seconds)

  1. 正数:将Cookie数据写到硬盘文件中。持久化存储。Cookie存活时间
  2. 负数:默认值
  3. 0:删除cookie信息

3.cookie能不能存储中文

在Tomcat 8之前cookie中不能直接存储中文数据,需要将中文数据转码,一般采用URL编码(%E3)

在Tomcat8之后,cookie支持中文数据。特殊字符还是不支持建议使用URL编码

  1. cookie共享问题

假设在一个Tomcat服务器中部署多个web项目,那么这些web项目cookie能不能共享?

默认情况下cookie不能共享

setPath(String path):设置cookie的获取范围,默认情况下,这点当前虚拟目录,如果要共享,则可以将path设置为“/”

不同的同名cat服务器cookie共享问题

setDomain(String path):如果设置一级域名相同,那么多个服务器之间cookie可以共享

E.Cookie的特点和作用

1.cookie存储数据在客户端浏览器

2.浏览器对于单个cookie的大小有限制(4kb)以及在同一域名下总cookie数量也是有限制的(20个)

作用:cookie一般用于存储少量不太敏感的数据

在不登录的情况下,完成服务器的客户端的身份识别

F.案例:记住上一次访问时间

需求:

1.访问一个Servlet,如果是第一次访问,则提示:欢迎首次访问

2. 如果不是第一次访问,则提示:欢迎回来,上次访问的时间为:显示时间的字符串

分析:

  1. 可以采用Cookie来完成
  2. 在服务器的Servlet判断是否有一个名为lastTime的cookie

有:不是第一次访问,回写Cookie:lastTime=

没有:是第一次访问,相应数据:欢迎首次访问,回写一个Cookie,时间字符串

IE浏览器可能会出现错误500

## Session:

A.概念:服务器会话技术,在一次会话的多次请求间共享数据,将数据保存服务器的对象中,HttpSession

B.  获取HTTPSession对象:

HTTPSession session=request.getSession();

使用HttpSession对象

Object getAttribute(String name)

Void setAttribute(String name,Object value)

Void removeAttribute(String name)

C.原理

Session的实现是依赖于Cookie的。

D.细节:

1.当客户端关闭,服务器不关闭,两次获取session是否为同一个?

*默认情况下不是

*如果需要,则可以创建Cookie,键为JSESSIONID,设置最大存活时间。让cookie持久化存储

Cookie c=new Cookie(“JSESSIONID”,session.getId());

c.setMaxAge(60*60)

response.addCookie(c)

2客户端不关闭,服务器关闭后,俩次获取的session是同一个吗?

不是同一个,但是要确保数据不丢失。Tomcat自动完成以下工作

Session的钝化:

在服务器正常关闭之前,将session对象序列化到硬盘上

Session的活化:

在服务器启动之后,将session文件转化为内存的session对象即可

1.      Session什么时候被销毁?

1.      关闭服务器

2.      Session对象调用invalidate().

3.      Session默认实效时间是30分钟

E.  session的特点

1.session用于存储一次会话的多次请求的数据,存在服务器端

2.session可以存储任意类型,任意大小的数据

Session与Cookie的区别

1.      session存储数据在服务器端,Cookie在客户端

2.      session没有数据大小限制,Cookie有

3.      session数据安全,Cookie相对于不安全

JSP初级

A.      JSP

1.      指令

*作用:用于配置JSP页面,导入资源文件

*格式:<%@ 指令名称属性名1=属性值1 属性2=属性值2....>

*  分类:

1.page:配置JSP页面的

*contenyType:等同于response.setContenType

1.      设置相应体的mime类型以及字符集

2.      设置当前jsp页面和编码

*import: 导包

*errorPage:当前页面异常后,自动跳转指定的错误页面

*isErrorPage:表示当前也是错误页面

默认是false,不可以使用内置对象,true:可以使用内置对象exception

2include:页面包含的,导入页面的资源文件

<%@include file=”top.jsp”%>

3.taglib : 导入资源

2.      注释

htlm注释<!--   -->

jsp<%--   --%>

3.      内置对象

*在jsp页面中不需要创建,直接使用的对象

一共有9个

变量名                                真正类型                                 作用

pageContext                        PageContext                             当前页面共享数据,还可以获取其他八个内置对象

request                                HttpServletRequest                  一次请求访问的多个资源

session                                 HttpSession                              一次会话的多个请求

application                          ServletContext                         所有用户间共享数据

response                              HttpServletResponse                相应对象

page                                    Object                                      当前页面(Servlet)的对象

out                                       JspWriter                                  输出对象,数据输出到页面上

config                                  ServletConfig                           Servlet的配置对象

exception                            Throwable                                异常对象

B.      MVC开发模式

1.      早期只有Servlet,只能使用respomse输出标签,非常麻烦

2.      后来又jsp,简化了Servlet的开发,如果过度使用jsp,在jsp中既写大量的java代码,又写html表,造成难以维护,难以分工协作

3.      再后来,java的web开发,借鉴mvc开发模式,使程序的设计更加合理性

MVC:

M.  Model,模型:完成具体的业务操作,如:查询数据库,封装对象

V.     View  视图:展示数据

C.      Controller:  控制器:获取用户的输入,调用模型,将数据交给视图进行展示

优点:耦合性低,方便维护,可以利于分工协作,重用性高

缺点:使项目架构变的复杂,对开发人员要求高

C.      EL表达式

概念:Expression Language  在 JSP 中简化表达式的方法

语法:${表达式}

在jsp默认支持el表达式如果要忽略el表达式

1.     设置jsp中page指令中:isELIgnored=”true”  忽略当前jsp页面中所有el表达式

2.     \${表达式}:忽略当前这个el表达式

使用:

运算符

算数运算符:+ — * /(div)  %(mod)

比较运算符:> <  >=  ==  !=

逻辑运算符:  &&(and) ||(or)  !(not)

空运算符:empty

功能:用于判断字符串,集合,数组对象是否是null并且长度是否为0

获取值:

1.el表达式只能从指定域中获取值

${域名称.键名} :从指定域中获取指定值

域名称

1.pageScope             àpageContext

2.requestScope           àrequest

3.sessionScope          àsession

4.applicationScope        àapplication(ServletContext)

举例:在request域中存储了name=张三

获取:${requsetScope.name}

2.${键名}:表示依次从最小的域中查找是否有该键对应的值

3.获取对象,List集合,Map集合的值

1.对象:${域名称.键名,属性名}

2.List集合:${域名称.建名[索引]}

3.Map集合:

${域名称。键名.key名称}

${域名称。键名.[“key名称”]}

隐式对象:

el表达式中有11个隐式对象

pageContext:

获取jsp其他八个内置对象

${pageContext.request.contextPath}:动态获取虚拟目录

D.     JSTL标签

a)        JavaServer Pages Standard Tag Library  JSP标准标签库

b)        用于简化和替代jso页面的java代码

c)        使用步骤

1.    导入jstl相关jar包

2.      引入标签库:taglib指令:<%@ taglib %>

3.      使用标签

d)        常用JSTL标签

1.    if:和java代码中的if语句一样

属性:

test  必须属性,接收boolean表达式

如果表达式为true,则显示if标签体内容,如果为false,则不显示标签体内容

一般情况下,test属性会集合el表达式一起使用

c:if标签没有else情况,想要else情况,则可以定义一个c:if标签

2.    choose:相当于java代码中的switch语句

1.      使用choose标签声明                      相当于switch声明

2.      使用when标签做判断                             相当于case

3.      使用otherwise标签做其他情况的声明   相当于default

3.    foreach:相当于java代码的for语句

E.      三层架构

 

原文地址:https://www.cnblogs.com/liyado/p/10799402.html

时间: 2024-08-26 16:55:44

会话技术: Cookie Session JSP的相关文章

JavaWeb-10(会话技术之session&amp;JSP)

JavaWeb-会话技术之session&JSP 会话管理之Session技术 一.Session 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务. 1.Session和Cookie的主要区别在于: a. Cookie是

JavaWeb学习笔记五 会话技术Cookie&amp;Session

什么是会话技术? 例如网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器记住客户端状态(区分客户端). 从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话.会话技术就是记录这次会话中客户端的状态与数据的.会话技术分为Cookie和Session: Cookie:数据存储在客户端本地,减少服务器端的存储的压力,安全性不好,客户端可以清除

会话技术Cookie&amp;Session

一.会话技术简介 1.存储客户端的状态 如网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器    记住客户端状态(区分客户端) 2.会话技术 从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话.会话技术就是记录这次会话中客户端的状态与数据的. 会话技术分为Cookie和Session: Cookie:数据存储在客户端本地,减少服务器

JavaWeb开发中的会话技术[Cookie/Session]

会话 会话:用户打开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. 会话过程中要解决的一些问题: 每个用户在使用浏览器与服务器进行会话的过程中,不可避免各自回产生一些数据,程序要想办法为每个用户保存这些资源.电商中的保存用户的购买的商品. 保存会话数据的两种技术 Cookie:Cookie是客户端技术,程序把每个用户的数据以cookie的形式写给用户各自的浏览器.当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去,这样web资源处

Servlet学习(七)——会话技术cookie&amp;session

一.会话技术简介 1.存储客户端的状态 例如网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器记住客户端状态(或者说区分客户端,是张三登录的还是李四登录的) 2.会话技术 从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话.会话技术就是记录这次会话中客户端的状态与数据的. 会话技术分为Cookie和Session: Cookie:数据

03012_会话技术Cookie&amp;Session

1.会话技术简介 (1)存储客户端的技术 网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器记住客户端状态(区分客户端). (2)会话技术 ①从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话: ②会话技术就是记录这次会话中客户端的状态与数据的: ③会话技术分为Cookie和Session: ④Cookie:数据存储在客户端本地,减少

JavaWeb——会话技术Cookie &amp; Session

会话技术 因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器记住客户端状态(区分不同的客户端) 从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话.会话技术就是记录这次会话中客户端的状态与数据的.会话技术分为Cookie和Session: Cookie:数据存储在客户端本地,减少服务器端的存储的压力,安全性不好,客户端 可以清除cookie Session:将数据存储到服务器端,安

JavaEE之会话技术Cookie&amp;Session

会话技术简介 存储客户端的状态 由一个问题引出今天的内容,例如网站的购物系统,用户将购买的商品信息存储到哪         里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并         不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器         记住客户端状态(区分客户端) 会话技术 从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话.会         话技术就是记录这次会话中客户端态的状与数据的. 会话技术分

JAVA web 会话技术Cookie&amp;Session

会话技术,指的是从打开浏览器开始访问某个站点,到关闭浏览器的整个过程,称为一次会话. 会话技术分为Cookie和Session. Cookie是指 将数据存储在本地,减少服务器的存储压力,安全性不好,客户端可清除Cookie. Session是指将数据存储在服务器,增加服务器的存储压力,安全性高,客户端不可清除. 一.Cookie技术 (一). 服务器端怎么发送一个Cookie到客户端 1.创建一个Cookie Cookie cookie = new Cookie( String cookieN

JavaWeb-10(会话技术之session&amp;amp;JSP)

JavaWeb-会话技术之session&JSP 会话管理之Session技术 一.Session 在WEB开发中,server能够为每一个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此.在须要保存用户数据时.server程序能够把用户数据写到用户浏览器独占的session中,当用户使用浏览器訪问其他程序时,其他程序能够从用户的session中取出该用户的数据,为用户服务. 1.Session和Cookie的主要差别在于: a.