JSP

1.什么是jsp

Java Server Pages : Java服务器端页面,也和Servlet一样,用于动态Web技术!

最大的特点:

  • 写JSP就像在写HTML
  • 区别:
    • HTML只给用户提供静态的数据
    • JSP页面中可以嵌入JAVA代码,为用户提供动态数据;

2.jsp原理

我的理解

jsp在运行时,会被先转换成为一个java文件,再被编译为一个class类,这个class类继承了HttpJspBase类,而HttpJspBase继承自HttpServlet类,可以说,jsp本质就是一个servlet类,

相比于传统的servlet,jsp帮助程序员减少了写代码的繁琐步骤

思路:JSP到底怎么执行的!

  • 代码层面没有任何问题

  • 服务器内部工作

    tomcat中有一个work目录;

    IDEA中使用Tomcat的会在IDEA的tomcat中生产一个work目录

    我电脑的地址:

    C:\Users\Administrator\.IntelliJIdea2018.1\system\tomcat\Unnamed_javaweb-session-cookie\work\Catalina\localhost\ROOT\org\apache\jsp
    

    发现页面转变成了Java程序!

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lcIvHXq7-1586419445122)(…/img/1568345948307.png)]

浏览器向服务器发送请求,不管访问什么资源,其实都是在访问Servlet!

JSP最终也会被转换成为一个Java类!

JSP 本质上就是一个Servlet

//初始化
  public void _jspInit() {
      
  }
//销毁
  public void _jspDestroy() {
  }
//JSPService
  public void _jspService(.HttpServletRequest request,HttpServletResponse response)
      
  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/html");       //设置响应的页面类型
    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;
    
  4. 以上的这些个对象我们可以在JSP页面中直接使用!

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-77vFFk7s-1586419445124)(…/img/1568347078207.png)]

在JSP页面中;

只要是 JAVA代码就会原封不动的输出;

如果是HTML代码,就会被转换为:

out.write("<html>\r\n");

这样的格式,输出到前端!

3.jsp语法

任何语言都有自己的语法,JAVA中有,。 JSP 作为java技术的一种应用,它拥有一些自己扩充的语法(了解,知道即可!),Java所有语法都支持!

JSP表达式
  <%--JSP表达式
  作用:用来将程序的输出,输出到客户端
  <%= 变量或者表达式%>
  --%>
  <%= 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 = 2;
    out.println(y);
  %>

  <hr>


  <%--在代码嵌入HTML元素--%>
  <%
    for (int i = 0; i < 5; i++) {
  %>
    <h1>Hello,World  <%=i%> </h1>
  <%
    }
  %>
JSP声明
  <%!
    static {
      System.out.println("Loading Servlet!");
    }

    private int globalVar = 0;

    public void kuang(){
      System.out.println("进入了方法Kuang!");
    }
  %>

JSP声明:会被编译到JSP生成Java的类中!其他的,就会被生成到_jspService方法中!

在JSP,嵌入Java代码即可!

<%%>
<%=%>
<%!%>

<%--注释--%>

JSP的注释,不会在客户端显示,HTML就会!

4.jsp指令

1.自定义500和404错误

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q8wycb9t-1586419445128)(…/img/image-20200328153204971.png)]

在webapp下和WEB-INF同级目录下,新建两个包,名字分别为error和img,用来存放发生500和404后,自己定义的jsp页面,img则存放你要展示的图片

img包的名字只能为img,不能为image,否则图片会加载不出来

新建一个404.jsp在error包中

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<img src="../img/404.jpg" alt="">
</body>
</html>

在web.xml中配置相关的error文件

<error-page>
        <error-code>404</error-code>
        <location>/error/404.jsp</location>
    </error-page>

500同理

2.网页头部和尾部

改变网页中间的内容,头部和尾部不变

其中header.jsp和footer.jsp代表自己设置的网站的头部和外部,在网页中间要显示的部分,引用一下头部和尾部,则可以保持头部和尾部不变

<%@include file="common/header.jsp"%>
<jsp:include page="/common/header.jsp"/>

使用<%@include file=""%>和<jsp:include page=""/>都可以导入头部和尾部,区别是,
<%@include file=""%>的内容和中间的内容在转换为class类后,在一个类里面,这意味着你不能定义名字相同的变量,或者说在第一个作用域不能定义两个名字相同的变量

而<jsp:include page=""/>的内容和中间的内容在转换为class类后,只是在中间类里面调用了头部和尾部的类,二者是两个类,定义内容不受影响。

<%@page args.... %>
<%@include file=""%>

%--@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"/>

