会话技术: Cookie Session JSP
## Cookie
A..概念:客户端会话技术,将数据保存到客户端
B.使用步骤:
1.创建Cookie对象,绑定数据
new Cookie(String name, String value)
2.发送Cookie对象
response.addCookie(Cookie cookie)
- 获取Cookie,拿到数据
request.Cookie[]getCookies
` C.实现原理
基于相应头set-cookie和请求头cookie实现
D.cookie的细节
1.一次可不可以发送多个cookie?
# 可以,创建多个cookie对象,使用response调用多次addCookie方法发送Cookie
2.cookie在浏览器中保存多久
1.默认情况下,当浏览器关闭,Cookie数据被销毁
2.持久化存储:
setMaxAge(int seconds)
- 正数:将Cookie数据写到硬盘文件中。持久化存储。Cookie存活时间
- 负数:默认值
- 0:删除cookie信息
3.cookie能不能存储中文
在Tomcat 8之前cookie中不能直接存储中文数据,需要将中文数据转码,一般采用URL编码(%E3)
在Tomcat8之后,cookie支持中文数据。特殊字符还是不支持建议使用URL编码
- 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. 如果不是第一次访问,则提示:欢迎回来,上次访问的时间为:显示时间的字符串
分析:
- 可以采用Cookie来完成
- 在服务器的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. 三层架构
会话技术: Cookie Session JSP的更多相关文章
- java ->会话技术Cookie&Session
会话技术Cookie&Session 会话技术简介 存储客户端的状态 由一个问题引出今天的内容,例如网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户 ...
- Web核心之会话技术Cookie&Session
什么是会话技术? http协议是无状态协议.为了满足在多次请求之间数据进行交互,推出了会话技术. 会话概念:一次会话,指的是从客户端和服务器建立起连接开始,到客户端或服务器断开连接为止.中间可能进行多 ...
- JavaWeb学习笔记五 会话技术Cookie&Session
什么是会话技术? 例如网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话 ...
- JavaEE之会话技术Cookie&Session
会话技术简介 存储客户端的状态 由一个问题引出今天的内容,例如网站的购物系统,用户将购买的商品信息存储到哪 里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并 ...
- 会话技术Cookie&Session
1.会话技术概述 从打开浏览器访问某个站点,到关闭这个浏览器的整个过程,称为一次会话.会话技术用于记录本次会话中客户端的状态与数据. 会话技术分为Cookie和Session: Cookie:数据存储 ...
- 03012_会话技术Cookie&Session
1.会话技术简介 (1)存储客户端的技术 网站的购物系统,用户将购买的商品信息存储到哪里?因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识 ...
- Django2.2 会话技术cookie session token的区别以及实例介绍
一.区别: 本人见解:使用自定义数据项进行加密,作为唯一身份识别,登陆时写入cookie(session基于这个).在显示相关数据 1.cookie 属于客户端会话技术(数据存储在客户端) 默认的Co ...
- 会话技术 Cookie+Session
会话:这种在多次HTTP连接间维护用户与同一用户发出的不同请求之间关联的情况称为维护一个会话(session) 一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开: 功能:在一次会话 ...
- JavaWeb-10(会话技术之session&JSP)
JavaWeb-会话技术之session&JSP 会话管理之Session技术 一.Session 在WEB开发中,server能够为每一个用户浏览器创建一个会话对象(session对象),注 ...
- 会话技术cookie与session
目录 会话技术cookie 会话技术 cookie 服务器怎样把Cookie写 给客户端 服务器如何获取客户端携带的cookie session session简介 Session如何办到在一个ser ...
随机推荐
- hadoop install start-dfs.sh 失败
linux:ubuntu 16.04 LTS hadoop version: 2.7.3 JDK: java-9-open-jdk issue: start-dfs.sh start-dfs.sh:c ...
- Mybatis学习笔记4 - 获取自增主键的值
获取自增主键的值:mysql支持自增主键,自增主键值的获取,mybatis也是利用statement.getGenreatedKeys():useGeneratedKeys="true&qu ...
- Turing Year 2012
Turing LectureFrom cryptanalysis to cognitive neuroscience - a hidden legacy of Alan Turinghttp://co ...
- Python collections
#count对象 Only 2.7 from collections import Counter #统计字母出现的次数 Counter('hello world') Counter(['red', ...
- Angularjs ui router,路由嵌套 父controller执行问题
解决方式来源:https://stackoverflow.com/questions/25316591/angularjs-ui-router-state-reload-child-state-onl ...
- IIS下不能下载文件的docx文档,XLSX文档的设置方法(转)
IIS下不能下载文件的docx文档,XLSX文档的设置方法 Office 2007的的界面风格默认格式中都是.DOCX,XLSX,PPTX等等后缀,连结中包含此类文件时,界面风格默认什么打不开的其实只 ...
- 【踩坑】报错 non-static method xxx() cannot be referenced from a static context
今天测试代码时遇到 Error:(6, 55) java: non-static method sayGoodbye() cannot be referenced from a static cont ...
- hibernate课程 初探一对多映射2-1 一对多映射简介
1 在数据库中用主外键的形式实现一对多的映射关系 2 hibernate 在一方设置集合set,表示多方
- css中的伪元素,我今天记住了!o~yeah
对于伪类和伪元素,我如果要区别它们,一般是使用css中的手册来区分,平常时候也没特意去记,需要用到时打开手册“哦,这个是伪元素,这个是伪类”,我个人觉的某些东西你把它存在网上,不一定要存在头脑中.带着 ...
- Android 6.0 动态权限申请
1. 概述 Android 6.0 (API 23) 之前应用的权限在安装时全部授予,运行时应用不再需要询问用户.在 Android 6.0 或更高版本对权限进行了分类,对某些涉及到用户隐私的权限可在 ...