一、JSP技术:在html中嵌入java代码
1.jsp脚本和注释
jsp脚本:
1)<%java代码%> ----- 内部的java代码翻译到service方法的内部
2)<%=java变量或表达式> ----- 会被翻译成service方法内部out.print()
3)<%!java代码%> ---- 会被翻译成servlet的成员的内容
<body>
<%
int i=0;
System.out.print(i);//控制台输出(java注释)
%>
<%-- 页面输出 (jsp注释)--%>
<%=i %>
<%=1+1 %>
<%!
String str = "nihao china!";
%>
<%=str %>
<!-- html注释 -->>
<h1>akdhakh</h1>
</body>
jsp注释: 不同的注释可见范围是不同
1)Html注释:
—可见范围 jsp源码、翻译后的servlet、页面 显示html源码
2)java注释://单行注释 /多行注释/ --可见范围 jsp源码 翻译后的servlet
3)jsp注释:<%–注释内容–%> ----- 可见范围 jsp源码可见
2.jsp运行原理-----jsp本质就是servlet
jsp在第一次被访问时会被Web容器翻译成servlet,在执行
过程:
第一次访问---->helloServlet.jsp---->helloServlet_jsp.java---->编译运行
PS:被翻译后的servlet在Tomcat的work目录中可以找到
3.jsp指令(3个)
jsp的指令是指导jsp翻译和运行的命令,jsp包括三大指令:
1)page指令 — 属性最多的指令(实际开发中page指令默认)
属性最多的一个指令,根据不同的属性,指导整个页面特性
格式:<%@ page 属性名1= “属性值1” 属性名2= “属性值2” …%>
常用属性如下:
language:jsp脚本中可以嵌入的语言种类
pageEncoding:当前jsp文件的本身编码—内部可以包含contentType
contentType:response.setContentType(text/html;charset=UTF-8)
session:是否jsp在翻译时自动创建session(默认为true)
import:导入java的包
errorPage:当当前页面出错后跳转到哪个页面 errorPage="/error.jsp",(500错误后跳的页面)
isErrorPage:当前页面是一个处理错误的页面
在web.xml中配置
<!-- 设置web应用的全局的错误页面 -->
<error-page>
<error-code>404</error-code>
<location>/error.jsp</location>
</error-page>
<error-page>
<error-code>500</error-code>
<location>/error2.jsp</location>
</error-page>
当同时配置errorPage="/error.jsp"时,就近原则
2)include指令
页面包含(静态包含)指令,可以将一个jsp页面包含到另一个jsp页面中
格式:<%@ include file=“被包含的文件地址”%>
<%@ include file="/header.jsp"%>
3)taglib指令
在jsp页面中引入标签库(jstl标签库、struts2标签库)
格式:<%@ taglib uri=“标签库地址” prefix=“前缀”%>
引入jstl核心库:
<%@ taglib uri=“http://” prefix=“c”%>
<%@ taglib uri=“http://” prefix=“fmt”%>
使用c库的标签:
<c:if></c:if>
4.jsp内置/隐式对象(9个)
jsp被翻译成servlet之后,service方法中有9个对象定义并初始化完毕,我们在jsp 脚本中可以直接使用这9个对象
名称 | 类型 | 描述 |
---|---|---|
out | javax.servlet.jsp.JspWriter | 用于页面输出 |
request | javax.servlet.http.HttpServletRequest | 得到用户请求信息 |
response | javax.servlet.http.HttpServletResponse | 服务器向客户端的回应信息 |
config | javax.servlet.ServletConfig | 服务器配置,可以取得初始化参数 |
session | javax.servlet.http.HttpSession | 用来保存用户的信息 |
application | javax.servlet.ServletContext | 所有用户的共享信息 |
page | java.lang.Object | 指当前页面转换后的Servlet类的实例 |
pageContext | javax.servlet.jsp.PageContext | JSP的页面容器 |
exception | java.lang.Throwable | 表示JSP页面所发生的异常,在错误页中才起作用 |
exception:当isErrorPage=“true”,才会创建exception对象
(1)out对象
out的类型:JspWriter
out作用就是想客户端输出内容----out.write()
out缓冲区默认8kb 可以设置成0 代表关闭out缓冲区 内容直接写到respons缓冲器
<body>
aaa
<%
int i=10;
out.write("bbb");
response.getWriter().write("ccc");
%>
<%="ddd" %>
<%
System.out.print(i);
%>
</body>
返回ccc aaa bbb ddd
原理:aaa bbb ddd最终都被翻译成out.write(),存放在out缓冲区,而ccc存放在response缓冲区,tomcate内核默认从response缓冲区取数据,out缓冲区数据最后会被刷到response缓冲区
当设置buffer=“0kb”,关闭out缓冲区,则返回aaa bbbccc ddd
(2)pageContext对象
page对象:当前页面的对象,
pageContext对象:当前页面的上下文对象
1)pageContext是一个域对象
setAttribute(String name,Object obj)
getAttribute(String name)
removeAttrbute(String name)
pageContext可以向指定的其他域中存取数据
setAttribute(String name,Object obj,int scope)
getAttribute(String name,int scope)
removeAttrbute(String name,int scope)
findAttribute(String name)
—依次从pageContext域,request域,session域,application域中获 取属性,在某个域中获取后将不在向后寻找
<body>
<%
//使用pageContext向request域、session域、servletContext域存数据
request.setAttribute("name", "zhangsan");
pageContext.setAttribute("name", "sunba");
pageContext.setAttribute("name", "lisi", PageContext.REQUEST_SCOPE);
pageContext.setAttribute("name", "wangwu", PageContext.SESSION_SCOPE);
pageContext.setAttribute("name", "tianqi", PageContext.APPLICATION_SCOPE);
%>
<%=request.getAttribute("name") %>
<%=pageContext.getAttribute("name", PageContext.REQUEST_SCOPE)%>
<!-- findAttribute会从小到大搜索域的范围中的name -->
<!-- page域<request域<session域<application域 ,找到想要的屬性后就不往后找了-->
<%=pageContext.findAttribute("name") %>
<%
pageContext.getRequest();
pageContext.getOut();
%>
</body>
四大作用域的总结:
page域:当前jsp页面范围
request域:一次请求
session域:一次会话
application域:整个web应用
2)可以获得其他8大隐式对象
例如: pageContext.getRequest()
pageContext.getSession()
…
5.jsp标签(动作)
1)页面包含(动态包含):<jsp:include page=“被包含的页面”/>
静态包含:
<%@ include file="/include_2.jsp" %>
动态包含:
<jsp:include page="/include2.jsp"></jsp:include>
静态包含与动态包含的区别?
2)请求转发:<jsp:forward page=“要转发的资源” />
<jsp:forward page="/forward2.jsp"></jsp:forward>
二、EL技术
1.EL 表达式概述
EL(Express Lanuage)表达式可以嵌入在jsp页面内部,减少jsp脚本的编写,EL出现的目的是要替代jsp页面中脚本的编写。
2.EL从域中取出数据(EL最重要的作用)
jsp脚本:<%=request.getAttribute(name)%>
EL表达式替代上面的脚本:${requestScope.name}
EL最主要的作用是获得四大域中的数据,格式${EL表达式}
EL获得pageContext域中的值:
${pageScope.key};
EL获得request域中的值:
${requestScope.key};
EL获得session域中的值:
${sessionScope.key};
EL获得application域中的值:
${applicationScope.key};
EL从四个域中获得某个值${key};
—同样是依次从pageContext域,request域,session域,application域中获取属性,在某个域中获取后将不在向后寻找
<!-- 模拟域中的数据 -->
<%
pageContext.setAttribute("name", "pageContext域");
//存储字符串
request.setAttribute("name", "request域");
//存储一个对象
User user = new User();
user.setId(1);
user.setName("zhangsan");
user.setPassword("123");
session.setAttribute("user", user);
//存储一个集合
List<User> list = new ArrayList<User>();
User user1 = new User();
user1.setId(2);
user1.setName("lisi");
user1.setPassword("123");
list.add(user1);
User user2 = new User();
user2.setId(3);
user2.setName("wangwu");
user2.setPassword("123");
list.add(user2);
application.setAttribute("list", list);
%>
<!-- 脚本法是取出域中的值 -->
<%=request.getAttribute("company") %>
<%
User sessionUser = (User)session.getAttribute("user");
out.write(sessionUser.getName());
%>
<hr/>
<!-- 使用EL表达式获得域中的值 -->
${requestScope.company }
${sessionScope.user.name }
${applicationScope.list[1].name}
<hr/>
<!-- 使用el表达式 全域查找 -->
${company }
${user.name }
${list[1].name}
3.EL的内置对象11个
pageScope,requestScope,sessionScope,applicationScope
(request是jsp内置对象,requestScope是el内置对象,requestScope是request的域)
---- 获取JSP中域中的数据
param,paramValues - 接收参数.
相当于request.getParameter() rrquest.getParameterValues()
${param.username }
header,headerValues - 获取请求头信息
相当于request.getHeader(name)
<!-- [和.用法一样,有特殊字符用[ -->
${header["User-Agent"] }
initParam - 获取全局初始化参数
相当于this.getServletContext().getInitParameter(name)
web.xml中配置:
<context-param>
<param-name>aaa</param-name>
<param-value>XXXXX</param-value>
</context-param>
获取:
${initParam.aaa }
cookie - WEB开发中cookie
相当于request.getCookies()—cookie.getName()—cookie.getValue()
<%
Cookie cookie = new Cookie("jack","rose");
response.addCookie(cookie);
%>
<!-- 返回jack -->
${cookie.name.name }
<!-- 返回rose -->
${cookie.name.value }
pageContext - WEB开发中的pageContext.
pageContext获得其他八大对象
<!-- 通过el表达式获得request对象 -->
${pageContext.request }
${pageContext.request.contextPath}
相当于
<%=pageContext.getRequest().getContextPath%> 这句代码不能实现
获得WEB应用的名称
用处:
引入css、js文件等
<link href="${pageContext.request.contextPath }/xxx.css">
<script type="text/javascript" src="${pageContext.request.contextPath }/yyy.js"></script>
form表单提交:
<form action="${pageContext.request.contextPath }/el/form2.jsp"
图片:
<img alt="" src="${pageContext.request.contextPath }/1.png">
4.EL执行表达式
例如:
${1+1}
${empty user}
${user==null?true:false}
<!-- el可以执行表达式运算 -->
${1+1 }
${1==1?true:false }
<!-- empty 判定某个对象是否是null 是null返回true -->
${empty list}
三、JSTL技术
1.JSTL概述
JSTL(JSP Standard Tag Library),JSP标准标签库,可以嵌入在jsp页面中使用标签的形式完成业务逻辑等功能。jstl出现的目的同el一样也是要代替jsp页面中的脚本代码。JSTL标准标准标签库有5个子库,但随着发展,目前常使用的是他的核心库
标签库 | 库的URI | 前缀 |
---|---|---|
Core | http://java.sun.com/jsp/jstl/core | c |
I18N | http://java.sun.com/jsp/jstl/fmt | fmt |
SQL | http://java.sun.com/jsp/jstl/sql | sql |
XML | http://java.sun.com/jsp/jstl/xml | x |
Functions | http://java.sun.com/jsp/jstl/functions | fn |
2.JSTL下载与导入
JSTL下载:
从Apache的网站下载JSTL的JAR包。进入 “http://archive.apache.org/dist/jakarta/taglibs/standard/binaries/”网址下载 JSTL的安装包。jakarta-taglibs-standard-1.1.2.zip,然后将下载好的JSTL安装包 进行解压,此时,在lib目录下可以看到两个JAR文件,分别为jstl.jar和standard.jar。 其中,jstl.jar文件包含JSTL规范中定义的接口和相关类,standard.jar文件包含用于实现JSTL的.class文件以及JSTL中5个标签库描述符文件(TLD)
将两个jar包导入我们工程的lib中
使用jsp的taglib指令导入核心标签库
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
3.JSTL核心库的常用标签
1)<c:if test=””>标签
其中test是返回boolean的条件
<!-- 用户没有登录 -->
<c:if test="${empty user}">
<li><a href="login.jsp">登录</a></li>
<li><a href="register.jsp">注册</a></li>
</c:if>
<!-- 用户已经登录 -->
<c:if test="${!empty user}">
<li>${user.name }</li>
<li><a href="#">退出</a></li>
</c:if>
<!-- 如果性别是男的, 可以在男的性别 input标签里面, 出现checked ,如果性别是女的, 可以在女的性别 input标签里面,出现checked -->
<input type="radio" name="gender" value="男" <c:if test="${stu.gender == '男'}">checked</c:if>>男
<input type="radio" name="gender" value="女" <c:if test="${stu.gender == '女'}">checked</c:if>>女
2)<c:forEach>标签
使用方式有两种组合形式:
第一种:
<!-- forEach模拟
for(int i=0;i<=5;i++){
syso(i)
}
-->
<c:forEach begin="0" end="5" var="i">
${i }<br/>
</c:forEach>
第二种:
<!-- 模拟增强for productList---List<Product>
for(Product product : productList){
syso(product.getPname());
}
-->
<!-- items:一个集合或数组 var:代表集合中的某一个元素-->
<c:forEach items="${productList }" var="product">
${product.pname }
</c:forEach>
示例:
1)遍历List的值
2)遍历List的值
3)遍历Map<String,String>的值
4)遍历Map<String,User>的值
5)遍历Map<User,Map<String,User>>的值
entry.key-----User
entry.value------List<String,User>
<%
//模拟List<String> strList
List<String> strList = new ArrayList<String>();
strList.add("hello");
strList.add("my");
strList.add("name");
strList.add("is");
strList.add("my");
request.setAttribute("strList", strList);
//遍历List<User>的值
List<User> userList = new ArrayList<User>();
User user1 = new User();
user1.setId(2);
user1.setName("lisi");
user1.setPassword("123");
userList.add(user1);
User user2 = new User();
user2.setId(3);
user2.setName("wangwu");
user2.setPassword("123");
userList.add(user2);
application.setAttribute("userList", userList);
//遍历Map<String,String>的值
Map<String,String> strMap = new HashMap<String,String>();
strMap.put("name", "lucy");
strMap.put("age", "18");
strMap.put("addr", "南京");
strMap.put("email", "licy@itcast.cn");
session.setAttribute("strMap", strMap);
//遍历Map<String,User>的值
Map<String,User> userMap = new HashMap<String,User>();
userMap.put("user1", user1);
userMap.put("user2", user2);
request.setAttribute("userMap", userMap);
%>
<h1>取出strList的数据</h1>
<c:forEach items="${strList }" var="str">
${str }<br/>
</c:forEach>
<h1>取出userList的数据</h1>
<c:forEach items="${userList}" var="user">
user的name:${user.name }------user的password:${user.password }<br/>
</c:forEach>
<h1>取出strMap的数据</h1>
<c:forEach items="${strMap }" var="entry">
${entry.key }====${entry.value }<br/>
</c:forEach>
<h1>取出userMap的数据</h1>
<c:forEach items="${userMap }" var="entry">
${entry.key }----${entry.value.name }--${entry.value.password }<br/>
</c:forEach>
3).c和fn用在多选框中
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
<input type="checkbox" name="hobby" value="游泳" <c:if test="${fn:contains(stu.hobby,'游泳') }">checked</c:if>>游泳
fn:contains(‘原字符串’,‘包含的字符串’)
四、javaEE的开发模式
1.什么是模式
在开发过程中总结出的“套路”,总结出的一套约定俗成的设计模式
2.javaEE经历的模式
model1模式:
技术组成:jsp+javaBean
model1的弊端:随着业务复杂性 导致jsp页面比较混乱
model2模式
技术组成:jsp+servlet+javaBean
model2的优点:开发中使用各个技术擅长的方面
servlet:擅长处理java业务代码
jsp:擅长页面的显示
MVC:---- web开发的设计模式
M:Model—模型 javaBean:封装数据
V:View-----视图 jsp:单纯进行页面的显示
C:Controller----控制器 Servelt:获取数据–对数据进行封装–传递数据-- 指派显示的jsp页面
3.javaEE的三层架构
服务器开发时 分为三层
web层:与客户端交互
service层:复杂业务处理
dao层:与数据库进行交互
开发实践时 三层架构通过包结构体现
总结:
JSP
三个指令
page : 定义当前页面的一些信息
include : 包含其他页面
taglib : 引入标签库
三个动作标签
<jsp:forward page=""> : 跳转
<jsp:include page=""> : 包含
<jsp:param name="" value=""> : 跳转到具体页面或者是某个页面被包含的时候,可以指定这个参数。
九个内置对象
4+5
pageContext
作用范围: 当前页
request
作用范围: 一次请求
session
作用范围: 一次会话
application
作用范围: 整个项目,直到关闭服务器。
response
out
exception
config -- ServletConfig
page --- this 这个jsp翻译成java文件的类对象。
EL
${}
1. 取值。
<% User user = new User();
pageContext.setAttribute("u" , user);
%>
${u.name} ---> 是从四个作用域里面,由小到大去获取值。 如果没有, 那就什么都没有。
${sessionScope.u.name} --> 强制到session里面去找
2. 11个隐式对象。 (10 map + 1 pageContext )
--- 4 (作用域)+ 7 ${}
pageContext
pageScope
requestScope
sessionScope
applicationScop
头相关
header
headerValues
参数相关
param
paramValues
cookie
initparam
JSTL
1. 导包
2. 引入标签库(1.1 EL)
taglib
3. 常用标签
<c:set var="" value="" scope=""> :存储一个值到作用域里面, page
<c:if> : 判断
<c:forEach items="" var=""> : 遍历