Java基礎(十二)——Cookie、Session、AJAX、JSON

目錄

1.概念:客戶端會話技術,將數據保存到客戶端

2.快速入門:

3.實現原理

4. cookie的細節

5. Cookie的特點和作用

例子:

6.案例:記住上一次訪問時間

Session

1.概念:服務器端會話技術,在一-次會話的多次請求間共享數據,將數據保存在服務器端的對象中。HttpSession

2.快速入門:

3.原理

4.細節:

5. session的特點

AJAX 

1.概念: ASynchronous JavaScript And XML

2.實現方式

JSON

概念: JavaScript object Notation

JSON語法

獲取數據

JSON數據與Java對象互相轉換


 

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信息

3. cookie能不能存中文?

  1. 在tomcat 8之前cooki e中不能直接存儲中文數據。
  2. 需要將中文數據轉碼----般採用URL編碼(%E3)
  3. 在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

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>

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解析器

  1. Jsonlib
  2. Gson
  3. fastjson
  4. jackson

Java對象轉json字符串

  1. 導入jackson的相關jar包
  2. 創建Jackson核心對象objectMapper
  3. 調用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形式的字符串 

 

 

一起學習,一起進步 -.- ,如有錯誤,可以發評論

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章