1.12.JSP
1.12.1.JSP工作原理
测试步骤:
1.创建一个静态jsp页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>$Title$</title>
<meta charset="utf-8">
</head>
<body>
<form action="/Encoding" method="post">
<input type="text" name="name"/>
<input type="submit"/>
</form>
</body>
</html>
2.在tomcat的webapps中添加一个符合web组件规范的web应用目录
3.把index.jsp拷贝到这个web应用目录的根目录中
4.启动服务器并访问这个index.jsp页面 http://localhost:8080/web/index.jsp
5.查看work目录下的我们的应用目录,当我们请求这个页面后,多出了一个index_jsp.java和index_jsp.class文件,这个就是由JSP引擎根据jsp页面内容生成的Servlet源代码和编译生成的 字节码
我们看看index_jsp.java内容
jsp页面中的静态内容被转换成输出代码嵌入到Servlet代码中
1.12.2.scriptlet脚本
<%…%>块,这个块中的代码,会被拷贝到jsp引擎生成的脚本的这个脚本所在位置
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<%
int a = 20;
%>
<head>
<title>$Title$</title>
<meta charset="utf-8">
</head>
<body>
<%
out.write(new java.util.Date().toString());
%>
<form action="/Encoding" method="post">
<input type="text" name="name"/>
<input type="submit"/>
</form>
</body>
<%
String name = request.getParameter("name");
session.getAttribute("name");
a += 10;
%>
</html>
生成的源码:
对比一下scriptlet脚本在页面流中的位置和生成的源码中的位置,实际就是把scriptlet脚本拷贝到源码输出流中对应的位置
1.12.3.JSP声明块
<%!..定义Servlet类中的方法和属性… %>
JSP声明块声明Servlet类中的方法和属性
<%!
public int sum(int a,int b){
return a + b;
}
%>
生成的源码中声明块的位置
1.12.4.输出块
<%=“HelloWorld”%> 等同于<%out.println("Hello World ");%>
生成的源代码
1.13.三大指令
JSP页面中的指令是JSP页面通知引擎如何处理自己的信息
1.page指令
<%@ page contentType="text/html;charset=UTF-8" isELIgnored="false" pageEncoding="utf-8" import="java.util.*,java.io.*" language="java" %>
<%@ page contentType="text/html;charset=UTF-8"%>
<%@ page language="java" %>
<%@ page import="java.util.*,java.io.*"%>
<%@ page import="java.jdbc.*"%>
上面是page指令的常用属性,可以连起来写,也可以写多个pgae指令配置-
- contentType属性:指定jsp的内容类型
- language属性:指定jsp引擎用什么语言处理页面
- Import属性:指定页面导入的类
- isELIgnored:指定JSP引擎是否处理页面中的EL表达式
2.include指令
主要用于静态包含其它jsp页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%@include file="header.jsp"%>
<%@include file="main.jsp"%>
<%@include file="footer.jsp"%>
</body>
</html>
header.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
Header
</body>
</html>
footer.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
Footer
</body>
</html>
main.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
Main
</body>
</html>
生成的页面