一、jsp定义及作用
JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计的显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。 JSP(JavaServer Pages)是一种动态页面技术,它的主要目的是将表示逻辑从Servlet中分离出来。
二、Myeclipse Web项目目录结构:
修改项目虚拟路径:(即web访问路径,默认和项目名称相同)
右键项目名称 -> Properties -> MyEclipse -> Web -> 修改Web Content-root
修改之后需要重新deploy到 web server上才能生效(相当于Tomcat的webappps文件夹里的项目文件夹名称变化了)
修改Tomcat默认端口号:修改conf目录中的server.xml文件的Connector节点的port属性
三、jsp指令:
- 1、page指令:位于jsp页面顶端,同一个页面可以有多个page指令。
@和page间有空格 - 2、include指令:讲一个外部文件嵌入到jsp文件中,并解析这个页面的jsp文件。
- 3、taglib指令:使用标签库定义新的自定义标签,在jsp页面中启动定制行为。
- 4、jsp书写规范
html注释:客户端可见
jsp注释:<%--注释-->客户端不可见
Jsp脚本:<%Java代码%>
Jsp声明:定义变量或是方法<%!Java代码%>
Jsp表达式:<%=变量或方法>
四、内置对象简介
- 1、JSP内置对象是Web容器创建的一组对象,【不使用new关键字】就可以使用的内置对象。例如:out
- 2、JSP九大内置对象:out,request,response,session,application(五大常用对象)Page,pageContext,exception.config(四个不太常用对象)
- 3、什么是缓冲区
1、缓冲区:Buffer,所谓缓冲区就是内存的一块区域,用来保存临时数据
2、IO输出最原始的就是一个字节一个字节输出,效率很低。缓冲区可以先将多个字节读出来,再一次性的输出,提高效率
out对象
- 1、out对象是JspWriter类的实例,是向客户端(这里指浏览器)输出内容的常用对象。
- 2、常用方法:
· void println()向客户端打印字符
· void clear()清除缓冲区的内容。如果在flush之后调用,会抛出异常
· void clearBuffer() 也是清除缓冲区内容,但在flush之后不会抛出异常
· void flush()将缓冲区内容输出到客户端
· int getBufferSize()返回缓冲区的大小(字节数),如不设缓冲区则为0
· int getRemaining()返回缓冲区还剩余多少可用
· boolean isAutoFlush()返回缓冲区满时,是否自动清空缓冲区
· void close()关闭输出流
request对象
- 1、内容:
客户端的请求信息被封装在request对象中,通过它才能了解到客户的需求,然后做出响应。
它是HttpServletRequest类的实例。request对象具有请求域,即完成客户端的请求之前,该对象一直有效。 - 2、方法:
1 object getAttribute(String name) 返回指定属性的属性值
2 Enumeration getAttributeNames() 返回所有可用属性名的枚举
3 String getCharacterEncoding() 返回字符编码方式
4 int getContentLength() 返回请求体的长度(以字节数)
5 String getContentType() 得到请求体的MIME类型
6 ServletInputStream getInputStream() 得到请求体中一行的二进制流
7 String getParameter(String name) 返回name指定参数的参数值
8 Enumeration getParameterNames() 返回可用参数名的枚举
9 String[] getParameterValues(String name) 返回包含参数name的所有值的数组
10 String getProtocol() 返回请求用的协议类型及版本号
11 String getScheme() 返回请求用的计划名,如:http.https及ftp等
12 String getServerName() 返回接受请求的服务器主机名
13 int getServerPort() 返回服务器接受此请求所用的端口号
14 BufferedReader getReader() 返回解码过了的请求体
15 String getRemoteAddr() 返回发送此请求的客户端IP地址
16 String request.getContextPath();//返回上下文路径
编码问题
- request.setCharacterEncoding("utf-8");参数应该与提交请求的JSP页面的charset保持一致。解决中文乱码问题,只对post方法提交的参数有用,无法解决URL传递中文出现的乱码问题。
- 解决URL传递中文出现的乱码问题,需要修改Tomcat的server.xml文件,在修改端口的节点Connector上加URIEncoding="utf-8",并重启web服务器。
getServerPort()返回服务器接收此请求所用的端口号
getCharacterEncoding()返回字符编码方式
setCharacterEncoding()设置请求的字符编码方式
getContentLength()返回请求体的长度
getRemoteAddr()返回发送此请求的客户端ip地址
getRealPath(String path)返回一虚拟路径的真实路径
request.getContextPath()返回上下文路径
数据交互
- response.getWriter()获得的输出流对象输出的内容总是提前于内置对象out输出的内容。
- 用out.flush()可以强制out对象输出的内容提前。
- response.sendRedirect() -> 请求重定向
- 请求重定向:客户端行为,本质上是两次请求,并且对第一次的请求对象不会保存,地址栏的URL地址会改变(response实现)
- 请求转发:服务器行为,本质上是一次请求,转发后会保存请求对象,地址栏的URL地址不会改变(request实现)
session
session表示客户端与服务器的一次会话
用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间
(1)session是JSP的一个内置对象,是HttpSession类的实例。
(2)从客户打开浏览器并连接到服务器开始,到客户关闭浏览器窗口断开与服务器的连接,这一过程成为一个会话。
(3)当客户在同一个网站的不同页面之间进行切换并访问时,服务器是通过session来判断这些请求是否来自同一个客户。
(4)session一般有时间限制,长时间不操作可能会导致session失效。session失效后原session中保存的属性值会全部丢失。
(5)setMaxInactiveInterval(int i) 该方法可直接设定session的生存时间,超过该时间session会重新创建。(单位:秒)session的生命周期
1.创建:当客户端第一次访问某个jsp或者servlet时候,服务器会为当前会话创建一个SessionId,每次客户端向服务器发送请求时,都会将此SessionId携带过去,服务端会对此SessionId进行校验
2.活动:
①某次会话当中通过超链接打开的新页面属于同一次会话
②只要当前会话页面没有全部关闭,重新打开的浏览器窗口访问同一个项目资源时属于同一次会话
③除非本次会话的所有页面都关闭后在重新访问某个JSP或者servlet将会创建新的会话
注意:注意原有会话还存在,只是这个旧的Session仍然存在于服务端,只不过再也没有客户端会携带它然后交予服务端校验(原来的会话处于休眠状态)
3.销毁:三种方式
①调用了session.invalidate()方法
②Session过期(超时)
③服务器重新启动
application介绍
1、实现了用户间数据的共享,可存放全局变量。(类似静态对象)
2、开始于服务器启动,终止于服务器的关闭(生命周期)
3、在用户的前后连接或不同用户之间的连接中,可以对application对象的同一属性进行操作
4、在任何地方对application对象属性进行操作,都将影响到其他用户对此的访问
5、application对象是ServletContext类的实例
一、page对象:是指指向当前JSP页面本身,有点像类中的this指针,它是java.long.Object类的实例。
二、常用方法如下:主要是Object类中声明的方法
JSP内置对象 - pageContext
(1)pageContext对象提供了对JSP页面中所有对象及名字空间的访问操作
(2)pageContext对象可以访问本页面的session,可以访问本页面的application对象的任意属性值
(3)pageContext对象是某个页面中所有功能的集大成者
pageContext对象的常用方法:
(1)JspWriter getOut() 返回当前客户端相应被使用的JspWriter流(out)
(2)HttpSession getSession() 返回当前页面中HttpSession对象(session)
(3)Object getPage() 返回当前页面的Object对象(page)
(4)ServletRequest getRequest() 返回当前面的ServletRequest对象(request)
(5)servletResponse getResponse() 返回当前页的ServletResponse对象(response)
(6)void setAttribute(Strign name, Object attribute) 设置属性及属性值
(7)Object getAttribute(String name ,int scope) 在指定范围内取属性值
(8)int getAttributeScope(String name) 返回某属性的作用范围
(9)void forward(String relativeUrlPath) 使当前页面跳转到另外一个页面(服务器转发)
(10)void include(String relativeUrlPath) 在当前位置包含另一个文件
config对象 常用方法: ServletContext getServletContext()返回含有服务器相关信息的ServletContext对象
String getInitParameter(String name)返回初始化参数的值
Enumeration getInitParameterNames()返回Servlet初始化所需所有参数的枚举
1.需要捕获异常的页面,在page指令中写属性errorpage=“出错跳转到的页面”
2.在跳转到的错误处理页面page指令中输入属性isErrorPage=“true”
JSP内置对象 - Exception
(1)Exception是java.lang.Throwable类的实例
(2)当一个页面运行发生了异常,就产生了该Exception对象。
(3)若一个JSP页面要使用该Exception对象,需要将isErrorPage的值设为true
Exception对象常用方法:
(1)String getMessage() 返回描述异常的信息
(2)String toString() 返回关于异常的简短描述信息
(3)void printStackTrace() 显示异常及其栈轨迹
(4)Throwable FillInStackTrace() 重写异常的执行栈轨迹
javabean:
1、Javabeans就是符合某种特定规范Java类。使用Javabeans的好处是【解决代码的重复编写】,减少代码冗余,功能区分明确,提高代码的维护性。
2、设计原则四点:公有类,属性私有,包含无参的共有构造方法,getter和setter方法封装属性
(1)JSP动作元素(action element)
JSP动作元素为请求处理阶段提供信息。动作元素遵循XML语法,有一个包含元素名的开始标签,可以有属性,可选的内容、与开始标签匹配的结束标签。
(2)JSP动作元素种类
第一类是与存取JavaBean有关,包括:
<jsp:useBean> <jsp:setProperty> <jsp:getProperty>
第二类是JSP1.2开始有的基本元素,包括:
<jsp:include> <jsp:forward> <jsp:param> <jsp:plugin> <jsp:params> <jsp:fallback>
第三类是JSP2.0新增的动作元素,主要与JSP Document有关,包括:
<jsp:root> <jsp:declaration> <jsp:scriptlet> <jsp:expression> <jsp:text> <jsp:output>
第四类是JSP2.0新增的动作元素,主要是用来动态生成XML元素标签的值,包括:
<jsp:attribute> <jsp:body> <jsp:element>
第五类是JSP2.0新增的动作元素,主要是用在Tag File中,包括:
<jsp:invoke> <jsp:dobody>
一、像使用普通java类一样
1、创建一个web project项目。
2、在src文件下,创建一个包,在包中创建一个类,满足设计原则即可
3、在index.jsp页面中通过import导入之前创建的类(import="包名.类名")
在JSP中使用JavaBean有两种方法:
1。在src下按照规则新建一个JavaBean类,然后再WebRoot下对应的jsp文件中,在声明里新建一个JavaBean类,然后赋值、使用。
2.或是使用JSp的动作标签,如<jsp:useBean id="标识符(类似于Java中的实例变量名)" class="java类名(需要将包名一同写入)" scope="作用范围(默认是page)">
<jsp:useBeans>动作:在jsp页面中实例化或者在指定范围内使用javabean
1、<jsp:useBean id="标示符" class="java类名" scope="作用范围" />
2、【其中标示符为对象引用;java类名需要使用全名】
<jsp:setProperty>动作:给【已经实例化的Javabean对象的属性赋值】,一共有四种形式。
1、需要表单提交属性:<jsp:setProperty name="Javabean实例名" property=""/>: 与之前页面提交的表单的【所有属性进行匹配】,若有与javabean类属性名相同的,则进行赋值。比如表坛提交了username="xxx",而javabean里有username属性,则对其进行赋值
2、需要表单提交属性<jsp:setPropery name="Javabean实例名" property="javabean属性名" />:对【指定的属性进行匹配】
3、手动设置属性:<jsp:setProperty name = "Javabean实例名" property="Javabean属性名" value="BeanValue" />
4、与request参数有关,通过url传参 :<jsp:setProperty name="Javabean实例名" property="propertyName" param="request对象中的参数名" />
例
1.根据表单自动匹配所有的属性
<jsp:setProperty name="myUsers" property=""/>
2.根据表单自动匹配相应的属性(部分匹配)
<jsp:setProperty name="myUsers" property="username"/>
3.与表单无关,通过手工赋值给属性
<jsp:setProperty name="myUsers" property="username" value=“Lisa”/>
4.通过url传参数给属性赋值
<jsp:setProperty name="myUsers" property="username"/>
<jsp:setProperty name="myUsers" property="password" param=“mypass”/>
getProperty
作用:获取指定javabean对象的属性值。
〈jsp:getProperty name="javabean实例名" property="javabean属性名"〉
JavaBean作用域:
page://仅当前页面有效
request//可以通过HttpRequest.getAttribute()方法来取得javaBean对象,本次请求有效,服务器跳转有效,重定向无效
session//可以通过Session.getAttribute()方法取得javaBean对象,本次会话有效,服务器跳转有效,重定向有效
application//可以通过application.getAttribute()方法来取得javaBean对象,本webapp全局有效,只有当该app关闭后失效
Model1分为三层:
1.界面层:由JSP页面进行与客户端浏览器的交互,可以直接调用JavaBeans
2.业务逻辑层:由JavaBeans进行处理业务逻辑,封装数据,并与数据库层进行交互
3.数据库层:底层数据库,可被javaBeans访问
避免了JSP页面直接进行业务逻辑处理所带来的维护性,扩展性差的弱点.体现了分层设计的思想
http协议的无状态性:服务器不会记住你
保存用户状态的两大机制:Cookie,session
Cookie:Web服务器保存在客户端的一系列文本信息
Cookie作用:
1、对特定对象的追踪
2、保存用户网页浏览记录和习惯
3、简化登录
安全风险:容易泄露用户信息
创建Cookie对象:Cookie newCookie=new Cookie(String key,Object value);
写入Cookie对象:response.addCookie(newCookie);
读取Cookie对象:Cookie[] cookies=request.getCookies();
Cookie方法:
设置cookie的有效期 void setMaxAge(int a)
获取cookie的有效期 int getMaxAge();
设置cookie的值 void setValue(String a);
获取cookie的值 String getValue();
获取cookie的名称 String getName();
session和cookie区别:
1、保存位置:session在服务器端内存,cookie在客户端文本
2、保存对象:session保存Object类(保存对象大小没有限制),cookie保存String类型(保存对象大小有限制)
3、生存权:session会话结束即销毁,cookie可以长期保存在客户端
4、重要性:session安全性更高,保存重要信息,cookie保存不重要的信息
JSP有page、include、taglib指令这三种指令;
page:位于页面顶端,一个页面可以包含多个page指令
include:将一个外部文件嵌入jsp中,同时解析这个页面中的jsp语句。
taglib:使用标签库,自定义新的标签,在jsp中启动定制行为。
include指令:
include指令是编译阶段的指令,即include所包含的文件的内容是编译的时候插入到JSP文件中‘因此如果只修改了include文件内容,而没有对JSP修改,得到的结构将不会改变,所以直接执行已经存在的字节码文件,而没有重新编译。因此对不经常变化的内容,用include指令是合适的,如果需要的内容是经常变化的,则需要动作元素<jsp:include>.
include指令的主要优点是功能强大,所包含的代码可以含有总体上影响主页面的JSP构造,比如属性、方法的定义和文档类型的设定。它的缺点是难于维护只要被包含的页面发生更改,就得更改主页面,这是因为主页面不会自动地查看被包含的页面是否发生更改。
仅当include动作不能满足要求时,我们才应该使用include指令。
include动作在维护上的优势十分巨大,当两种方法都可以使用时,include动作几乎肯定是首选的方法。
对于文件包含,应该尽可能地使用include动作。仅在所包含的文件中定义了主页面要用到的字段或方法,或所包含的文件设置了主页面的响应报头时,才应该使用include指令。
因为include指令更为强大。include指令允许所包含的文件中含有影响主页面的Jsp代码,比如响应报头的设置和字段、方法的定义。