Java Web系列之使用Eclipse開發web項目(jsp項目)

基本概念

  • 在eclipse中建立的web項目:
  1. 瀏覽器能夠直接訪問WebContent中的文件
  2. 可是WEB-INF中的文件沒法經過客戶端(瀏覽器)直接訪問,只能經過請求轉發來訪問

注意:並非任何內部的跳轉都都能訪問WEB-INF,跳轉有請求轉發和重定向兩種方式html

  • 配置Tomcat運行時環境

jsp<->servletjava

  1. 將Tomcat/lib中的servlet-api.jar加入項目的構建路徑
  2. 右鍵項目->build path ->add library ->server runtime
  • 部署Tomcat
  • 在servers面板,新建一個Tomcat實例,再在該實例中部署
  • 注意:通常建議將eclipse中的tomcat與本地Tomcat中的信息保持一致;第一次建立完設置託管模式;不然之後就變灰了,不能改
  • 統一字符集編碼

設置jsp文件的編碼(jsp中的pageEncoding屬性):jsp->java
設置瀏覽器讀取jsp文件的編碼(jsp文件中content屬性)
通常講上述設置成統一碼,推薦使用國際碼utf-8web

文本編碼:shell

  1. 將整個eclipse中的之後文件統一設置
  2. 設置一個項目
  3. 設置單獨文件
  • jsp的頁面元素:HTML,Java代碼(腳本scriptlet),指令
  1. 腳本scriptlet
//1
<%
	局部變量、Java語句
%>
//2
<%!
	全局變量、定義方法
%>
//3
<%= 輸出表達式    %>

通常而言,修改web.xml須要重啓tomcat,修改jsp不須要api

注意:out.println()不會回車,須要添加HTML的換行符,out.println()中能夠識別html代碼瀏覽器

  1. 指令
  • page指令
<%@page .....%>
  • page指令的屬性:
  1. language:jsp頁面使用的腳本語言
  2. import:導入類
  3. pageEncoding:jsp文件自身編碼 jsp->java
  4. contentType:瀏覽器解析jsp的編碼
<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
  1. 註釋
  1. html註釋 網頁源代碼裏邊能夠顯示
  2. java註釋// /.../
  3. jsp註釋<%-- jsp註釋 --%>

JSP九大內置對象(重點)

  • jsp九大內置對象(重點)(自帶的,不須要new也能使用的對象)
  1. out:輸出對象,向客戶端輸出內容
  2. request:(封裝請求信息)請求對象;存儲"客戶端向服務端發送的請求信息"(數據只在同一次請求有效)
  • 常見方法:
  • String getParameter(String name):根據請求的字段名key,返回字段值value;
  • String[] getParameterValues(String name):根據請求的字段名key,返回多個字段值value(checkbox);
  • void setCharacterEncoding("編碼格式utf-8"):具體設置post請求編碼(tomcat默認編碼iso-8859-1);
  • getRequestDispatcher("b.jsp").forward(request,response): 請求轉發的方式跳轉頁面 A->B
  • ServletContext getServerContext():獲取項目的ServletContext對象
  • 示例:
  • 註冊
  • 註冊頁register.jsp 展現頁show.jsp
  • 訪問url含義
  • localhost:8080/MyJspProject/show.jsp?uname=aa&upwd=wer&uage=12
  • 鏈接/文件?參數名1=參數值1&參數名2=參數值2&參數名3=參數值3
  • 統一請求的編碼request
  1. get方式 若是出現亂碼解決方式:
  • 統一每個變量的編碼(不推薦)
  • 變量名=new String(變量名.getBytes("iso-8859-1"),"utf-8");
  • 每一個變量改一次
  • 修改server.xml一勞永逸
  • 建議使用Tomcat時,首先在server.xml中統一編碼方式 URIEncoding="UTF-8"
  1. post方式
  • request.setCharacterEncoding("utf-8");
  • get提交方式:method="get"和地址欄、超連接請求方式默認都屬於get提交方式
  • get與post請求方式的區別:
  1. get方式在地址欄顯示請求信息(可是地址欄容納信息有限,4-5kb,若是請求數據存在大文件,圖片,存儲不下會報錯),post不會顯示
  2. 文件上傳操做,必須是post
  3. 推薦使用:post
  1. response:(響應信息)響應對象
  • 提供的方法:
  1. void addCookie(Cookie cookie):服務端向客戶端增長cookie對象
  2. void sendRedirect(String location)throws IOException:頁面跳轉的一種方式
  3. void setContentType(String type):設置服務端響應的編碼(設置服務端的contentType類型)
  • 示例:登陸
  • login.jsp登陸->check.jsp判斷->success.jsp
  • 請求轉發和重定向的區別:
  1. 地址欄改變:不變,變
  2. 是否保留第一次請求時的數據:保留,不保留(跳到success.jsp拿不到數據) --4種範圍對象
  3. 請求的次數:1次(請求轉發的跳轉是在服務器內部跳轉),2次
  4. 跳轉發生的位置:服務器端,客戶端
  5. 轉發、重定向:
  • 轉發: 張三(客戶端)->【服務窗口A->服務窗口B】
  • 重定向: 張三(客戶端)->【服務窗口A】->張三(客戶端)->【服務窗口B】
  1. session(存在於服務端)
  • Cookie
  • Cookie(存在於客戶端,不是內置對象,得new):
  • Cookie是有服務端生成的,再發送給客戶端保存;
  • Cookie至關於本地緩存的做用:客戶端->服務端
  • 做用:提升訪問服務端的效率,可是安全性較差
  • Cookie:name-value
  1. javax.servlet.http.Cookie類產生的 public Cookie(String name,String value)
  2. String getName():獲取name
  3. String getValue():獲取value
  4. void setMaxAge(int expiry):設置最大有效期(秒)
  1. 服務端準備Cookie:
  • response.addCookie(Cookie cookie)
  • 頁面跳轉(轉發,重定向)
  1. 客戶端獲取Cookie:
  • request.getCookies(); //獲取Cookie必須每次都是獲取所有
  • 注意:
  1. 服務端增長cookie:response對象
    客戶端獲取對象:request對象
  2. 不能直接獲取單獨對象,只能一次性將所有cookie獲得
    除了本身設置的Cookie對象外,還有一個name叫JSESSIONIDDE的cookie
  3. 使用Cookie實現自動記住用戶名 //建議cookie只保存英文數字,不然要編解碼
  • session:會話
  1. 瀏覽網站:開始-關閉
  2. 購物:瀏覽-付款-退出
  3. 電子郵件:瀏覽-寫郵件-退出 一次開始到關閉
  • session機制
  • 客戶端第一次請求服務端
  1. 客戶端第一次請求服務端時,(jsessionid-sessionid)服務端會產生一個session對象(用於保存該客戶的信息),而且每一個session對象都會有惟一的sessionId(用於區分其餘session);
  2. 服務端會產生一個cookie,而且該cookie的name=JSESSIONID,value=服務端sessionId的值;
  3. 而後,服務端會在響應客戶端的同時,將該cookie發送給客戶端,至此 客戶端就有一個cookie(JSESSIONID)
  4. 所以,客戶端的cookie就能夠和服務端的session一一對應(JSESSIONID-SESSIONID)
  • 客戶端第二次/n次訪問服務端
  1. 客戶端第二次/n次訪問服務端時:服務端會先用客戶端cooki中的JSESSIONID去服務端session中匹配sessionId,若匹配到,則說明不是第一次訪問
  • 例子:
  • 客戶端:顧客
  • 服務端:存包處

