定义:

  XML(eXtended Markup Language,可扩展标记语言)提供了一套跨平台、跨网络、跨程序的语言的数据描述方式,使用XML可以方便地实现数据交换、系统配置、内容管理等常见功能。

XML解析:

  在XML文件中由于更多的是描述信息的内容,所以在得到一个XML文档后应该利用程序按照其中元素的定义名称取出相应的内容,这样的操作就称为XML解析。XML解析有两种方式,SAX和DOM解析方式。

  1)DOM解析与用户登录

  登录表单(login.jsp):

 <%@page contentType="text/html;charset=gb2312"%>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>登录</title></head>
<body>
<form action="login_xml.jsp" method="post">
用户名:<input type="text" name="name">
密&nbsp;码:<input type="password" name="password">
<select name="type">
<option value="student" selected="selected">学生登录</option>
<option value="teacher">教师登录</option>
<option value="admin">管理员登录</option>
</select>
<select name="database">
<option value="oracle" selected="selected">oracle数据库</option>
<option value="sqlserver">sqlserver数据库</option>
<option value="dom">通过xml文件验证</option>
</select>
<input type="submit" value="登录" />
<input type="reset" value="清除">
</form>
</body>
</html>

  XML文件(student_login.xml):

 <?xml version="1.0" encoding="UTF-8"?>
<user>
<student>
<name>王定</name>
<password>123</password>
</student>
<teacher>
<name>黄艳娟</name>
<password>111</password>
</teacher>
<admin>
<name>奥巴马</name>
<password>588</password>
</admin>
</user>

  登录验证(login_xml.jsp):

 <%@ page language="java" contentType="text/html; charset=gb2312"
pageEncoding="gb2312"%>
<%@page import="java.io.*,org.w3c.dom.*,javax.xml.parsers.*" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>登录验证</title>
</head>
<body>
<%
String name=request.getParameter("name");
name=new String(name.getBytes("ISO-8859-1"), "gb2312"); //处理乱码
String password=request.getParameter("password");
String user=request.getParameter("type");
String database=request.getParameter("database"); //获得数据库类型信息
boolean login_tag=false; System.out.println(name);
System.out.println(password);
System.out.println(user);
System.out.println(database); // 取得DocumentBuilderFactory类的对象
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance() ;
// 取得DocumentBuilder类的对象
DocumentBuilder build = factory.newDocumentBuilder() ;
Document doc = build.parse(new File("E:" + File.separator + "eclipse" + File.separator+"wd_eclipse"+
File.separator+"webconfig"+File.separator+"student_login.xml")) ; //xml文件路径 NodeList nl = doc.getElementsByTagName("student") ;
Element e1 = (Element) nl.item(0) ; // 取出每一个元素
String studentName=e1.getElementsByTagName("name").item(0).getFirstChild().getNodeValue();
String studentPassword=e1.getElementsByTagName("password").item(0).getFirstChild().getNodeValue() ; NodeList n2 = doc.getElementsByTagName("teacher") ;
Element e2 = (Element) n2.item(0) ; // 取出每一个元素
String teacherName=e2.getElementsByTagName("name").item(0).getFirstChild().getNodeValue();
String teacherPassword=e2.getElementsByTagName("password").item(0).getFirstChild().getNodeValue() ; NodeList n3 = doc.getElementsByTagName("admin") ;
Element e3 = (Element) n3.item(0) ; // 取出每一个元素
String adminName=e3.getElementsByTagName("name").item(0).getFirstChild().getNodeValue();
String adminPassword=e3.getElementsByTagName("password").item(0).getFirstChild().getNodeValue() ; if(user.equals("student") && name.equals(studentName) && password.equals(studentPassword)){
login_tag=true;
}
if(user.equals("teacher") && name.equals(teacherName) && password.equals(teacherPassword)){
login_tag=true;
}
if(user.equals("admin") && name.equals(adminName) && password.equals(adminPassword)){
login_tag=true;
}
if(login_tag==true){
%> 用户登录成功!
<%
}else{
%> 登录失败!
<%
}
%>
</body>
</html>

  这三个文件结合使用即可实现通过XML文件验证用户登录的功能,简单吧!

xml的应用:

  对于小型项目来说,你可能完全不需要存储大量的数据,不需要经常进行读取,这时使用一个完整的数据库来完成任务无疑是杀鸡用牛刀,只使用简简单单的xml便是极好的。xml文件需要解析才能使用,它存在于磁盘中,所以经常读取的效率不是很高,小项目的配置是它的天下。

小结:

  本文介绍的只是xml文件知识的一个非常简单的应用,就像文章开头提到的,xml的应用远远超过本文所介绍的这一点。xml文件只能但是对于只会通过数据库验证的同学来说,这无疑能帮助你打开视野,提升编程水平。

