新建一个Maven项目,这次选择空项目,通过后续操作将它变成Web项目。
名为javaweb-jsp,右键项目名,选择“add framework support”。可以发现和之前有一些区别,web目录现在与src目录平级了,而且添加框架支持的时候可以选择web版本,选择4.0后就不用手动更改了。
然后在pom.xml中导包,这次新增了三个JSP以及JSP表达式的依赖:
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.3.3</version>
</dependency>
<!-- JSTL表达式的依赖-->
<dependency>
<groupId>javax.servlet.jsp.jstl</groupId>
<artifactId>jstl-api</artifactId>
<version>1.2</version>
</dependency>
<!-- JSTL表达式以来的标签的依赖-->
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
</dependencies>
JSP基础语法
JSP作为Java技术的一种应用,拥有一些扩充的语法(了解)。
- JSP表达式
<%-- JSP表达式
作用:将程序的输出输出到客户端
格式:<%= 变量或表达式%>--%>
<%= new java.util.Date()%>
也可以导包然后快捷用对象(=new Date()):
<%@ page import="java.util" %>
- JSP脚本
看下列两个JSP脚本片段
<%
int sum = 0;
for (int i = 0; i < 100; i++) {
sum += i;
}
out.println("<h1>sum: "+sum+"<h1>");
%>
<%
for (int i = 0; i < 5; i++) {
%>
<h1>Hello world <%= i%></h1>
<%
}
%>
- JSP声明:JSP脚本和表达式代码被生成到最后的.jsp.java文件的_jspService方法中,而JSP声明会被编译到_jspService方法外,以下为可以声明的内容,即静态代码块/全局变量/方法:
<%!
static {
System.out.println("Loading Servlet");
}
private int globalvar = 0;
public void test(){
System.out.println("enter method test");
}
%>
- JSP指令
看个例子,假如我们现在一个页面发生错误,我们不想让它跳转到默认的错误页面,此时我们需要定制页面.
新建一个JSP名为jsp2,写一个明显的500类型错误,并且用指令指定错误跳转的页面,内容如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ page errorPage="error/500.jsp" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%= 2/0%>
</body>
</html>
web文件夹下新建两个文件夹名为error和img,img下存入自定义跳转500错误的显示图片,error下新建一个JSP页面名为500,内容如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<img src="../img/500.jpg" alt="500error">
</body>
</html>
启动Tomcat后输入后缀jsp2.jsp,会跳转到500.jsp显示错误图片。
但是别忘了我们还可能出现404错误,怎么样能让系统根据错误的类型跳转不同的页面呢?和Servlet一样,在web.xml中注册errorpage,这样我们就不用在JSP头部定义了:
<error-page>
<error-code>500</error-code>
<location>/error/500.jsp</location>
</error-page>
<error-page>
<error-code>404</error-code>
<location>/error/404.jsp</location>
</error-page>
error文件夹新建一个JSP名为404,内容如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<img src="../img/404.jpg" alt="404error">
</body>
</html>
这样就能给不同的错误类型分配不同的错误页面。
此外,还可以在头部显式地声明错误页面:
<%@ page isErrorPage="true" %>
除了page属性外,还可以定义include.新建一个common文件夹,common下新建两个JSP页面,名为header,footer。内容分别如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<h1>l'm header</h1>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<h1>l'm footer</h1>
在web文件夹下新建一个名为jsp3的JSP页面,内容如下:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%@include file="common/header.jsp"%>
<h1>Website Main Part</h1>
<%@include file="common/footer.jsp"%>
</body>
</html>
运行Tomcat后输入后缀jsp3.jsp,结果如下:
但是jsp3.jsp中的include代码稍显复杂,我们可以更换为以下形式,更简单易记一些,而且效果一样:
<%--JSP标签--%>
<jsp:include page="/common/header.jsp"/>
<h1>Website Main Part</h1>
<jsp:include page="/common/footer.jsp"/>
但是注意它们的不同点:
1.其中有两个地方的斜杠用法和JSP指令不同.
2.后者所引用的界面在转换成Java代码时会被声明在静态代码块,而后用include方法调取;前者的话直接把多个页面合并了这导致一个结果:假如在被调页面中赋值一个变量或常量,然后jsp3中又有重名元素,那么代码会报错.然而同样的操作在后者就不会出错,因为并没有合并成一个页面,实际上还是三个页面,栈不会出错.
以上给我们一个启示,可以把一些重复用到内容用这种方法重复利用,减少代码重复率.
jsp3.jsp中演示另一个JSP标签:
<jsp:forward page="/pageContextDemo01.jsp">
<jsp:param name="adress1" value="Guandong"/>
<jsp:param name="adress2" value="Xingjiang"/>
</jsp:forward>
该代码请求转发本页面给pageContextDemo01.jsp页面,并且附带两个参数
pageContext中添加以下代码接受参数:
<%=request.getParameter("adress1")%>
<%=request.getParameter("adress2")%>
运行后输入后缀jsp3.jsp,自动跳转到pageContextDemo01并输出地址.
JSP标签主要是以上三个