• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    jsp基于XML实现用户登录与注册的实例解析(附源码)

    简单的基于xml做数据库的登录与注册

    主题介绍:

    1.xml的读取和存储,主要是用到dom4j技术,(网络中的文件存储路径采用classLoader)

    文件的读取和存储,写了一个工厂类

    public class DocumentFactory { 
     private static Document dom=null;//需要共享一个dom,所以需要设置为static 
     private static String name="user.xml"; 
     private static String filename; 
    
    
    //写一个静态块实现对dom树的读取 
    static{//dom4j技术 
     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> 
    
    //主要获得和存储的两个函数(采用单例模式)(必须共享一个dom数) 
    
    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("关流失败"+e.getMessage());}}} 
    } 
    

    2.前台的技术:基本上就是界面的搭建和将数据传到后台进行处理。以及部分的必填选项要求。

    两个页面的代码:
    //登录

    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");//设置utf-8的编码格式去接收 
     response.setContentType("text/html;charset=UTF-8");//span style="color:#ff0000;">设置页面显示方式,这个设置必须要在获得输出流之前设置,不然设置都没有用,照样会出现乱码/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/> 
      确认密码 :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;">必须要设置在获得Printwrite之前,都则设置无效/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.所以我们必须在前台要预防一下,当然在这里也要考虑一下 
      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.验证码技术:同样的从后台获取图片,以及登录时候进行匹配
    效果图:

    1,首先是验证验证码的

    2.密码匹配

    3,用户注册

    4.密码正确

     5,查看user.xml文件

    整个登录和注册的源代码下载地址:jsp基于XML实现用户登录与注册的实例解析

    以上就是本文的全部内容,希望对大家的学习有所帮助。

    您可能感兴趣的文章:
    • jsp+dao+bean+servlet(MVC模式)实现简单用户登录和注册页面
    • 使用JSP实现简单的用户登录注册页面示例代码解析
    • jsp实现用户自动登录功能
    • jsp实现简单用户7天内免登录
    • servlet+jsp实现过滤器 防止用户未登录访问
    • JSP Spring防止用户重复登录的实现方法
    • JavaWeb实现用户登录注册功能实例代码(基于Servlet+JSP+JavaBean模式)
    • JSP实现用户登录、注册和退出功能
    • JSP实现简单的用户登录并显示出用户信息的方法
    • 在jsp中用bean和servlet联合实现用户注册、登录
    • 关于JSP用户登录连接数据库详情
    上一篇:servlet+JSP+mysql实现文件上传的方法
    下一篇:JSP针对XML文件操作技巧实例分析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    jsp基于XML实现用户登录与注册的实例解析(附源码) jsp,基于,XML,实现,用户,登录,