JavaWeb會話技術詳解與案例
1.什麼是會話:
2.會話技術有哪些:
什麼是Cookie?
Cookie,有時也用其復數形式 Cookies。類型為“小型文本文件”,是某些網站為瞭辨別用戶身份,進行Session跟蹤而儲存在用戶本地終端上的數據(通常經過加密),由用戶客戶端計算機暫時或永久保存的信息。
3.cookie學習案例:
cookie:是數組,中每個元素有:名稱和值,
可以通過名稱找到名稱對應的元素。
重要:
Cookie[] cookies = req.getCookies(); //創建cookie對象,獲得瀏覽器所有的cookie數組 Cookie cookie = CookieUtils.findCookie(cookies,"lasttime");//通過:cookies:一個名稱“lasttime”,找到數組裡面對應的cookies,返回這個cookie:值
String value = cookie.getValue();
resp.getWriter().println(value);
//value:獲取cookie(這個)的值,
打印在瀏覽器上面
Cookie c = new Cookie("lasttime", wer); //創建一個cookie, 名稱為:lasttime,值為:wer變量對應的值 resp.addCookie(c); //在瀏覽器添加:增加這個名稱的cookie值, 可以
創建:HelloServlet4 extends HttpServlet
這個類
package com.example.demo16; import javax.servlet.ServletException; 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.net.URLEncoder; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; public class HelloServlet4 extends HttpServlet { @Override public void init() throws ServletException { super.init(); this.getServletContext().setAttribute("name","張三"); } @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //super.doGet(req, resp); Cookie[] cookies = req.getCookies(); Cookie cookie = CookieUtils.findCookie(cookies,"lasttime"); System.out.println(cookie); if (cookie==null) { resp.setCharacterEncoding("utf-8"); resp.setContentType("text/html;charset=UTF-8"); resp.getWriter().println("<h1>您好,歡迎來到本網站!</h1>"); } else { resp.setCharacterEncoding("utf-8"); resp.setContentType("text/htm/UTF-8"); resp.getWriter().println("你上一次訪問時間是:"); //出現瞭中文錯誤 cookie = CookieUtils.findCookie(cookies, "lasttime"); String value = cookie.getValue(); resp.getWriter().println(value); Date d = new Date(); //變化的 SimpleDateFormat sc=new SimpleDateFormat("yyyy-MM-dd-HH:mm:ss"); String wer=sc.format(d); //字符串 System.out.println(wer); //其實就是要設置:時間,時間值為java, 變化的時間 // Cookie c = new Cookie("lasttime","11111"); 這個可以顯示 // Cookie c = new Cookie("lasttime","1-1-1-1-1"); // Cookie c = new Cookie("lasttime","2021-11-14");//2021-11-14 20:14不能反映,中文也不能 // Cookie c = new Cookie("lasttime","2021:11:14");// 空格不行 Cookie c = new Cookie("lasttime", wer); resp.addCookie(c); } /*resp.getWriter().println("helloworld"); resp.setStatus(302); //resp.setHeader("Location","/demo16_war/helloo"); resp.setHeader("Refresh","5,url=/demo16_war/helloo"); */ // String name= (String) this.getServletContext().getAttribute("name"); // System.out.println(name); //text(); text(); } protected void text() throws IOException { //Properties properties=new Properties();//創建文件對象 //InputStream is=this.getServletContext().getResourceAsStream("WEB-INF/dp.properties");//這裡的路徑, // properties.load(is); //String driverClassName=properties.getProperty("driverClassName"); // String url=properties.getProperty("url"); //String password=properties.getProperty("password"); // String usernane=properties.getProperty("username"); // System.out.println(driverClassName); //System.out.println(url); //System.out.println(password); //System.out.println(usernane); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); try { Date d = sdf.parse(toString()); System.out.println(d); } catch (ParseException e) { e.printStackTrace(); } } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doPost(req, resp); } }
創建CookieUtils類:
package com.example.demo16; import javax.servlet.http.Cookie; public class CookieUtils { public static Cookie findCookie(Cookie[] cookies, String name){ if(cookies==null){ return null; }else { for(Cookie cookie:cookies){ if(name.equals(cookie.getName())) { //找到相等的name名稱 return cookie; } } return null; }}}
效果圖:
點擊刷新頁面:
4. 使用cookie註意出現的問題:
Cookie c = new Cookie(“lasttime”,“2021 11 14”);
// 空格不行,
返回:亂碼
如果:cookievalue值為:中文,就要設置:
resp.setCharacterEncoding(“utf-8”);
響應設置為:utf-8,解決中文亂碼
下面:
String werr="我是誰"; Cookie c = new Cookie("lasttime", werr); resp.addCookie(c);
還有:
可以在 resp.getWriter().println
:放html標簽
需要
resp.setContentType(“text/html;charset=UTF-8”);
//來解析
resp.setContentType("text/html;charset=UTF-8"); resp.getWriter().println("<h1>你上一次訪問時間是:</h1>");
到此這篇關於JavaWeb會話技術詳解與案例的文章就介紹到這瞭,更多相關JavaWeb 會話技術內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Cookie的工作原理和應用詳解
- 淺談Servlet的Cookie和Session機制
- JavaWeb之會話技術案例詳解
- JavaWeb詳細講述Cookie和Session的概念
- 手工搭建Servlet實現