JavaWeb --JSP详解
前言
- Java Web 其实就是一个技术的总和,把Web看成一个容器而已主要使用JavaEE技术来实现.在加上各种中间件。
- 整个javaWeb阶段的内容通过实际的案例贯穿学习, 所涉及到的技术知识点会在案例中根据不同的需求引入。
- 首先了解javaWeb的整个技术体系,掌握常用的技术知识点。
我会将JavaWeb分为8篇左右的文章来记录自己的学习过程,也方便大家逐级递增难度的学习,如有错误或遗漏欢迎大家指出。
注:本篇文章承接上一篇JavaWeb文章JavaWeb--Cookie与Session
下面我们进入正题!
8、JSP
8.1、什么是JSP
JavaServletPages: Java服务器端页面,也和Serlvet一样,用于动态web技术
最大的特点:
- 写JSP就像写HTML
- 区别:
- HTML只给用户提供静态的数据
- JSP页面中可以嵌入Java代码,为用户提供动态数据
8.2、JSP原理
思路:JSP到底是怎么执行的
-
代码层面没有任何问题
-
服务器内部工作
Tomcat中有一个work目录:
idea中使用Tomcat会在idea的Tomcat中产生一个work目录
-
发现页面变成了Java程序
JSP最终也会被转成一个java类
JSP本质上就是一个Servlet
浏览器向服务器发送请求,不管访问什么资源,其实都是在访问servlet
1.判断请求
2.内置一些对象
final javax.servlet.jsp.Pagecontext pagecontext;
//页面上下文
javax.servlet.http.Httpsession session null;
//session
final javax.servlet.Servletcontext application;
//applicationContext
final javax.servlet.servletconfig config;
//config
javax.servlet.jsp.Jspwriter out null;
//out
final java.lang.object page this;
//page:当前
HttpservletRequest request
//请求
HttpservletResponse response
//响应
3.输出页面前增加的代码
response.setcontentType("text/htm1");
//设望响应的页面类型
pagecontext = _jspxFactory.getPagecontext(this,request,response,
null,true,8192,true);
_jspx_page_context = pagecontext;
application = pagecontext.getservletcontext();
config = pagecontext.getservletconfig();
session = pagecontext,getsession();
out = pagecontext.getout();
_jspx_out=out;
以上的这些对象我们可以在JSP页面上直接使用
在JSP页面中,只要是Java代码就会原封不动的输出
如果是HTML代码就会被转换为:
out.write("<html>\n");
这样的格式输出到前端
8.3、JSP基础语法
任何语言都有自己的语法,Java中有;JSP作为Java技术的一种应用,他拥有一些自己的扩充语法,Java所有的语法都支持
JSP表达式
<%--JSP表达式
作用:用来将程序的输出,输出到客户端
<%= new 变量或者表达式%>
--%>
<%= new java.util.Date()%>
JSP脚本片段
<%--jsp 脚本片段 --%>
<%
int sum = 0;
for (int i = 1; i <= 100; i++) {
sum+=i;
}
out.println("<h1>Sum="+sum+"</h1>");
%>
脚本片段的再实现
<%
int x = 10;
out.println(x);
%>
<p>这是一个jsp文档</p>
<%
int y = 20;
out.println(2);
%>
<hr>
<%--在代码中嵌入HTML元素 --%>
<%
for (int i = 0; i < 5; i++) {
%>
<h1>hello world <%=i%> </h1>
<%
}
%>
JSP声明
<%!
static {
System.out.println("Loading Servlet!");
}
private int global = 0;
public void qjd(){
System.out.println("进入了方法qjd");
}
%>
JSP声明:(<%!%>)会被编译到JSP生成的Java类中!其他的(<%%>)就会被生成到jspService 方法中
在JSP中嵌入Java代码
<%----%> 注释
<%%> 片段
<%=%> 表达式输出一个值
<%!%> 全局
${} el表达式
JSP的注释(<%----%>)不会在客户端显示,HTML()就会
8.4、JSP指令
<%@page args...%>
<%@ include file="" %>
1.定制错误页面<%@page args...%>
jsp2.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%--定制错误页面(可以在这个jsp中引入也可以在web.xml 中配置)--%>
<%@ page errorPage="error/500.jsp" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
int x = 1/0;
%>
</body>
</html>
如果在web.xml中配置
<error-page>
<error-code>500</error-code>
<location>/error/500.jsp</location>
</error-page>
500.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<img src="../img/500.png" alt="500">
</body>
</html>
测试
500错误:
404错误:
2.共用部分<%@ include file="" %>
<head>
<title>Title</title>
</head>
<body>
<%--方法一@ include会将三个页面合三为一--%>
<%@ include file="common/header.jsp" %>
<h1>网页主体</h1>
<%@ include file="common/footer.jsp" %>
<hr>
<%--方法二jsp标签
jsp:include:拼接页面,本质还是3个
--%>
<jsp:include page="/common/header.jsp"></jsp:include>
<h1>网页主体</h1>
<jsp:include page="/common/footer.jsp"></jsp:include>
</body>
</html>
测试
8.5、九大内置对象
- PageContext (存东西)
- Request (存东西)
- Response
- Session (存东西)
- Application 【ServletContext】(存东西)
- config 【ServletConfig】
- out
- page
- exception
重点对象理解:
request:客户端向服务器发送请求,产生的数据,用户看完就没用了,比如:新闻,用户看完没用的!
session:客户端向服务器发送请求,产生的数据,用户用完一会还有用,比如:购物车;
application:客户端向服务器发送请求,产生的数据,一个用户用完了,其他用户还可能使用,比如:聊天数
据;
具体实现:
- 通过pageContext寻找的方式取出我们保存的值
pageContextDemon01.jsp(在一个页面取值)
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%--内置对象--%>
<%
pageContext.setAttribute("name1","张三1");//保存的数据只在一个页面中有效
request.setAttribute("name2","张三2");//保存的数据只在一次请求中有效,请求转发会携带这个数据
session.setAttribute("name3","张三3");//保存的数据只在一次会话中有效,打开到关闭浏览器
application.setAttribute("name4","张三4");//保存的数据在服务器中有效,打开到关闭服务器
%>
<%
//通过pageContext寻找的方式取出我们保存的值
//从底层到高层(作用域): page->request->session->application->找不到
//JVM:双亲委派机制 应用->扩展类->rt.jar
String name1 =(String) pageContext.findAttribute("name1");
String name2 =(String) pageContext.findAttribute("name2");
String name3 =(String) pageContext.findAttribute("name3");
String name4 =(String) pageContext.findAttribute("name4");
String name5 =(String) pageContext.findAttribute("name5");//不存在
%>
<%--使用el表达式输出 ${}--%>
<h1>取出的值为:</h1>
<h2>${name1}</h2>
<h2>${name2}</h2>
<h2>${name3}</h2>
<h2>${name4}</h2>
<h2>${name5}</h2>
</body>
</html>
pageDemon02.jsp(在另一个页面取值)
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%--在另一个页面取pageContextDemon01.jsp中的值只能取到3和4
如果 request请求转发就可以取出来
--%>
<%
//通过pageContext寻找的方式取出我们保存的值
//从底层到高层(作用域)
String name1 =(String) pageContext.findAttribute("name1");
String name2 =(String) pageContext.findAttribute("name2");
String name3 =(String) pageContext.findAttribute("name3");
String name4 =(String) pageContext.findAttribute("name4");
String name5 =(String) pageContext.findAttribute("name5");//不存在
%>
<%--使用el表达式输出 ${}--%>
<h1>取出的值为:</h1>
<h2>${name1}</h2>
<h2>${name2}</h2>
<h2>${name3}</h2>
<h2>${name4}</h2>
<h2>${name5}</h2>
</body>
</html>
手动修改作用域与请求转发
//手动修改作用域,第三个参数为作用域
pageContext.setAttribute("hello","hello1",PageContext.SESSION_SCOPE);//等价于 session.setAttribute("hello","hello1");
<%
//请求转发
pageContext.forward("/index.jsp");
//等价于 request.getRequestDispatcher("/index.jsp").forward(request,response);
%>
8.6、JSP标签、JSTL标签、EL表达式
<!-- jstl表达式依赖 -->
<dependency>
<groupId>javax.servlet.jsp.jstl</groupId>
<artifactId>jstl-api</artifactId>
<version>1.2</version>
</dependency>
<!-- standard标签 -->
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
EL表达式:${}
- 获取数据
- 执行运算
- 获取web开发的常用对象
JSP标签:
<%--jsp:include --%>
<h1>1</h1>
<%--转发时添加数据--%>
<jsp:forward page="/jsptag2.jsp">
<jsp:param name="name" value="ikun"/>
<jsp:param name="age" value="23"/>
</jsp:forward>
<%--取出参数--%>
名字:<%=request.getParameter("name")%>
年龄:<%=request.getParameter("age")%>
JSTL表达式:
JSTL标签库的使用就是为了弥补html标签的不足;它自定义许多标签,可以供我们使用,标签的功能和Java代码一样
- 核心标签(掌握部分)
-
格式化标签
-
SQL标签
-
XML标签
JSTL标签库使用步骤:
- 引入对应的taglib
- 使用其中的方法
- 在Tomcat也需要导入jstl的包。否则会报错:jstl解析错误
c:if:
<%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h3>if测试</h3>
<hr>
<form action="coreif.jsp" method="get">
<%--el表达式获取表单中的数据
${param.参数名}
--%>
<input type="text" name="username" value="${param.username}">
<input type="submit" value="登录">
</form>
<%--判断如果提交的用户名是管理员则登录成功--%>
<c:if test="${param.username == 'admin'}" var="isAdmin">
<c:out value="管理员进入"></c:out>
</c:if>
<c:out value="${isAdmin}"></c:out>
</body>
</html>
c:choose:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%--引入jstl核心标签库--%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%--定义一个标量scroe,值为99--%>
<c:set var="score" value="99"/>
<c:choose>
<c:when test="${score>=95}">
你的成绩为优秀
</c:when>
<c:when test="${score>=80}">
你的成绩为良好
</c:when>
<c:when test="${score>=70}">
你的成绩为一般
</c:when>
<c:when test="${score<60}">
你的成绩为不及格
</c:when>
</c:choose>
</body>
</html>
c:forEach:
<%@ page import="java.util.ArrayList" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%--引入jstl核心标签库--%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
ArrayList<String> people = new ArrayList<>();
people.add(0,"张三");
people.add(1,"李四");
people.add(2,"王五");
people.add(3,"赵六");
people.add(4,"田七");
request.setAttribute("list",people);
%>
<%--var:每一次遍历出来的变量
items:要遍历的对象
begin:开始
end:结束
step:步长
--%>
<c:forEach var="people" items="${list}">
<c:out value="${people}"></c:out>
<br>
</c:forEach>
</body>
</html>
到这里关于JSP的知识就结束啦≧ω≦,希望对大家有所帮助!
大家觉得文章还可以的话可以点个推荐支持博主啊 (u‿ฺu✿ฺ)