Java Server Pages : Java服务器端页面,也和Servlet一样,用于动态web技术!
最大的特点:
思路: JSP到底怎么执行的!
代码层面没有任何问题
服务器内部 工作
tomcat 中有一个work目录
idea中使用tomcat会在idea中产生一个work目录
路径:
C:\Users\40875\AppData\Local\JetBrains\IntelliJIdea2020.2\tomcat\Unnamed_Javaweb-cookie-session\work\Catalina\localhost\Javaweb_cookie_session_war\org\apache\jsp
浏览器向服务器发送请求,不管访问什么资源,起始都是在访问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("\t\n")
这样的格式,输出到前端
任何语言都有自己的语法,Java中有,JSP作为Java技术的一种应用,它拥有一些自己的扩容的语法,Java所有语法都支持
<%--JSP表达式
作用:用来将程序的输出,输出到客户端
--%>
<%=变量或者表达式%>
<% new java.util.Date()%>
<%
int sum=0;
for (int i = 0; i <=100 ; i++) {
sum+=i;
}
out.write(""
+sum+"");
%>
脚本片段的实现
<%
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>
<%
}
%>
<%!
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就会
<%-- @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标签 进行页面拼接
<%
pageContext.setAttribute("name1","波波1"); //保存的数据只在一个页面中有效
request.setAttribute("name2","波波2"); //保存的数据只在一个请求中有效 转发可以携带请求
session.setAttribute("name3","波波3"); // 保存的数据只在一个会话中有效 浏览器关闭会话停止
application.setAttribute("name4","波波4"); //保存的数据只在服务器中生效 从打开服务器到关闭服务器
%>
request:客户端向服务器发送请求,产生的数据,用户看完了就没作用了,比如:新闻 用户看完了没作用了。
session:客户端向服务器发送请求,产生的数据,用户用完了一会还有用,比如:购物车;
application:客户端向服务器发送请求,产生的数据,一个用户用完了,其他用户还可能使用:比如:聊天数据;
开始之前导入所学的依赖
<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表达式: ${ }
JSP 标签
发送:
Title
111
接收:
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="utf-8" language="java" %>
Title
222
姓名:<%= request.getParameter("name") %>
年龄:<%= request.getParameter("age") %>
JSTL表达式的使用就是为了弥补HTML标签的不足;它自定义许多标签,供我们使用,标签的功能和Java代码一样
JSTL 标签库使用步骤
c:if
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
Title
测试
<%--判断如果提交用户是管理员 则登录成功--%>
c:choose c:when
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
Title
<%--定义一个变量Score 值为55--%>
优秀
良好
一般
不及格
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" %>
Title
<%
ArrayList 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 步长
--%>