JSP的Cookie在登錄中的使用
jsp的cookie在登錄中的使用
一 功能需求
實現(xiàn)記憶用戶名和密碼功能。
二 代碼
1、login.jsp
<%@ page language="java" import="java.util.*,java.net.*" contenttype="text/html; charset=utf-8"%> <% string path = request.getcontextpath(); string basepath = request.getscheme()+"://"+request.getservername()+":"+request.getserverport()+path+"/"; %> <!doctype html public "-//w3c//dtd html 4.01 transitional//en"> <html> <head> <base href="<%=basepath%>" rel="external nofollow" rel="external nofollow" rel="external nofollow" > <title>my jsp 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css" rel="external nofollow" rel="external nofollow" rel="external nofollow" > --> </head> <body> <h1>用戶登錄</h1> <hr> <% request.setcharacterencoding("utf-8"); string username=""; string password = ""; cookie[] cookies = request.getcookies(); if(cookies!=null&&cookies.length>0) { for(cookie c:cookies) { if(c.getname().equals("username")) { username = urldecoder.decode(c.getvalue(),"utf-8"); } if(c.getname().equals("password")) { password = urldecoder.decode(c.getvalue(),"utf-8"); } } } %> <form name="loginform" action="dologin.jsp" method="post"> <table> <tr> <td>用戶名:</td> <td><input type="text" name="username" value="<%=username %>"/></td> </tr> <tr> <td>密碼:</td> <td><input type="password" name="password" value="<%=password %>" /></td> </tr> <tr> <td colspan="2"><input type="checkbox" name="isusecookie" checked="checked"/>十天內(nèi)記住我的登錄狀態(tài)</td> </tr> <tr> <td colspan="2" align="center"><input type="submit" value="登錄"/><input type="reset" value="取消"/></td> </tr> </table> </form> </body> </html>
2、dologin.jsp
<%@ page language="java" import="java.util.*,java.net.*" contenttype="text/html; charset=utf-8"%> <% string path = request.getcontextpath(); string basepath = request.getscheme()+"://"+request.getservername()+":"+request.getserverport()+path+"/"; %> <!doctype html public "-//w3c//dtd html 4.01 transitional//en"> <html> <head> <base href="<%=basepath%>" rel="external nofollow" rel="external nofollow" rel="external nofollow" > <title>my jsp 'dologin.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css" rel="external nofollow" rel="external nofollow" rel="external nofollow" > --> </head> <body> <h1>登錄成功</h1> <hr> <br> <br> <br> <% request.setcharacterencoding("utf-8"); //首先判斷用戶是否選擇了記住登錄狀態(tài) string[] isusecookies = request.getparametervalues("isusecookie"); if(isusecookies!=null&&isusecookies.length>0) { //把用戶名和密碼保存在cookie對象里面 string username = urlencoder.encode(request.getparameter("username"),"utf-8"); //使用urlencoder解決無法在cookie當中保存中文字符串問題 string password = urlencoder.encode(request.getparameter("password"),"utf-8"); cookie usernamecookie = new cookie("username",username); cookie passwordcookie = new cookie("password",password); usernamecookie.setmaxage(864000); passwordcookie.setmaxage(864000);//設置最大生存期限為10天 response.addcookie(usernamecookie); response.addcookie(passwordcookie); } else { cookie[] cookies = request.getcookies(); if(cookies!=null&&cookies.length>0) { for(cookie c:cookies) { if(c.getname().equals("username")||c.getname().equals("password")) { c.setmaxage(0); //設置cookie失效 response.addcookie(c); //重新保存。 } } } } %> <a href="users.jsp" rel="external nofollow" target="_blank">查看用戶信息</a> </body> </html>
3、users.jsp
<%@ page language="java" import="java.util.*,java.net.*" contenttype="text/html; charset=utf-8"%> <% string path = request.getcontextpath(); string basepath = request.getscheme()+"://"+request.getservername()+":"+request.getserverport()+path+"/"; %> <!doctype html public "-//w3c//dtd html 4.01 transitional//en"> <html> <head> <base href="<%=basepath%>" rel="external nofollow" rel="external nofollow" rel="external nofollow" > <title>my jsp 'users.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css" rel="external nofollow" rel="external nofollow" rel="external nofollow" > --> </head> <body> <h1>用戶信息</h1> <hr> <% request.setcharacterencoding("utf-8"); string username=""; string password = ""; cookie[] cookies = request.getcookies(); if(cookies!=null&&cookies.length>0) { for(cookie c:cookies) { if(c.getname().equals("username")) { username = urldecoder.decode(c.getvalue(),"utf-8"); } if(c.getname().equals("password")) { password = urldecoder.decode(c.getvalue(),"utf-8"); } } } %> <br> <br> <br> 用戶名:<%=username %><br> 密碼:<%=password %><br> </body> </html>
三 測試
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
- jsp+servlet實現(xiàn)文件上傳與下載功能
- EJB3.0部署消息驅(qū)動Bean拋javax.naming.NameNotFoundException異常
- 在JSP中使用formatNumber控制要顯示的小數(shù)位數(shù)方法
- 秒殺系統(tǒng)Web層設計的實現(xiàn)方法
- 將properties文件的配置設置為整個Web應用的全局變量實現(xiàn)方法
- JSP使用過濾器防止Xss漏洞
- 在JSP頁面中動態(tài)生成圖片驗證碼的方法實例
- 詳解JSP 內(nèi)置對象request常見用法
- 使用IDEA編寫jsp時EL表達式不起作用的問題及解決方法
- jsp實現(xiàn)局部刷新頁面、異步加載頁面的方法
- Jsp中request的3個基礎實踐
- JavaServlet的文件上傳和下載實現(xiàn)方法
- JSP頁面的靜態(tài)包含和動態(tài)包含使用方法