5.九大内置对象

  • PageContext 存东西

  • Request 存东西

  • Response

  • Session 存东西

  • Application 【SerlvetContext】 存东西

  • config 【SerlvetConfig】

  • out

  • page ,不用了解

  • exception

    取对象的时候,先从pageContext里面取,没有后再往request里面,即

    pageContext > request > session > application

pageContext.setAttribute("name1","秦疆1号"); //保存的数据只在一个页面中有效
request.setAttribute("name2","秦疆2号"); //保存的数据只在一次请求中有效,请求转发会携带这个数据
session.setAttribute("name3","秦疆3号"); //保存的数据只在一次会话中有效,从打开浏览器到关闭浏览器
application.setAttribute("name4","秦疆4号");  //保存的数据只在服务器中有效,从打开服务器到关闭服务器

request:客户端向服务器发送请求,产生的数据,用户看完就没用了,比如:新闻,用户看完没用的!

session:客户端向服务器发送请求,产生的数据,用户用完一会还有用,比如:购物车;

application:客户端向服务器发送请求,产生的数据,一个用户用完了,其他用户还可能使用,比如:聊天数据;

用四种方式存东西,但是只用pageContext去取

1.${name4} ,EL表达式,存在就取出来,不存在就不取

<%=name5%>,存在就取出来,不存在就取个null

2.当前页面四个都能取出来

3.新建与1个jsp文件,只能取出来3,4;在当前页面转发到新建jsp页面,则2也可以取出来

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%
    pageContext.setAttribute("name1","神州一号");
    request.setAttribute("name2","神州二号");
    session.setAttribute("name3","神州三号");
    application.setAttribute("name4","神州四号");
%>

<%
    String name1 = (String) pageContext.getAttribute("name1");
    String name2 = (String) pageContext.getAttribute("name2");
    String name3 = (String) pageContext.getAttribute("name3");
    String name4 = (String) pageContext.getAttribute("name4");
    String name5 = (String) pageContext.getAttribute("name5");

%>
<h1>取出来的内容有:</h1>
<h3>${name1}</h3>
<h3>${name2}</h3>
<h3>${name3}</h3>
<h3>${name4}</h3>
<h3><%=name5%></h3>

</body>
</html>

6.jsp标签、jstl标签和EL表达式

我的理解

  1. 使用jstl标签和EL标签要配置相关的依赖,及导入相关的jar包

    <!-- 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>
    
  2. 在jsp中使用不同的jstl标签,要导入对应的库

    如使用jstl核心库,就要导入下面语句

    <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
    

EL表达式: ${ }

  • 获取数据
  • 执行运算
  • 获取web开发的常用对象

JSP标签

  • jsp:include,在一个jsp页面中包含另一个jsp页面
  • jsp:forward,从一个jsp页面转向另一个jsp页面
  • jsp:param ,定义一个或多个参数
<%--jsp:include--%>

<%--
http://localhost:8080/jsptag.jsp?name=kuangshen&age=12
--%>

<jsp:forward page="/jsptag2.jsp">
    <jsp:param name="name" value="kuangshen"></jsp:param>
    <jsp:param name="age" value="12"></jsp:param>
</jsp:forward>

JSTL表达式

JSTL标签库的使用就是为了弥补HTML标签的不足;它自定义许多标签,可以供我们使用,标签的功能和Java代码一样!

格式化标签

SQL标签

XML 标签

核心标签 (掌握部分)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YsH1J9Sn-1586419445129)(…/img/1568362473764.png)]

JSTL标签库使用步骤

  • 引入对应的 taglib
  • 使用其中的方法
  • 在Tomcat 也需要引入 jstl的包,否则会报错:JSTL解析错误

c:if

<head>
    <title>Title</title>
</head>
<body>


<h4>if测试</h4>

<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:if>

<%--自闭合标签--%>
<c:out value="${isAdmin}"/>

</body>

c:choose c:when

<body>

<%--定义一个变量score,值为85--%>
<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>

c:forEach

<%

    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}"/> <br>
</c:forEach>

<hr>

<c:forEach var="people" items="${list}" begin="1" end="3" step="1" >
    <c:out value="${people}"/> <br>
</c:forEach>

yList 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=" l i s t " > < c : o u t v a l u e = " {list}"> <c:out value=" list"><c:outvalue="{people}"/>

</c:forEach>


<c:forEach var=“people” items=" l i s t " b e g i n = " 1 " e n d = " 3 " s t e p = " 1 " > < c : o u t v a l u e = " {list}" begin="1" end="3" step="1" > <c:out value=" list"begin="1"end="3"step="1"><c:outvalue="{people}"/>

</c:forEach>

参考

https://www.bilibili.com/video/BV12J411M7Sj?p=40


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值