xml实现登录表单验证的更多相关文章

  1. jQuery封装的表单验证,模仿网易或者腾讯登录的风格

    模仿网易邮箱做了一个登录表单验证,不太好,请指教 上代码 <form action="" name="" id="form1"> ...

  2. 配置web.xml和glassfish容器实现javaEE表单验证

    web.xml配置: <!-- 声明用于安全约束的角色 --> <security-role> <role-name>ReimUser</role-name& ...

  3. Xamarin.Forms登录对话框及表单验证

    微信公众号:Dotnet9,网站:Dotnet9,问题或建议,请网站留言: 如果您觉得Dotnet9对您有帮助,欢迎赞赏. Xamarin.Forms登录系统 内容目录 实现效果 业务场景 编码实现 ...

  4. AngularJS学习之 登录表单 清爽验证(边学边更新)

    注册过程的确好多需要验证的,但是注册成功之后的登录就简单多了, 只要用户 输入 用户名和密码, ajax向后台提交登录请求, 根据返回的结果确定用户名或者密码是否正确即可登录. 所以这个登录表单的验证 ...

  5. 6.4-6.5 使用form表单验证,完善登录页面

    之前是使用自定义的类来实现登录逻辑,现在使用django内置的form表单验证,用继承django的view来实现登录页面. users > views.py 的内容是: from django ...

  6. Django(5) session登录注销、csrf及中间件自定义、django Form表单验证(非常好用)

    一.Django中默认支持Session,其内部提供了5种类型的Session供开发者使用: 数据库(默认) 缓存 文件 缓存+数据库 加密cookie 1.数据库Session 1 2 3 4 5 ...

  7. struts2官方 中文教程 系列十一:使用XML进行表单验证

    在本教程中,我们将讨论如何使用Struts 2的XML验证方法来验证表单字段中用户的输入.在前面的教程中,我们讨论了在Action类中使用validate方法验证用户的输入.使用单独的XML验证文件让 ...

  8. Flask10 登录模块、表单框架、表单渲染、表单验证、bookie、请求之前钩子、g对象、编写装饰器

    from flask import Flask from flask import request from flask import render_template from flask_wtf i ...

  9. Vue项目之实现登录功能的表单验证!

    Vue项目之实现登录功能的表单验证! 步骤: 配置 Form表单验证; 1.必须给el-from组件绑定model 为表单数据对象 2 给需要验证的表单项 el-form-item 绑定 prop 属 ...

随机推荐

  1. 莫烦tensorflow(8)-CNN

    import tensorflow as tffrom tensorflow.examples.tutorials.mnist import input_data#number 1 to 10 dat ...

  2. SSH设置秘钥登录

    设置 SSH 通过密钥登录 我们一般使用 PuTTY 等 SSH 客户端来远程管理 Linux 服务器.但是,一般的密码方式登录,容易有密码被暴力破解的问题.所以,一般我们会将 SSH 的端口设置为默 ...

  3. C语言笔记变量与数据类型

    目录 1.转义字符 2.常量与变量 2.1 什么是常量和变量 2.2 内存 2.3 变量的内存机制 2.4 变量命名规则 2.5 变量的定义 2.6 常量的定义 2.7 计算机内存字节顺序 2.8 局 ...

  4. 各机器学习方法代码(OpenCV2)

    #include <iostream> #include <math.h> #include <string> #include "cv.h" ...

  5. 使用SURF::create()以后报错无法解析

    理论上,如果在cmake中勾选了Build_opencv_world.OPENCV_ENABLE_NONFREE以及选择了OPENCV_EXTRA_MODULES_PATH三项后,再编译INSTALL ...

  6. ionic使用的一些技巧

    使用ionic总结: 1.全局禁用缓存的方法是:  $ionicConfigProvider.views.maxCache(0); 2. 在不同的用户输入场景下,需要显示不同的键盘模式以方便用户输入, ...

  7. web前端常用代码于面试等资源

    https://www.cnblogs.com/moqiutao/p/4766146.html

  8. java 实现excel 导出功能

    实现功能:java导出excel表 1.jsp代码 <form id="zhanwForm" action="<%=path%>/conferences ...

  9. 1.2.4 Excel快速建立n个文件夹

    1.准备员工信息表,选中名字 2.[设置单元格格式]>[数字]>[自定义]>右侧的[类型]>输入”md ”@>单击[确定] 3.确定后在姓名前会出现md,新建文本文档,将 ...

  10. JavaScript获取mp4文件MIME编码格式,用于判读是否是h.264,解决在线播放只有声音问题

    测试网址:https://gpac.github.io/mp4box.js/test/filereader.html js库:mp4box.js 不能在线播放的:audio/mp4; codecs=& ...