jsp基于XML实现用户登录与注册的实例解析(附源码)
程序员文章站
2022-05-18 12:37:33
简单的基于xml做数据库的登录与注册
主题介绍:
1.xml的读取和存储,主要是用到dom4j技术,(网络中的文件存储路径采用classloader)
文件的读取和存...
简单的基于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(); 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='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(); 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='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基于JDBC的数据库连接类实例