侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

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

Java  /  管理员 发布于 7年前   208

简单的基于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="https:LOGIN/immg" id='imgid'><a href="">看不清</a>//需要重写一个js进行刷新   <br/>   <input type="submit"value="登录" />   <input type="reset"value="重置" />   <a href='https:/article/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='https:/article/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();  Iterator<Element> 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='https:/article/index.jsp'>返回登录</a>");  }else{   out.print("用户名和密码不匹配。登录失败。。。");   out.println("<a href='https:/article/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();  Iterator<Element> 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='https:/article/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='https:/article/index.jsp'>返回登录</a>");  }  out.println(" </BODY>");  out.println("</HTML>"); } 

3.验证码技术:同样的从后台获取图片,以及登录时候进行匹配
效果图:

1,首先是验证验证码的

2.密码匹配

3,用户注册

4.密码正确

 5,查看user.xml文件

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

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


  • 上一条:
    JSP针对XML文件操作技巧实例分析
    下一条:
    jsp实现防盗链的方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在java中实现的脱敏工具类代码示例分享(0个评论)
    • zookeeper安装流程步骤(0个评论)
    • 在java中你背的“八股文”可能已经过时了(2个评论)
    • 在php8.0+版本中使用属性来增加值代码示例(3个评论)
    • java 正则表达式基础,实例学习资料收集大全 原创(0个评论)
    • 近期文章
    • 在go语言中实现字符串可逆性压缩及解压缩功能(0个评论)
    • 使用go + gin + jwt + qrcode实现网站生成登录二维码在app中扫码登录功能(0个评论)
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-11
    • 2018-03
    • 2020-03
    • 2023-05
    • 2023-11
    • 2024-01
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客