jsp原理详解
9. jsp9.1 什么是JSPJava Server Pages : Java服务器端页面,也和Servlet一样,用于动态web技术!最大的特点:写Jsp就像写HTML区别:HTML只给用户提供静态的数据JSP页面中可以嵌套Java代码,为用户提供动态数据9.2jSP原理思路: JSP到底怎么执行的!代码层面没有任何问题服务器内部 工作tomcat 中有一个work目录idea中使用tomca
jsp
1 什么是JSP
Java Server Pages : Java服务器端页面,也和Servlet一样,用于动态web技术!
最大的特点:
- 写Jsp就像写HTML
- 区别:
- HTML只给用户提供静态的数据
- JSP页面中可以嵌套Java代码,为用户提供动态数据
2 jSP原理
思路: JSP到底怎么执行的!
-
代码层面没有任何问题
-
服务器内部 工作
tomcat 中有一个work目录
idea中使用tomcat会在idea中产生一个work目录
这个是 idea tomcat的工作空间
路径:
C:\Users\40875\AppData\Local\JetBrains\IntelliJIdea2020.2\tomcat\Unnamed_Javaweb-cookie-session\work\Catalina\localhost\Javaweb_cookie_session_war\org\apache\jsp
发现 页面转换成了Java程序
浏览器向服务器发送请求,不管访问什么资源,起始都是在访问Servlet
JSP最终也会被转换成为一个Java类
JSP本质上就是一个Servlet
//初始化
public void _jspInit() {
}
//销毁
public void _jspDestroy() {
}
//JSPServlet
public void _jspService(final javax.servlet.http.HttpServletRequest request, final javax.servlet.http.HttpServletResponse response)
-
判断请求
-
内置对象
final javax.servlet.jsp.PageContext pageContext; //页面上下文 javax.servlet.http.HttpSession session = null; // session final javax.servlet.ServletContext application; //application final javax.servlet.ServletConfig config; //config javax.servlet.jsp.JspWriter out = null; //out final java.lang.Object page = this; //page 当前 HttpServletRequest req // request 请求 HttpServletResponse resp //respones 响应
-
输出页面前增加的代码
// 设置响应的页面类型 response.setContentType("text/html;charset=UTF-8"); 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原理图
在JSP页面中;
只要是Java代码就会原封不动的输出
如果是HTML代码,就会被转换
out.print("<html>\t\n")
这样的格式,输出到前端
3 JSP基础语法
任何语言都有自己的语法,Java中有,JSP作为Java技术的一种应用,它拥有一些自己的扩容的语法,Java所有语法都支持
JSP表达式
<%--JSP表达式
作用:用来将程序的输出,输出到客户端
--%>
<%=变量或者表达式%>
<% new java.util.Date()%>
jsp 脚本片段
<%
int sum=0;
for (int i = 0; i <=100 ; i++) {
sum+=i;
}
out.write("<h1>"+sum+"</h1>");
%>
脚本片段的实现
<%
int x=10;
out.print(x);
%>
<p>这是一个JSP文档</p>
<%
int y=20;
out.print(y);
%>
<hr>
<%-- 在代码嵌套HTML元素--%>
<%
for (int i = 0; i <5 ; i++) {
%>
<h1>hellow world <%=i%></h1>
<%
}
%>
JSP声明
<%!
static {
System.out.println("Loading Servlet!");
}
private int globaVar=0;
public void aaa(){
System.out.println("进入了aaa方法");
}
%>
JSP声明: 会被编译到JSP生成Java类中! 其他的,就会被生成到 _jspService 方法中
在JSP中嵌入Java代码即可
<%%>
<%=%>
<%!%>
<%--注释--%>
jsp的注释,不会在客户端显示,HTML就会
4 JSP指令
<%-- @include会将两个页面合二为一--%>
<%@include file="common/header.jsp" %>
<h1>我是网页的正文</h1>
<%@include file="common/footer.jsp" %>
<hr>
<%--jsp标签
jsp:include :拼接页面 本质还是三个
--%>
<jsp:include page="/common/header.jsp"/>
<h1>我是网页的正文</h1>
<jsp:include page="common/footer.jsp"/>
总结:
在实际开发中建议使用 下面 jsp:include/的方式
如果使用上面那一种的话 如果在header.jsp或者在footer.jsp中声明了 int a=1; 又在当前jsp中声明了相同的变量 在jsp页面不会报错,去了浏览器里面 就报错了。
所以建议使用 jsp标签 进行页面拼接
5 九大内置对象
- PageContext 存东西
- Request 存东西
- Response
- Session 存东西
- Application 【ServletContext 】 存东西
- config 【ServletConfig】
- out
- page
- exception
<%
pageContext.setAttribute("name1","波波1"); //保存的数据只在一个页面中有效
request.setAttribute("name2","波波2"); //保存的数据只在一个请求中有效 转发可以携带请求
session.setAttribute("name3","波波3"); // 保存的数据只在一个会话中有效 浏览器关闭会话停止
application.setAttribute("name4","波波4"); //保存的数据只在服务器中生效 从打开服务器到关闭服务器
%>
request:客户端向服务器发送请求,产生的数据,用户看完了就没作用了,比如:新闻 用户看完了没作用了。
session:客户端向服务器发送请求,产生的数据,用户用完了一会还有用,比如:购物车;
application:客户端向服务器发送请求,产生的数据,一个用户用完了,其他用户还可能使用:比如:聊天数据;
6 JSP标签 JSTL标签 EL表达式
开始之前导入所学的依赖
<dependency>
<groupId>javax.servlet.jsp.jstl</groupId>
<artifactId>jstl-api</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
EL表达式: ${ }
- 获取数据
- 执行运算
- 获取web开发的常用对象
JSP 标签
发送:
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>111</h1>
<jsp:forward page="bbb.jsp">
<jsp:param name="name" value="aaabbb"/>
<jsp:param name="age" value="18"/>
</jsp:forward>
</body>
</html>
接收:
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="utf-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h2>222</h2>
姓名:<%= request.getParameter("name") %>
年龄:<%= request.getParameter("age") %>
</body>
</html>
JSTL 表达式
JSTL表达式的使用就是为了弥补HTML标签的不足;它自定义许多标签,供我们使用,标签的功能和Java代码一样
核心标签
JSTL 标签库使用步骤
- 引入对应的taglib
- 使用其中的方法
- 在Tomcat也需要引入jstl的包,否则会报错
c:if
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>测试</h1>
<form action="ccc.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 c:when
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%--定义一个变量Score 值为55--%>
<c:set var="score" value="55"/>
<c:choose>
<c:when test="${score>=90}">
优秀
</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 contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page import="java.util.ArrayList" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
ArrayList<String> people=new ArrayList();
people.add(0,"1");
people.add(1,"2");
people.add(2,"3");
people.add(3,"4");
people.add(4,"5");
people.add(5,"6");
request.setAttribute("list",people);
%>
<%--
var 每一次遍历出来的变量
itmes 要遍历的对象
begin 哪里开始
end 到哪里结束
step 步长
--%>
<c:forEach var="people" items="${list}">
<c:out value="${people}"></c:out> <br>
</c:forEach>
<hr>
<c:forEach var="people" items="${list}" begin="1" end="5" step="1">
<c:out value="${people}"></c:out> <br>
</c:forEach>
</body>
</html>
更多推荐
所有评论(0)