第12章WEB12-JSP&EL&JSTL篇

今日任务
Ø 商品信息的显示
教学导航
教学目标
掌握JSP的基本的使用
掌握EL的表达式的用法
掌握JSTL的常用标签的使用
教学方法
案例驱动法
1.1 上次课内容回顾:
Cookie :就是将数据保存到客户端浏览器的会话技术.

  • 从浏览器获得Cookie :request.getCookies();
  • 向浏览器回写Cookie :response.addCookie(Cookie cookie);
  • Cookie的相关的API :
    • setPath(String path); -- /day11 /day11/aaa
    • setMaxAge(int time); -- 有效时长.
    • setDomain(String domain);
  • Cookie的分类:
    • 会话级别Cookie:会话级别关闭浏览器的时候Cookie就销毁了.默认的
    • 持久级别Cookie:设置有效时长的Cookie,关闭浏览器的时候不会销毁的.
      Session :就是将数据保存到服务器端的会话技术.基于Cookie回写SessionID的.
  • Session存取数据:
    • setAttribute(String name,Object value);
    • getAttribute(String name);
  • Session作用域:
    • session的作用范围:一次会话.(多次请求)
    • session生命周期:
      • 创建:第一次调用getSession的时候创建session。
      • 销毁:
        • 非正常关闭服务器.
        • session过期
        • 手动调用invalidate方法的时候
          1.2 案例一:在JSP的页面中显示商品的信息.1.2.1 需求:
          数据库中存放了很多商品信息,现在将商品的信息全部显示到页面.
          1.2.2 分析:1.2.2.1 技术分析:
          【JSP的概述】
          Ø 什么是JSP:
  • Java Server Pages(Java服务器端的页面)
    Ø 为什么要学习JSP:
  • SUN公司推出的Servlet自身有缺陷,没有办法与ASP,PHP进行竞争.推出了动态网页开发技术JSP.
    Ø 使用JSP:
  • JSP = HTML + Java代码 + JSP自身的东西.
    Ø 执行JSP的过程:
  • JSP翻译成Servlet,编译这个Servlet的类,生成class文件.得到执行.
    【JSP的脚本】
    Ø <%! %> :翻译成Servlet中的成员内容. 定义变量,方法,类. -- 不建议.
    Ø <% %> :翻译成Servlet中service方法内部的内容. 定义类,变量
    Ø <%= %> :翻译成Servlet中service方法中out.print();
    【JSP的注释】-了解
    Ø HTML的注释 :<!-- 注释 -->
    Ø Java代码的注释 :// 单行注释 /多行注释/ /* 文档注释 /
    Ø JSP的注释 :<%-- JSP的注释 --%>
    【JSP的指令】
    Ø 指令的语法:
    <%@ 指令名称 属性名称=”属性值” 属性名称=”属性值” ...%>
    Ø JSP中有三个指令:page指令, include指令, taglib指令.
    Ø JSP中page指令:<%@ page %> -- 设置JSP的.
  • language :JSP脚本中使用的语言.现在只能写java.
  • contentType :设置浏览器打开这个JSP的时候采用的默认的字符集的编码.
  • pageEncoding :设置文件保存到本地硬盘,以及生成Servlet后,Servlet保存到硬盘上的编码.
  • import :在JSP中引入类对象.但是import可以出现多次.
    <%@page import="java.util.ArrayList"%>
    <%@page import="java.util.List"%>
  • extends :设置JSP翻译成Servlet后继承的类,默认值:org.apache.jasper.runtime.HttpJspBase,这个值要想修改,这个类必须是HttpServlet的子类
  • autoFlush :设置JSP的缓存自动刷出.true:自动刷出.
  • buffer :设置JSP的缓冲区的大小,默认8kb.
  • session :设置在JSP中是否可以直接使用session对象.默认值是true.
  • isELIgnored :设置在JSP中是否忽略EL表达式.默认值是false不忽略.
  • errorPage :设置错误友好页面的提示.
  • isErrorPage :通过这个设置显示JSP的错误信息.
    • 设置全局的错误友好页面:
      • 在web.xml中设置:
        <error-page>
        <error-code>404</error-code>
        <location>/404.jsp</location>
        </error-page>
        <error-page>
        <error-code>500</error-code>
        <location>/500.jsp</location>
        </error-page>
        Ø JSP中的include指令:指示JSP包含其他的页面.
        <%@ include file="logo.jsp" %>
        <%@ include file="menu.jsp" %>
        <h1>BODY部分</h1>
        <%@ include file="footer.jsp" %>
        Ø JSP中的taglib指令:指示JSP引入标签库.
        <%@ taglib uri="标签的URI的路径" prefix="标签的别名" %>
        【JSP的内置对象(*****)】
        Ø JSP的内置对象:在JSP中可以直接使用的对象.
        Ø JSP中有9大内置对象:
  • request HttpServletRequest getParameter(),setAttribute(String name,Object value);
  • response HttpServletResponse setHeader(String name,String value);getOutputStream();getWriter();
  • session HttpSession setAttribute();getAttribute();
  • application ServletContext setAttribute();getAttribute();
  • page Object toString();wait();
  • pageContext PageContext setAttribute();getAttribute();
  • config ServletConfig getServletName();getServletContext();
  • out JspWriter write(),print();
  • exception Throwable getMessage(),getCause(); 设置isErrorPage=”true”
    Ø page内置对象 :真实对象是Object,就是JSP翻译成Servlet后的类的引用.
    Ø out内置对象 :out和response.getWriter是不是同一个对象?区别是什么?
  • 不是out真实对象JspWriter ,response获得Writer是PrintWriter.
    Ø pageContext内置对象 :
  • 获得其他的8个内置对象 :编写通用性代码或者框架的时候.
  • 向JSP的四个域中存取数据 :
    JSP的四个域范围:
    • PageScope:当前页面中有效.pageContextPageContext
    • RequestScope:一次请求范围.requestHttpServletRequest
    • SessionScope:一次会话范围.sessionHttpSession
    • ApplicationScope:应用范围applicationServletContext
      【JSP的动作标签】列出6个.
      Ø 标签的作用:简化代码.
      Ø <jsp:forward /> :用于页面的转发.
  • <jsp:forward page="/demo1-jsp/demo3-object/demo3.jsp"></jsp:forward>
    Ø <jsp:include /> :用于页面的包含.(动态包含)
    *****静态包含和动态包含的区别?(<%@ include%>和<jsp:include>)
    Ø <jsp:param /> :用于带有路径的标签下,传递参数.
    Ø <jsp:useBean /> :用于在JSP中使用JavaBean.
    Ø <jsp:setProperty /> :用于在JSP中向JavaBean设置属性的.
    Ø <jsp:getProperty /> :用于在JSP中获得JavaBean的属性.
    1.2.2.2 EL表达式:
    【EL的概述】
    Ø 什么是EL:
    第12章WEB12-JSP&EL&JSTL篇
    Ø 为什么学习EL:
  • 简化JSP的代码,而且减少<%%>
    Ø 使用EL表达式:
  • 语法:${ EL表达式 }
    Ø EL的功能:
  • 获取数据:(JSP的四个域)
  • 执行运算:
  • 操作WEB开发的常用的对象:
  • 调用Java中方法:--很少用.
    【EL获取数据】
    <h3>存取是普通的单值数据</h3>
    <%
    //pageContext.setAttribute("name", "pValue");
    //request.setAttribute("name", "rValue");
    //session.setAttribute("name", "sValue");
    application.setAttribute("name", "aValue");
    %>
    <%=pageContext.getAttribute("name") %> <!-- 如果没找到 返回null -->
    <%=request.getAttribute("name") %>
    <%=session.getAttribute("name") %>
    <%=application.getAttribute("name") %>
    <hr/>
    ${ pageScope.name } <!-- 返回的是"" -->
    ${ requestScope.name }
    ${ sessionScope.name }
    ${ applicationScope.name }
    <hr/>
    ${ name } <!-- 类似findAttribute("name") 先从page域中查找,没找到去request域中查询,没有找到去session域中找,没有找到就去application域中找 -->
    <h3>获取数组的数据</h3>
    <%
    String[] arrs = {"李旭华","李冠希","杨凤","杨如花"};
    pageContext.setAttribute("arrs", arrs);
    %>
    ${ arrs[0] }
    ${ arrs[1] }
    ${ arrs[2] }
    ${ arrs[3] }
    <h3>获取List集合的数据</h3>
    <%
    List<String> list = new ArrayList<String>();
    list.add("李芙蓉");
    list.add("杨芙蓉");
    list.add("王凤");
    pageContext.setAttribute("list", list);
    %>
    ${ list[0] }
    ${ list[1] }
    ${ list[2] }
    <h3>获取Map集合的数据</h3>
    <%
    Map<String,String> map = new HashMap<String,String>();
    map.put("aaa","李旭华");
    map.put("bbb","杨久君");
    map.put("ccc","李芮");
    map.put("ddd","李凤");
    pageContext.setAttribute("map", map);
    %>
    ${ map.aaa }
    ${ map.bbb }
    ${ map.ccc }
    ${ map.ddd }
    <h3>获取对象的数据</h3>
    <%
    User user = new User(1,"aaa","123");
    pageContext.setAttribute("user", user);
    %>
    ${ user.id }
    ${ user.username }
    ${ user.password }
    <h3>获取对象的集合的数据</h3>
    <%
    User user1 = new User(1,"aaa","123");
    User user2 = new User(2,"bbb","123");
    User user3 = new User(3,"ccc","123");

    List<User> userList = new ArrayList<User>();
    userList.add(user1);
    userList.add(user2);
    userList.add(user3);
    
    pageContext.setAttribute("userList", userList);

    %>
    ${ userList[0].id } - ${ userList[0].username } - ${ userList[0].password }<br/>
    ${ userList[1].id } - ${ userList[1].username } - ${ userList[1].password }<br/>
    ${ userList[2].id } - ${ userList[2].username } - ${ userList[2].password }<br/>
    ***** .和[]的区别.

    • []用于有下标的数据(数组,list集合) .用于有属性的数据(map,对象)
    • 如果属性名中包含有特殊的字符.必须使用[]
      【EL执行运算】
      <h1>EL的功能二:执行运算</h1>
      <h3>EL执行算数运算</h3>
      <%
      pageContext.setAttribute("n1", "10");
      pageContext.setAttribute("n2", "20");
      pageContext.setAttribute("n3", "30");
      pageContext.setAttribute("n4", "40");
      %>
      ${ n1 + n2 + n3 }
      <h3>EL执行逻辑运算</h3>
      ${ n1 < n2 } - ${ n1 lt n2 } <!-- less than --><br/>
      ${ n1 > n2 } - ${ n1 gt n2 } <!-- great than --><br/>
      ${ n1 <= n2 } - ${ n1 le n2 } <!-- less equal --><br/>
      ${ n1 >= n2 } - ${ n1 ge n2 } <!-- great equal --><br/>
      ${ n1 == n2 } - ${ n1 eq n2 } <!-- equal --><br/>
      <h3>EL执行关系运算</h3>
      ${ n1<n2 && n3 < n4 } - ${ n1<n2 and n3 < n4 }<br/>
      ${ n1<n2 || n3 < n4 } - ${ n1<n2 or n3 < n4 }<br/>
      ${ !(n1 < n2) } - ${ not(n1<n2) }
      <h3>EL执行三元运算</h3>
      ${ n1 < n2 ? "正确":"错误" }
      <h3>empty运算</h3>
      ${ user == null } - ${ empty user }
      ${ user != null } - ${ not empty user }
      【EL操作WEB开发的常用对象11个】
      <h1>EL功能三:操作WEB开发常用的对象</h1>
      <!--
      pageScope,requestScope,sessionScope,applicationScope - 获取JSP中域中的数据
      param,paramValues - 接收参数.
      header,headerValues - 获取请求头信息
      initParam - 获取全局初始化参数
      cookie - WEB开发中cookie
      pageContext - WEB开发中的pageContext.
      -->
      <h3>接收请求的参数</h3>
      <%= request.getParameter("id") %>
      <%= request.getParameter("name") %>
      <%= Arrays.toString(request.getParameterValues("hobby")) %>
      <hr/>
      ${ param.id }
      ${ param.name }
      ${ paramValues.hobby[0] }
      ${ paramValues.hobby[1] }
      <h3>获取请求头</h3>
      <%= request.getHeader("User-Agent") %>
      <hr/>
      ${ header["User-Agent"] }
      <h3>获取全局初始化参数</h3>
      ${ initParam.username }
      <h3>获取Cookie中的值</h3>
      ${ cookie.history.value }
      <h3>获取PageContext中的对象</h3>
      IP地址:${ pageContext.request.remoteAddr }
      工程路径:${ pageContext.request.contextPath }
      1.2.2.3 JSTL
      【JSTL的概述】
      Ø 什么是JSTL:

