1. 程式人生 > >JavaWeb12-HTML篇筆記(一)

JavaWeb12-HTML篇筆記(一)

Java

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 :當前頁面中有效.   pageContext PageContext
    * RequestScope  :一次請求範圍.    request HttpServletRequest
    * SessionScope  :一次會話範圍.    session HttpSession
    * ApplicationScope  :應用範圍   application ServletContext
【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的概述】
![](http://i2.51cto.com/images/blog/201805/28/3bd3f7dc0fbf2ff0468ca17039acc69b.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)
? 什麽是EL:
? 為什麽學習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");

JavaWeb12-HTML篇筆記(一)