簡單的基于xml做數(shù)據(jù)庫的登錄與注冊
主題介紹:
1.xml的讀取和存儲,主要是用到dom4j技術(shù),(網(wǎng)絡(luò)中的文件存儲路徑采用classLoader)
文件的讀取和存儲,寫了一個工廠類
public class DocumentFactory { private static Document dom=null;//需要共享一個dom,所以需要設(shè)置為static private static String name="user.xml"; private static String filename; //寫一個靜態(tài)塊實現(xiàn)對dom樹的讀取 static{//dom4j技術(shù) SAXReader read=new SAXReader(); filename=DocumentFactory.class.getClassLoader().getResource(name).getPath();//采用類加載器進行讀取文件 try { dom=read.read(filename); } catch (DocumentException e) {span style="font-family: Arial, Helvetica, sans-serif;"> e.printStackTrace();}}/span> //主要獲得和存儲的兩個函數(shù)(采用單例模式)(必須共享一個dom數(shù)) public static Document getDocument(){ //獲得xml中的dom樹 return dom; } //注冊之后需要保存 public static void Save() { XMLWriter wr; try { wr = new XMLWriter(new FileOutputStream(filename)); }catch (Exception e1) { throw new RuntimeException("存儲文件時讀文件失敗"); } try { wr.write(dom); } catch (IOException e) { throw new RuntimeException("寫文件失敗"+e.getMessage()); }finally{ try { if(wr!=null){ wr.close(); } } catch (IOException e) { throw new RuntimeException("關(guān)流失敗"+e.getMessage());}}} }
2.前臺的技術(shù):基本上就是界面的搭建和將數(shù)據(jù)傳到后臺進行處理。以及部分的必填選項要求。
兩個頁面的代碼:
//登錄
body> form action='login' method="post"> 用戶名:input type="text" name="name" />br/> 密 碼 :input type="text" name="pwd" />br/> 驗證碼:input type="text" name="checkCode">img src="/LOGIN/immg" id='imgid'>a href="javascript:flush()">看不清/a>//需要重寫一個js進行刷新 br/> input type="submit"value="登錄" /> input type="reset"value="重置" /> a href='jsps/Reg.jsp'>注冊/a> /form>
//登錄后臺的處理
public class Login extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request, response); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf-8");//設(shè)置utf-8的編碼格式去接收 response.setContentType("text/html;charset=UTF-8");//span style="color:#ff0000;">設(shè)置頁面顯示方式,這個設(shè)置必須要在獲得輸出流之前設(shè)置,不然設(shè)置都沒有用,照樣會出現(xiàn)亂碼/span> PrintWriter out = response.getWriter(); out.println("!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">"); out.println("HTML>"); out.println(" HEAD>TITLE>A Servlet/TITLE>"); out.println(" meta http-equiv='content-type' content='text/html; charset=UTF-8'> /HEAD>"); out.println(" BODY>"); String name=request.getParameter("name"); String pwd=request.getParameter("pwd"); String check=request.getParameter("checkCode");//從界面獲得驗證碼輸入的值 ImgDemo id =new ImgDemo(); String str=id.getStr(); if(!check.equals(str)){ out.println("登錄失敗,驗證碼不正確??!");//要是驗證碼不符合,直接返回登錄界面 out.print("a href='index.jsp'>返回登錄/a>"); return; } // System.out.println("11"+check); // System.out.println("22"+str); //登錄前獲得所有的對象 Document dom=DocumentFactory.getDocument(); boolean flag=false; Element root=dom.getRootElement(); IteratorElement> it=root.elementIterator(); while(it.hasNext()){ Element ele =it.next(); String nameC=ele.attributeValue("name"); String pwdC=ele.attributeValue("pwd"); if(name.trim().equals(nameC)pwdC.equals(pwdC)){ flag=true; break; } } if(flag){ out.print("font color='red' size='8px'>恭喜您,登陸成功!/font>"); out.println("a href='index.jsp'>返回登錄/a>"); }else{ out.print("用戶名和密碼不匹配。登錄失敗。。。"); out.println("a href='index.jsp'>返回登錄/a>"); } out.println(" /BODY>"); out.println("/HTML>"); out.flush(); out.close(); } }
//注冊
body> form action='reg' method="post"> 用戶 名:input type="text" name="name" onblur="check()" id="name"/>span id="spanid">/span>br/> 密 碼 : input type="text" name="pwd" id="pwd" onblur="check1()"/>span id="spanid1">/span>br/> 確認(rèn)密碼 :input type="text" name="pwd2" id="pwd2" onblur="check2()"/>span id="spanid2">/span>br/> input type="submit"value="注冊" /> input type="reset"value="重置" /> /form> /body>
//注冊的后臺處理
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=utf-8");//span style="color:#ff0000;">必須要設(shè)置在獲得Printwrite之前,都則設(shè)置無效/span> PrintWriter out = response.getWriter(); out.println("!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">"); out.println("HTML>"); out.println(" HEAD>TITLE>A Servlet/TITLE>/HEAD>"); out.println(" BODY>"); boolean flag=false; request.setCharacterEncoding("utf-8"); String name=request.getParameter("name"); String pwd=request.getParameter("pwd"); Document dom =DocumentFactory.getDocument(); Element root=dom.getRootElement(); IteratorElement> it=root.elementIterator(); while(it.hasNext()){ Element ele=it.next(); String nameR=ele.attributeValue("name");//這里傳過來的值可能是null.所以我們必須在前臺要預(yù)防一下,當(dāng)然在這里也要考慮一下 String pwdR=ele.attributeValue("pwd"); if(name.equals(nameR)pwd.equals(pwdR)){ flag=true; break; } } if(flag){ out.print("此用戶已注冊??!"); out.print("a href='jsps/Reg.jsp'>返回注冊/a>"); }else{ Element ele=root.addElement("user"); ele.addAttribute("name", name); ele.addAttribute("pwd", pwd); DocumentFactory.Save(); out.print("注冊成功??!"); out.print("a href='index.jsp'>返回登錄/a>"); } out.println(" /BODY>"); out.println("/HTML>"); }
3.驗證碼技術(shù):同樣的從后臺獲取圖片,以及登錄時候進行匹配
效果圖:
1,首先是驗證驗證碼的
2.密碼匹配
3,用戶注冊
4.密碼正確
5,查看user.xml文件
整個登錄和注冊的源代碼下載地址:jsp基于XML實現(xiàn)用戶登錄與注冊的實例解析
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。
標(biāo)簽:自貢 山南 吉林 開封 銅川 白銀 烏蘭察布 臨汾
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《jsp基于XML實現(xiàn)用戶登錄與注冊的實例解析(附源碼)》,本文關(guān)鍵詞 jsp,基于,XML,實現(xiàn),用戶,登錄,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。