Ø 为什么学习JSTL:

  • JSTL和EL结合 替换页面中<%%>
    Ø JSTL版本:
  • JSTL1.0 :不支持EL表达式.
  • JSTL1.1 和 1.2 :支持EL表达式.
    Ø JSTL的标签库:包含了五类标签.
  • core(核心标签),fmt(国际化标签),xml(XML标签),sql(SQL标签),fn(JSTL提供EL函数库)
    Ø 使用JSTL:
  • 引入JSTL的相关的jar包.
  • 在页面中引入标签库.<%@ taglib uri=”” prefix=””%>
    【JSTL的核心标签的用法】
  • if
  • forEach
    【JSTL的提供EL的函数库】
    <h1>JSTL提供的EL的函数库</h1>
    ${ fn:contains("Hello World","Hello") }
    ${ fn:length("HelloWorld") }
    ${ fn:toLowerCase("ABCDE") }
    <c:forEach var="i" items='${ fn:split("a-b-c-d","-") }'>
    ${ i }
    </c:forEach>
    1.2.3 代码实现:1.2.3.1 创建数据库:
CREATE TABLE `product` (
  `pid` varchar(32) NOT NULL,
  `pname` varchar(50) DEFAULT NULL,
  `market_price` double DEFAULT NULL,
  `shop_price` double DEFAULT NULL,
  `pimage` varchar(200) DEFAULT NULL,
  `pdate` date DEFAULT NULL,
  `is_hot` int(11) DEFAULT NULL,
  `pdesc` varchar(255) DEFAULT NULL,
  `pflag` int(11) DEFAULT NULL,
  `cid` varchar(32) DEFAULT NULL,
  PRIMARY KEY (`pid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

1.2.3.2 页面显示:

<c:forEach var="p" items="${list }">
<tr>
<td>${ p.pid }</td>
<td>${ p.pname }</td>
<td>${ p.shop_price }</td>
<td>
<c:if test="${ p.is_hot == 1 }">
是
</c:if>
<c:if test="${ p.is_hot != 1 }">
否
</c:if>
</td>
<td>${ p.pdesc }</td>
</tr>
</c:forEach>

转载于:https://blog.51cto.com/13587708/2097232

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值