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 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!