- 瀏覽器能夠直接訪問WebContent中的文件
- 可是WEB-INF中的文件沒法經過客戶端(瀏覽器)直接訪問,只能經過請求轉發來訪問
注意:並非任何內部的跳轉都都能訪問WEB-INF,跳轉有請求轉發和重定向兩種方式html
jsp<->servletjava
- 將Tomcat/lib中的servlet-api.jar加入項目的構建路徑
- 右鍵項目->build path ->add library ->server runtime
- 在servers面板,新建一個Tomcat實例,再在該實例中部署
- 注意:通常建議將eclipse中的tomcat與本地Tomcat中的信息保持一致;第一次建立完設置託管模式;不然之後就變灰了,不能改
設置jsp文件的編碼(jsp中的pageEncoding屬性):jsp->java
設置瀏覽器讀取jsp文件的編碼(jsp文件中content屬性)
通常講上述設置成統一碼,推薦使用國際碼utf-8web
文本編碼:shell
- 將整個eclipse中的之後文件統一設置
- 設置一個項目
- 設置單獨文件
//1 <% 局部變量、Java語句 %> //2 <%! 全局變量、定義方法 %> //3 <%= 輸出表達式 %>
通常而言,修改web.xml須要重啓tomcat,修改jsp不須要api
注意:out.println()不會回車,須要添加HTML的換行符,out.println()中能夠識別html代碼瀏覽器
<%@page .....%>
- language:jsp頁面使用的腳本語言
- import:導入類
- pageEncoding:jsp文件自身編碼 jsp->java
- contentType:瀏覽器解析jsp的編碼
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
- html註釋 網頁源代碼裏邊能夠顯示
- java註釋// /.../
- jsp註釋<%-- jsp註釋 --%>
- 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
- localhost:8080/MyJspProject/show.jsp?uname=aa&upwd=wer&uage=12
- 鏈接/文件?參數名1=參數值1&參數名2=參數值2&參數名3=參數值3
- get方式 若是出現亂碼解決方式:
- 統一每個變量的編碼(不推薦)
- 變量名=new String(變量名.getBytes("iso-8859-1"),"utf-8");
- 每一個變量改一次
- 修改server.xml一勞永逸
- 建議使用Tomcat時,首先在server.xml中統一編碼方式 URIEncoding="UTF-8"
- post方式
- request.setCharacterEncoding("utf-8");
- get與post請求方式的區別:
- get方式在地址欄顯示請求信息(可是地址欄容納信息有限,4-5kb,若是請求數據存在大文件,圖片,存儲不下會報錯),post不會顯示
- 文件上傳操做,必須是post
- 推薦使用:post
- void addCookie(Cookie cookie):服務端向客戶端增長cookie對象
- void sendRedirect(String location)throws IOException:頁面跳轉的一種方式
- void setContentType(String type):設置服務端響應的編碼(設置服務端的contentType類型)
- 示例:登陸
- login.jsp登陸->check.jsp判斷->success.jsp
- 請求轉發和重定向的區別:
- 地址欄改變:不變,變
- 是否保留第一次請求時的數據:保留,不保留(跳到success.jsp拿不到數據) --4種範圍對象
- 請求的次數:1次(請求轉發的跳轉是在服務器內部跳轉),2次
- 跳轉發生的位置:服務器端,客戶端
- 轉發、重定向:
- 轉發: 張三(客戶端)->【服務窗口A->服務窗口B】
- 重定向: 張三(客戶端)->【服務窗口A】->張三(客戶端)->【服務窗口B】
- Cookie(存在於客戶端,不是內置對象,得new):
- Cookie是有服務端生成的,再發送給客戶端保存;
- Cookie至關於本地緩存的做用:客戶端->服務端
- 做用:提升訪問服務端的效率,可是安全性較差
- Cookie:name-value
- javax.servlet.http.Cookie類產生的 public Cookie(String name,String value)
- String getName():獲取name
- String getValue():獲取value
- void setMaxAge(int expiry):設置最大有效期(秒)
- 服務端準備Cookie:
- response.addCookie(Cookie cookie)
- 頁面跳轉(轉發,重定向)
- 客戶端獲取Cookie:
- request.getCookies(); //獲取Cookie必須每次都是獲取所有
- 服務端增長cookie:response對象
客戶端獲取對象:request對象- 不能直接獲取單獨對象,只能一次性將所有cookie獲得
除了本身設置的Cookie對象外,還有一個name叫JSESSIONIDDE的cookie- 使用Cookie實現自動記住用戶名 //建議cookie只保存英文數字,不然要編解碼
- 瀏覽網站:開始-關閉
- 購物:瀏覽-付款-退出
- 電子郵件:瀏覽-寫郵件-退出 一次開始到關閉
- 客戶端第一次請求服務端時,(jsessionid-sessionid)服務端會產生一個session對象(用於保存該客戶的信息),而且每一個session對象都會有惟一的sessionId(用於區分其餘session);
- 服務端會產生一個cookie,而且該cookie的name=JSESSIONID,value=服務端sessionId的值;
- 而後,服務端會在響應客戶端的同時,將該cookie發送給客戶端,至此 客戶端就有一個cookie(JSESSIONID)
- 所以,客戶端的cookie就能夠和服務端的session一一對應(JSESSIONID-SESSIONID)
- 客戶端第二次/n次訪問服務端時:服務端會先用客戶端cooki中的JSESSIONID去服務端session中匹配sessionId,若匹配到,則說明不是第一次訪問
- 例子:
- 客戶端:顧客
- 服務端:存包處
顧客第一次存包:商場判斷此人是否是以前已經存過包(是否有鑰匙),若是新顧客(沒鑰匙),分配一個鑰匙;緩存
第二次/n次,若是手裏有鑰匙,直接一一對應,不分配tomcat
- session存儲在服務端
- session是在同一個用戶請求時共享
- session實現機制:第一次客戶請求時產生一個sessionid並複製給jsessionid而後發給客戶端.最終實現sessionid與jsessionid一一對應
- String getId():獲取sessionId
- boolean isNew():判斷是不是新用戶(第一次訪問)
- void invalidate():使session失效(退出登陸、註銷)
- void setAttribute():
- Object getAttribute():
- void setMaxInactiveInterval(秒):設置最大有效非活動時間
- int getMaxInactiveInterval(秒):獲取最大有效非活動時間
- 示例:
- 登陸
- JSESSIONID5B3D4AA49AB91B1311F514BCF727DD29
- sessionId5B3D4AA49AB91B1311F514BCF727DD29
- 客戶端在第一次請求服務端時,若是服務端發現此請求沒有JSESSIONID,則會建立一個name=JSESSIONID的cookie並返回給客戶端
- 不是內置對象,要使用必須new
- 可是,服務端會自動new一個Jsessionid的cookie
- 位置分爲:客戶端和服務端
- 安全爲:不安全和較安全
- 保存的內容:Object和字符串String
- String getContextPath():虛擬路徑
- String getRealPath(String name):絕對路徑(虛擬路徑,相對的的絕對路徑)
- pageContext(也可稱爲page對象):當前頁面有效,頁面跳轉後無效
- request:同一次請求有效,其餘請求無效(請求轉發後有效,重定向後無效)
- session:同一次會話有效(不管怎麼跳轉都有效,只要不關/切換瀏覽器)
- application:全局有效(整個項目有效):整個項目運行期間都有效,切換瀏覽器也有效,關閉服務或者切換項目無效
- Object getAttribute(String name):根據屬性名,獲取屬性值
- void setAttribute(String name,Object obj):設置屬性值(新增,修改)
- setAttribute("a","b");//若是a對象以前不存在,則新建一個a對象; 若是a以前已經存在,則將a的值改成b
- void removeAttribute(String name):根據屬性名,刪除對象 //set賦值,get取值,儘可能使用小範圍,性能損耗小