佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > jsp基于XML實(shí)現(xiàn)用戶登錄與注冊(cè)的實(shí)例解析(附源碼)

jsp基于XML實(shí)現(xiàn)用戶登錄與注冊(cè)的實(shí)例解析(附源碼)

熱門標(biāo)簽:服務(wù)器配置 Mysql連接數(shù)設(shè)置 科大訊飛語音識(shí)別系統(tǒng) 銀行業(yè)務(wù) 團(tuán)購網(wǎng)站 Linux服務(wù)器 阿里云 電子圍欄

簡單的基于xml做數(shù)據(jù)庫的登錄與注冊(cè)

主題介紹:

1.xml的讀取和存儲(chǔ),主要是用到dom4j技術(shù),(網(wǎng)絡(luò)中的文件存儲(chǔ)路徑采用classLoader)

文件的讀取和存儲(chǔ),寫了一個(gè)工廠類

public class DocumentFactory { 
 private static Document dom=null;//需要共享一個(gè)dom,所以需要設(shè)置為static 
 private static String name="user.xml"; 
 private static String filename; 


//寫一個(gè)靜態(tài)塊實(shí)現(xiàn)對(duì)dom樹的讀取 
static{//dom4j技術(shù) 
 SAXReader read=new SAXReader(); 
 filename=DocumentFactory.class.getClassLoader().getResource(name).getPath();//采用類加載器進(jìn)行讀取文件 
  try { 
  dom=read.read(filename); 
  } catch (DocumentException e) {span style="font-family: Arial, Helvetica, sans-serif;">  e.printStackTrace();}}/span> 

//主要獲得和存儲(chǔ)的兩個(gè)函數(shù)(采用單例模式)(必須共享一個(gè)dom數(shù)) 

public static Document getDocument(){ //獲得xml中的dom樹 
 return dom; 
} 

//注冊(cè)之后需要保存 
 public static void Save() { 
 XMLWriter wr; 
 try { 
  wr = new XMLWriter(new FileOutputStream(filename)); 
 }catch (Exception e1) { 
  throw new RuntimeException("存儲(chǔ)文件時(shí)讀文件失敗"); 
 } 
 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.前臺(tái)的技術(shù):基本上就是界面的搭建和將數(shù)據(jù)傳到后臺(tái)進(jìn)行處理。以及部分的必填選項(xiàng)要求。

兩個(gè)頁面的代碼:
//登錄

body> 
  form action='login' method="post"> 
  用戶名:input type="text" name="name" />br/> 
  密 碼 :input type="text" name="pwd" />br/> 
  驗(yàn)證碼:input type="text" name="checkCode">img src="/LOGIN/immg" id='imgid'>a href="javascript:flush()">看不清/a>//需要重寫一個(gè)js進(jìn)行刷新 
  br/> 
  input type="submit"value="登錄" /> 
  input type="reset"value="重置" /> 
  a href='jsps/Reg.jsp'>注冊(cè)/a> 
  
 /form> 

//登錄后臺(tái)的處理

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è)置頁面顯示方式,這個(gè)設(shè)置必須要在獲得輸出流之前設(shè)置,不然設(shè)置都沒有用,照樣會(huì)出現(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");//從界面獲得驗(yàn)證碼輸入的值 
 ImgDemo id =new ImgDemo(); 
 String str=id.getStr(); 
 if(!check.equals(str)){ 
  out.println("登錄失敗,驗(yàn)證碼不正確?。?);//要是驗(yàn)證碼不符合,直接返回登錄界面 
  out.print("a href='index.jsp'>返回登錄/a>"); 
  return; 
 } 
// System.out.println("11"+check); 
// System.out.println("22"+str); 
  
 //登錄前獲得所有的對(duì)象 
 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(); 
 } 
 
} 

//注冊(cè)

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="注冊(cè)" /> 
  input type="reset"value="重置" /> 
  
 /form> 
 /body> 

//注冊(cè)的后臺(tái)處理

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.所以我們必須在前臺(tái)要預(yù)防一下,當(dāng)然在這里也要考慮一下 
  String pwdR=ele.attributeValue("pwd"); 
  if(name.equals(nameR)pwd.equals(pwdR)){ 
  flag=true; 
  break; 
  } 
 } 
 if(flag){ 
  out.print("此用戶已注冊(cè)?。?); 
  out.print("a href='jsps/Reg.jsp'>返回注冊(cè)/a>"); 
 }else{ 
  Element ele=root.addElement("user"); 
  ele.addAttribute("name", name); 
  ele.addAttribute("pwd", pwd); 
  DocumentFactory.Save(); 
  out.print("注冊(cè)成功?。?); 
  out.print("a href='index.jsp'>返回登錄/a>"); 
 } 
 out.println(" /BODY>"); 
 out.println("/HTML>"); 
} 

3.驗(yàn)證碼技術(shù):同樣的從后臺(tái)獲取圖片,以及登錄時(shí)候進(jìn)行匹配
效果圖:

1,首先是驗(yàn)證驗(yàn)證碼的

2.密碼匹配

3,用戶注冊(cè)

4.密碼正確

 5,查看user.xml文件

整個(gè)登錄和注冊(cè)的源代碼下載地址:jsp基于XML實(shí)現(xiàn)用戶登錄與注冊(cè)的實(shí)例解析

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

您可能感興趣的文章:
  • jsp+dao+bean+servlet(MVC模式)實(shí)現(xiàn)簡單用戶登錄和注冊(cè)頁面
  • 使用JSP實(shí)現(xiàn)簡單的用戶登錄注冊(cè)頁面示例代碼解析
  • jsp實(shí)現(xiàn)用戶自動(dòng)登錄功能
  • jsp實(shí)現(xiàn)簡單用戶7天內(nèi)免登錄
  • servlet+jsp實(shí)現(xiàn)過濾器 防止用戶未登錄訪問
  • JSP Spring防止用戶重復(fù)登錄的實(shí)現(xiàn)方法
  • JavaWeb實(shí)現(xiàn)用戶登錄注冊(cè)功能實(shí)例代碼(基于Servlet+JSP+JavaBean模式)
  • JSP實(shí)現(xiàn)用戶登錄、注冊(cè)和退出功能
  • JSP實(shí)現(xiàn)簡單的用戶登錄并顯示出用戶信息的方法
  • 在jsp中用bean和servlet聯(lián)合實(shí)現(xiàn)用戶注冊(cè)、登錄
  • 關(guān)于JSP用戶登錄連接數(shù)據(jù)庫詳情

標(biāo)簽:大理 江蘇 廣元 萍鄉(xiāng) 棗莊 衡水 衢州 蚌埠

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《jsp基于XML實(shí)現(xiàn)用戶登錄與注冊(cè)的實(shí)例解析(附源碼)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    顺平县| 原阳县| 连南| 突泉县| 宣化县| 元江| 理塘县| 宜章县| 锡林郭勒盟| 胶南市| 准格尔旗| 南木林县| 湛江市| 徐州市| 吉水县| 江孜县| 抚顺县| 肥西县| 莱州市| 天柱县| 博乐市| 巴里| 探索| 任丘市| 乌兰察布市| 安陆市| 盘锦市| 大宁县| 新乐市| 朝阳区| 白河县| 安丘市| 合作市| 北碚区| 武强县| 扶沟县| 云林县| 乌拉特后旗| 平邑县| 高州市| 永顺县|