JSP實現數據保存
1、概述
 
 
2、使用session保存用戶名
 
 
session工作方式:
 
 
會話的清除與過期:
 
 
createUser.jsp:
<%<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <form id="" action="doCreateUser.jsp" method="post">
  用戶名:<input type="text" name="userName"/>
  <input type="submit" value="提交"/>
 </form>
 <%
  // 取回提示信息
  Object oMess = request.getAttribute("mess");
  if (oMess != null) {
   out.print(oMess.toString());
  }
 %>
</body>
</html> doCreateUser.jsp
 <%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <%
  request.setCharacterEncoding("UTF-8");
  String userName = request.getParameter("userName");
  //out.print(userName);
  
  if (userName.equals("admin")) {
   // 加入提示信息
   request.setAttribute("mess","注冊失敗,更換用戶名。");
   request.getRequestDispatcher("createUser.jsp").forward(request, response);
   //response.sendRedirect("createUser.jsp");
  } else {
   session.setAttribute("user",userName);
   //request.getRequestDispatcher("default.jsp").forward(request, response);
   response.sendRedirect("default.jsp");
  }
 %>
</body>
</html> default.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <%-- <%=(request.getAttribute("mess")).toString() %> --%>
 <% 
  Object o = session.getAttribute("user");
  if (o == null) {
 %>
  <form id="" action="doCreateUser.jsp" method="post">
  用戶名:<input type="text" name="userName"/>
  <input type="submit" value="提交"/>
 </form>
 <% 
  } else {
   out.print("歡迎你," + o.toString());
 %>
  <a href="doLoginOut.jsp">注銷</a>
 <%
  }
 %>
</body>
</html> doLoginOut.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <%
  session.removeAttribute("user");// 釋放session
  //session.invalidate();
  response.sendRedirect("default.jsp");
 %>
</body>
</html> 3、使用cookie自動填寫用戶名
 
 
doCreateUser.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <%
  request.setCharacterEncoding("UTF-8");
  String userName = request.getParameter("userName");
  //out.print(userName);
  
  if (userName.equals("admin")) {
   // 加入提示信息
   request.setAttribute("mess","注冊失敗,更換用戶名。");
   request.getRequestDispatcher("createUser.jsp").forward(request, response);
   //response.sendRedirect("createUser.jsp");
  } else {
   // 創建cookie
   Cookie cookie = new Cookie("user",userName);
   // 設置cookie的有效期,單位秒
   cookie.setMaxAge(10);
   response.addCookie(cookie);
   
   session.setAttribute("user",userName);
   //request.getRequestDispatcher("default.jsp").forward(request, response);
   response.sendRedirect("default.jsp");
  }
 %>
</body>
</html> default.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <%-- <%=(request.getAttribute("mess")).toString() %> --%>
 <% 
  // 獲取cookie
  Cookie[] cookies = request.getCookies();
  String user = "";
  for (int i = 0 ; i < cookies.length ; i++) {
   if (cookies[i].getName().equals("user")) {
    user = cookies[i].getValue();
   } 
  }
 
  Object o = session.getAttribute("user");
  if (o == null) {
 %>
  <form id="" action="doCreateUser.jsp" method="post">
  用戶名:<input type="text" name="userName" value="<%=user%>"/>
  <input type="submit" value="提交"/>
 </form>
 <% 
  } else {
   out.print("歡迎你," + o.toString());
 %>
  <a href="doLoginOut.jsp">注銷</a>
 <%
  }
 %>
</body>
</html> 查看cookie文件:
 
 
 
 
cookie文件中的內容:
user
qwe
localhost/news/jsp/
1024
1578087680
30438420
1482467680
30438420
*
4、application實現計數器 
 
 
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
 <%-- <%=(request.getAttribute("mess")).toString() %> --%>
 <% 
  // 獲取cookie
  Cookie[] cookies = request.getCookies();
  String user = "";
  for (int i = 0 ; i < cookies.length ; i++) {
   if (cookies[i].getName().equals("user")) {
    user = cookies[i].getValue();
   } 
  }
 
  Object o = session.getAttribute("user");
  if (o == null) {
 %>
  <form id="" action="doCreateUser.jsp" method="post">
  用戶名:<input type="text" name="userName" value="<%=user%>"/>
  <input type="submit" value="提交"/>
 </form>
 <% 
  } else {
   out.print("歡迎你," + o.toString());
 %>
  <a href="doLoginOut.jsp">注銷</a>
 <%
  }
 %>
 <%
  Object count = application.getAttribute("count");
  if (count == null) {
   // 第一次訪問
   application.setAttribute("count", new Integer(1));
  } else {
   Integer i = (Integer)count;
   // 每一次訪問+1
   application.setAttribute("count", i.intValue() + 1);
  }
  Integer icount = (Integer)application.getAttribute("count");
  out.print("頁面被訪問了" + icount.intValue() + "次");
 %>
</body>
</html> 5、三個對象的對比
 
 
 
 
 
 
6、jsp頁面的組成部分
 
 
7、常用內置對象
 
 
8、數據保存
 
 
9、客戶端請求新頁面
 
 
 
 
 
 
 
 
注:修改onclick="return fun();"
 
 
 
 
 
 
  
 
10、處理中文亂碼
 
 
 
 
 
 

來自:http://my.oschina.net/u/2320342/blog/398660 
 本文由用戶 xg48 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
                         轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
                         本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!