简单的基于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="/UploadFiles/2021-04-02/immg">//登录后台的处理
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,XML,用户登录,注册
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]










