目錄
1.概念:服務器端會話技術,在一-次會話的多次請求間共享數據,將數據保存在服務器端的對象中。HttpSession
1.概念: ASynchronous JavaScript And XML
概念: JavaScript object Notation
Cookie
1.概念:客戶端會話技術,將數據保存到客戶端
2.快速入門:
- 使用步驟:
- 1.創建Cookie對象, 綁定數據
- new Cookie(String name, string value )
- 2.發送cookie對象
- response . addcookie(Cookie cookie)
- 3.獲取Cookie, 拿到數據
- Cookie[] request . getCookies()
3.實現原理
基於響應頭set- cooki e和請求頭cookie實現
4. cookie的細節
1.一次可不可以發送多個cookie?
- 可以
- 可以創建多個cookie對象,使用response調用多次addcookie方法發送cookie即可。
2. cookie在 瀏覽器中保存多長時間?
- 1.默認情況下,當瀏覽器關閉後,Cookie數據被銷燬
- 2.持久化存儲:
- setMaxAge(int seconds )
- 1.正數:將Cookie數據寫到硬盤的文件中。款化存儲。cooki e存活時間。
- 2.負數:默認值
- 3.零:刪除cookie信息
- setMaxAge(int seconds )
3. cookie能不能存中文?
- 在tomcat 8之前cooki e中不能直接存儲中文數據。
- 需要將中文數據轉碼----般採用URL編碼(%E3)
- 在tomcat 8之後,cookie支持中文數據。
4.,cookie獲取範圍多大?
- 1.假設在一個tomcat服務器中,部署了多個web項目,那麼在這些web項目中cookie能不能共享?
- 默認情況下cookie不能共享
- setPath(String path):設置Eookie的獲取範圍。默認情況下,設置當前的虛擬目錄
- 如果要共享,則可以將path設置爲" /"
- 2.不同的tomcat服務 器間cookie共享問題?
- setDomain(string path): 如果設置-級域名相同, 那麼多個服務器之間cookie可以共享
- setDomain(" .baidu.com" ),那麼tieba.baidu.com和news.baidu.com中cookie可以共享
5. Cookie的特點和作用
1. cookie存儲數據在客戶端瀏覽器
2.瀏覽器對於單個cookie的大小有限制(4kb)以及對同-個域名下的總cookie數量也有限制(20個)
作用:
- 1. cookie一般用於存出少量的不太敏感的數據
- 2.在不登錄的情況下,完成服務器對客戶端的身份識別
例子:
@WebServlet("/servletCookie")
public class ServletCookie extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.創建cookie對象
Cookie cookie = new Cookie("msg","hello#發送了什麼");
//2.發送cookie
response.addCookie(cookie);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request,response);
}
}
@WebServlet("/servletCookie2")
public class ServletCookie2 extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//3.獲取cookie
Cookie[] cookies = request.getCookies();
//獲取數據,遍歷cookie
if(cookies != null){
for(Cookie item : cookies){
String name = item.getName();
String con = item.getValue();
System.out.println(name+":"+con);
}
}
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
}
6.案例:記住上一次訪問時間
1.需求:
- 1.訪問一個Servlet,如果是第一次訪問, 則提示:您好,歡迎您首次訪問。
- 2.如果不是第一次訪問, 則提示:歡迎回來,您上次訪問時間爲:顯示時間字符串
2.分析:
- 1.可以採用cookie來完成
- 2.在服務器中的Servlet判斷是否有一 個名爲lastTime的cookie
- 1.有:不是第一次訪問
- 1.響應數據:歡迎回來,您上次訪問時間爲:2018年6月10日11:50:20
- 2.寫回Cookie : lastTime=2018年6月10日11 :50:01
- 2.沒有:是第一次訪問
- 1.響應數據:您好,歡迎您首次訪問
- 2.寫回Cookie : lastTime=2018年6月10日11:50:01
- 1.有:不是第一次訪問
Servlet代碼:
package cn.cast.cookie;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
@WebServlet("/cookieTest")
public class CookieTest extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//設置響應的消息體的數據格式和編碼
response.setContentType("text/html;charset=utf-8");
//獲取所有cookie
Cookie[] cookies = request.getCookies();
boolean flag = false; //沒有cookie爲last time
//遍歷cookies數組
if(cookies != null && cookies.length > 0){
for(Cookie cookie : cookies){
String name = cookie.getName();
//判斷cookie名稱是否是lasttime
if("lasttime".equals(name)){
flag = true;
//不是第一次訪問,響應數據
//設置cookie的value
//獲取當前時間的字符串,重新設置Cookie的值,重新發送cookie
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat( "yyy年M月dd日HH:mm:ss");
String str_date = sdf.format (date);
cookie. setValue(str_date);
//設置cookie的存活時間
// cookie.setMaxAge(60 * 60 * 24 * 30);//一個月
response.addCookie(cookie);
//獲取cookie數據
String value = cookie.getValue();
response.getWriter().write("<h2>歡迎回來,您上次訪問時間爲:"+value+"</h2>");
//跳出循環
break;
}
}
}
if(cookies == null || cookies.length == 0 || flag == false){
//設置cookie的value
//獲取當前時間的字符串,重新設置Cookie的值,重新發送cookie
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat( "yyy年M月dd日HH:mm:ss");
String str_date = sdf.format (date);
Cookie cookie = new Cookie("lasttime",str_date);
//設置cookie的存活時間
cookie.setMaxAge(60 * 60 * 24 * 30);//一個月
response.addCookie(cookie);
response.getWriter().write("<h2>您好,這是您第一次訪問,您本次訪問時間爲:"+str_date+"</h2>");
}
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
}
效果:
Session
session是依賴於cookie的
1.概念:服務器端會話技術,在一-次會話的多次請求間共享數據,將數據保存在服務器端的對象中。HttpSession
2.快速入門:
- 1.獲取HttpSession對象: .
- HttpSession session = request.getsession();
- 2.使用HttpSession對象:
- object getAttribute(String name )
- void setAttribute(String name, object value)
- void removeAttribute(String name )
3.原理
- Session的實現是依賴於cookie的。
4.細節:
1.當客戶端關閉後,服務器不關閉,兩次獲取session是否爲同一個?
- 默認情況下:不是。
- 如果需要相同,則可以創建Cookie,鍵爲JSESSIONID,設置最大存活時間,讓cookie持久化保存。
-
Cookie c = new Cookie("JSESSIONID" , session.getId()); c.setMaxAge(60*60); response.addCookie(c);
-
2.客戶端不關閉,服務器關閉後,兩次獲取的session是同- -個嗎?
- 不是同一個,但是要確保數據不丟失
- session的鈍化:
- 在服務器正常關閉之前,將session對象系列化到硬盤上
- session的活化:
- 在服務器啓動後,將session文件轉化爲內存中的session對象即可。
3. session什麼時候被銷燬?
- 1.服務器關閉
- 2. session對象調用invalidate() 。
- 3. session默認失效時間30分鐘
- 選擇性配置修改:tomcat目錄下conf/web.xml
- <session-config>
- <session-timeout>30</ session- timeout>
- </session-config>
- 選擇性配置修改:tomcat目錄下conf/web.xml
5. session的特點
1. session用於存儲一次會話的多次請求的數據,存在服務器端
2. session可以存儲任意類型,任意大小的數據
session與cookie的區別: .
- 1. session存 儲數據在服務器端,cookie在客戶端
- 2. session沒有數據大小限制,cookie有
- 3. session數據安全, cookie相對於不安全
@WebServlet("/Sessiondemo")
public class Sessiondemo extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.獲取session
HttpSession session = request.getSession();
System. out . println(session);
//期望客戶端關閉後,session也能相同
Cookie c = new Cookie("JSESSIONID" , session.getId());
c.setMaxAge(60*60);
response.addCookie(c);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
}
AJAX
1.概念: ASynchronous JavaScript And XML
異步的JavaScript和XML
- 1.異步和同步:客戶端和服務器端相互通信的基礎上
- 客戶端必須等待服務器端的響應。在等待的期間客戶端不能做其他操作。
- 客戶端不需要等待服務器端的響應。在服務器處理請求的過程中,客戶端可以進行其他的操作。
Ajax是一種在無需重新加載整個網頁的情況下,能夠更新部分網頁的技術。
- 通過在後臺與服務器進行少量數據交換, Ajax 可以使網頁實現異步更新。這意味着可以在不重新加載整個網頁的情況下,對網頁的某部分進行更新。
- 傳統的網頁(不使用Ajax) 如果需要更新內容,必須重載整個網頁頁面。
提升用戶的體驗
2.實現方式
1.原生的JS實現方式(瞭解)
function loadXMLDoc()
{
var xmlhttp;
if (window.XMLHttpRequest)
{
// IE7+, Firefox, Chrome, Opera, Safari 瀏覽器執行代碼
xmlhttp=new XMLHttpRequest();
}
else
{
// IE6, IE5 瀏覽器執行代碼
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
//true異步請求,false同步請求
xmlhttp.open("GET","ajaxServlet?name=t854",true);
xmlhttp.send();
//接收並處理來自服務器的響應結果
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
//獲取響應
var responseText = xmlhttp.responseText;
console.log(responseText)
// document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
}
}
}
@WebServlet("/ajaxServlet")
public class AjaxServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
ArrayList<String> list= new ArrayList<String>();
list.add("aaa");
list.add("bbb");
list.add("ccc");
//獲取請求參數
String name = request.getParameter("name");
//打印name
System.out.println(name+"**");
//響應
// response.getWriter().write("hello :" + name);
response.getWriter().write("hello :" + list);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request,response);
}
}
2. JQeury實現方式
- 1. $.ajax()
- 語法:$.ajax(url,[settings])
-
<button type="button" οnclick="fun()">發送異步請求</button> <script src="js/jquery-3.2.1.min.js"></script> <script> function fun(){ $.ajax({ url:"/ajaxServlet", //請求路徑 type:"GET", //請求方式 data:{"name":"tom","age":23}, //請求參數 success: function(data){ //響應成功後執行的回調函數 //data是服務器響應發送的數據 console.log(data) } }) } </script>
- 2. $.get()
- 語法: $.get(url,[data], [callback], [type])
- 參數:
- url :請求路徑
- data:請求參數
- callback :回調函數
- type :響應結果的類型
- 3. $. post()
JSON
概念: JavaScript object Notation
JavaScript對象表示法
- Person p = new Person();
- p. setName("張三");
- p. setAge(23);
- p. setGender("男");
- var p = {"name":"張三”," age" :23,' 'gender":"男" };
JSON是存儲和交換文本信息的語法。類似XML。
JSON比XML更小、更快,更易解析。
JSON語法
- 數據使用名/值對錶示。
- 使用大括號保存對象,每個名稱後面跟着一個 ':'(冒號),名/值對使用 ,(逗號)分割。
- 使用方括號保存數組,數組值使用 ,(逗號)分割。
鍵用引號(單雙都行)引起來,也可以不使用引號
值得取值類型:
- 1.數字(整數或浮點數)
- 2.字符串(在雙引號中)
- 3.邏輯值(true 或false)
- 4.數組(在方括號中) {"persons":[{},{}]}
- 5.對象(在花括號中) {" address":{"province" : "陝西"....}}
- 6. null
{
"book": [
{
"id":"01",
"language": "Java",
"edition": "third",
"author": "Herbert Schildt"
},
{
"id":"07",
"language": "C++",
"edition": "second"
"author": "E.Balagurusamy"
}]
}
獲取數據
1. json對象.鍵名
2. json對象[ "鍵名"]
3.數組對象[索引]
JSON數據與Java對象互相轉換
JSON解析器
- Jsonlib
- Gson
- fastjson
- jackson
Java對象轉json字符串
- 導入jackson的相關jar包
- 創建Jackson核心對象objectMapper
- 調用objectMapper的相關方法進行轉換
JSON字符串轉爲Java對象
- 1.導入jackson的相關jar包
- 2.創建Jackson核心對象objectMapper
- 3.調用objectMapper的相關方法進行轉換
- readValue(json字符串數據,Class)
註解:
1. @JsonIgnore :排除屬性。
2. @JsonFormat :屬性值得格式化
需要的Jackson包
下載jar地址:https://mvnrepository.com/artifact/com.fasterxml.jackson.core
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.junit.Test;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
public class JacksonTest {
//java對象轉爲json字符串
@Test
public void test1() throws IOException {
//1.創建person對象
Pserson s1 = new Pserson("曹操",25,true);
Pserson s2 = new Pserson("劉備",35,true);
Pserson s3 = new Pserson("孫權",21,true);
ArrayList<Pserson> list = new ArrayList<>();
list.add(s1);
list.add(s2);
list.add(s3);
//2.創建jackson核心對象 ObjectMapper
ObjectMapper mapper = new ObjectMapper();
//3.轉換
/*
轉換方法:
writeValue
writeValueAsString(obj) :將對象轉爲json字符串
* */
String json1 = mapper.writeValueAsString(list);
System.out.println(json1);
//writeValue,將數據寫到d://a. txt文件中
// mapper.writeValue(new File("d://a.txt"),json1);
}
}
輸出結果爲json形式的字符串
一起學習,一起進步 -.- ,如有錯誤,可以發評論