顧客第一次存包:商場判斷此人是否是以前已經存過包(是否有鑰匙),若是新顧客(沒鑰匙),分配一個鑰匙;緩存

第二次/n次,若是手裏有鑰匙,直接一一對應,不分配tomcat

  • session:
  1. session存儲在服務端
  2. session是在同一個用戶請求時共享
  3. session實現機制:第一次客戶請求時產生一個sessionid並複製給jsessionid而後發給客戶端.最終實現sessionid與jsessionid一一對應
  • session方法
  1. String getId():獲取sessionId
  2. boolean isNew():判斷是不是新用戶(第一次訪問)
  3. void invalidate():使session失效(退出登陸、註銷)
  4. void setAttribute():
  5. Object getAttribute():
  6. void setMaxInactiveInterval(秒):設置最大有效非活動時間
  7. int getMaxInactiveInterval(秒):獲取最大有效非活動時間
  • 示例:
  • 登陸
  • JSESSIONID5B3D4AA49AB91B1311F514BCF727DD29
  • sessionId5B3D4AA49AB91B1311F514BCF727DD29
  • 客戶端在第一次請求服務端時,若是服務端發現此請求沒有JSESSIONID,則會建立一個name=JSESSIONID的cookie並返回給客戶端
  • Cookie
  1. 不是內置對象,要使用必須new
  2. 可是,服務端會自動new一個Jsessionid的cookie
  • cookie和session的區別:
  1. 位置分爲:客戶端和服務端
  2. 安全爲:不安全和較安全
  3. 保存的內容:Object和字符串String
  1. application:全局對象
  1. String getContextPath():虛擬路徑
  2. String getRealPath(String name):絕對路徑(虛擬路徑,相對的的絕對路徑)
  1. pageContext:JSP頁面容器
  2. config:配置對象
  3. page:當前JSP頁面對象(至關於JAVA中的this)
  4. exception:異常對象

九大內置對象中四種範圍對象(小到大)

  1. pageContext(也可稱爲page對象):當前頁面有效,頁面跳轉後無效
  2. request:同一次請求有效,其餘請求無效(請求轉發後有效,重定向後無效)
  3. session:同一次會話有效(不管怎麼跳轉都有效,只要不關/切換瀏覽器)
  4. application:全局有效(整個項目有效):整個項目運行期間都有效,切換瀏覽器也有效,關閉服務或者切換項目無效
  • 以上四種對象的共有的方法:
  1. Object getAttribute(String name):根據屬性名,獲取屬性值
  2. void setAttribute(String name,Object obj):設置屬性值(新增,修改)
  3. setAttribute("a","b");//若是a對象以前不存在,則新建一個a對象; 若是a以前已經存在,則將a的值改成b
  4. void removeAttribute(String name):根據屬性名,刪除對象 //set賦值,get取值,儘可能使用小範圍,性能損耗小
相關文章
相關標籤/搜索