- 浏览: 500687 次
- 性别:
- 来自: 上海
-
文章分类
- 全部博客 (124)
- hibernate (7)
- spring (18)
- java se (32)
- jdbc (5)
- js (4)
- 数据库 (1)
- ide (2)
- Struts2 (1)
- 有用的链接 (2)
- 开源框架 (2)
- j2ee (2)
- spring mvc (4)
- weblogic (0)
- spring security (4)
- web服务器 (5)
- maven (2)
- 多线程 (12)
- linux (3)
- NIO (1)
- webservice (1)
- guava (5)
- restful (1)
- jenkins (1)
- ios (1)
- ehcache (1)
- jvm (1)
- 深入jvm (2)
- akka发 (1)
- disruptor (3)
- spring boot,异常处理, protobuf (1)
- curator (1)
- zookeeper (1)
最新评论
-
abc08010051:
张延龙地盘 写道多实例下就不行了吧是的,多实例直接上分布式锁
java高并发下的唯一性验证 -
张延龙地盘:
多实例下就不行了吧
java高并发下的唯一性验证 -
a12345531:
s3.getResourceUrl(bucketName, k ...
Amazon AWS S3 上传文件 并获取公用url -
544483342:
楼主请问WorkerEventHandler和EventHan ...
disruptor(一) 单一生产者和WorkPool消费者源码阅读 -
544483342:
请问楼主使用的是什么UML工具啊?
disruptor(一) 单一生产者和WorkPool消费者源码阅读
1.有很多时候我们需要将相关动态的信息保存到XML文件中去,那么我们就可以动态输入相关信息。特别是针对数据库方面的操作的时候就非常地灵活。那我现在假如项目中的操作数据库的包为model里面存放了我们的XML文件db.xml现在来看看如何解析出来相关的数据来调用。
第一个类:
package model;
import org.xml.sax.Attributes;
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.SAXException;
import java.util.Properties;
//使用DefaultHandler的好处 是 不必陈列出所有方法,
public class ConfigParser extends DefaultHandler {
////定义一个Properties 用来存放 dbhost dbuser dbpassword的值
private Properties props;
private String currentSet;
private String currentName;
private StringBuffer currentValue = new StringBuffer();
//构建器初始化props
public ConfigParser() {
this.props = new Properties();
}
public Properties getProps() {
return this.props;
}
//定义开始解析元素的方法. 这里是将<xxx>中的名称xxx提取出来.
public void startElement(String uri, String localName, String qName, Attributes attributes)throws SAXException {
currentValue.delete(0, currentValue.length());
this.currentName =qName;
}
//这里是将<xxx></xxx>之间的值加入到currentValue
public void characters(char[] ch, int start, int length) throws SAXException {
currentValue.append(ch, start, length);
}
//在遇到</xxx>结束后,将之前的名称和值一一对应保存在props中
public void endElement(String uri, String localName, String qName) throws SAXException {
props.put(qName.toLowerCase(), currentValue.toString().trim());
}
}
可以直接拷贝过来用了。
第二个类:
package model;
import java.util.Properties;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.SAXException;
import java.net.URL;
public class ParseXML{
//定义一个Properties 用来存放 dbhost dbuser dbpassword的值
private Properties props;
//这里的props
public Properties getProps() {
return this.props;
}
public void parse(String filename) {
//将我们的解析器对象化
ConfigParser handler = new ConfigParser();
//获取SAX工厂对象
SAXParserFactory factory = SAXParserFactory.newInstance();
factory.setNamespaceAware(false);
factory.setValidating(false);
//获取SAX解析
SAXParser parser=null;
try {
parser = factory.newSAXParser();
} catch (Exception e1) {
e1.printStackTrace();
}
URL confURL = null;
//得到配置文件myenv.xml所在目录. tomcat中是在WEB-INF/classes
//下例中BeansConstants是用来存放xml文件中配置信息的类,可以自己代替或定义
try{
confURL = ParseXML.class.getClassLoader().getResource(filename);
//只需要将我们所需要的XML文件名字输入进去就可以了!
}catch(Exception e){
System.out.print(e.toString());
}
try
{ //将解析器和解析对象myenv.xml联系起来,开始解析
parser.parse(confURL.toString(), handler);
//获取解析成功后的属性 以后 我们其他应用程序只要调用本程序的props就可以提取出属性名称和值了
props = handler.getProps();
}catch(Exception e){
System.out.println(e.toString());
}finally{
factory=null;
parser=null;
handler=null;
}
}
}
下面是我们所需要调用的XML文件内容:
<myenv>
<datasource>
<dbhost>localhost</dbhost>
<dbname>tianya_speed_test</dbname>
<dbuser>root</dbuser>
<dbpassword>321</dbpassword>
</datasource>
</myenv>
现在需要将其中的相关内容读取出来。包括数据库主机地址,数据库名字,用户名及密码好了,现在准备工作已经都做完了。现在就可以来想想如何来调用我们刚才解析出来的内容喽:
public void initVariable(){
ParseXML test = new ParseXML();
try{
test.parse("model/db.xml");//表示实际的XML文件位置,如果没有找到就报空指针异常!
}catch(Exception e){
System.out.print(e.toString());
}
Properties pro = test.getProps();//获取到PRO对象然后用它去调用相关的属性!
dbServer = pro.getProperty("dbhost");//相当于Python中的字典类型。
dbName = pro.getProperty("dbname");
dbUser = pro.getProperty("dbuser");
dbPwd = pro.getProperty("dbpassword");
}
tcp.validnode_checking=yes
#允许访问的ip
tcp.invited_nodes=(ip1,ip2,……)
#不允许访问的ip
tcp.excluded_nodes=(ip1,ip2,……)
好了,现在我们就只需要手工来修改XML就可以了。
以后在做项目过程中如果需要用XML来配置数据库或其他的相关信息就可以了用这个方法哦。比较简单而且实用!
(转载:http://java.e800.com.cn/articles/2008/1118/1226978922083_1.html)
第一个类:
package model;
import org.xml.sax.Attributes;
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.SAXException;
import java.util.Properties;
//使用DefaultHandler的好处 是 不必陈列出所有方法,
public class ConfigParser extends DefaultHandler {
////定义一个Properties 用来存放 dbhost dbuser dbpassword的值
private Properties props;
private String currentSet;
private String currentName;
private StringBuffer currentValue = new StringBuffer();
//构建器初始化props
public ConfigParser() {
this.props = new Properties();
}
public Properties getProps() {
return this.props;
}
//定义开始解析元素的方法. 这里是将<xxx>中的名称xxx提取出来.
public void startElement(String uri, String localName, String qName, Attributes attributes)throws SAXException {
currentValue.delete(0, currentValue.length());
this.currentName =qName;
}
//这里是将<xxx></xxx>之间的值加入到currentValue
public void characters(char[] ch, int start, int length) throws SAXException {
currentValue.append(ch, start, length);
}
//在遇到</xxx>结束后,将之前的名称和值一一对应保存在props中
public void endElement(String uri, String localName, String qName) throws SAXException {
props.put(qName.toLowerCase(), currentValue.toString().trim());
}
}
可以直接拷贝过来用了。
第二个类:
package model;
import java.util.Properties;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.SAXException;
import java.net.URL;
public class ParseXML{
//定义一个Properties 用来存放 dbhost dbuser dbpassword的值
private Properties props;
//这里的props
public Properties getProps() {
return this.props;
}
public void parse(String filename) {
//将我们的解析器对象化
ConfigParser handler = new ConfigParser();
//获取SAX工厂对象
SAXParserFactory factory = SAXParserFactory.newInstance();
factory.setNamespaceAware(false);
factory.setValidating(false);
//获取SAX解析
SAXParser parser=null;
try {
parser = factory.newSAXParser();
} catch (Exception e1) {
e1.printStackTrace();
}
URL confURL = null;
//得到配置文件myenv.xml所在目录. tomcat中是在WEB-INF/classes
//下例中BeansConstants是用来存放xml文件中配置信息的类,可以自己代替或定义
try{
confURL = ParseXML.class.getClassLoader().getResource(filename);
//只需要将我们所需要的XML文件名字输入进去就可以了!
}catch(Exception e){
System.out.print(e.toString());
}
try
{ //将解析器和解析对象myenv.xml联系起来,开始解析
parser.parse(confURL.toString(), handler);
//获取解析成功后的属性 以后 我们其他应用程序只要调用本程序的props就可以提取出属性名称和值了
props = handler.getProps();
}catch(Exception e){
System.out.println(e.toString());
}finally{
factory=null;
parser=null;
handler=null;
}
}
}
下面是我们所需要调用的XML文件内容:
<myenv>
<datasource>
<dbhost>localhost</dbhost>
<dbname>tianya_speed_test</dbname>
<dbuser>root</dbuser>
<dbpassword>321</dbpassword>
</datasource>
</myenv>
现在需要将其中的相关内容读取出来。包括数据库主机地址,数据库名字,用户名及密码好了,现在准备工作已经都做完了。现在就可以来想想如何来调用我们刚才解析出来的内容喽:
public void initVariable(){
ParseXML test = new ParseXML();
try{
test.parse("model/db.xml");//表示实际的XML文件位置,如果没有找到就报空指针异常!
}catch(Exception e){
System.out.print(e.toString());
}
Properties pro = test.getProps();//获取到PRO对象然后用它去调用相关的属性!
dbServer = pro.getProperty("dbhost");//相当于Python中的字典类型。
dbName = pro.getProperty("dbname");
dbUser = pro.getProperty("dbuser");
dbPwd = pro.getProperty("dbpassword");
}
tcp.validnode_checking=yes
#允许访问的ip
tcp.invited_nodes=(ip1,ip2,……)
#不允许访问的ip
tcp.excluded_nodes=(ip1,ip2,……)
好了,现在我们就只需要手工来修改XML就可以了。
以后在做项目过程中如果需要用XML来配置数据库或其他的相关信息就可以了用这个方法哦。比较简单而且实用!
(转载:http://java.e800.com.cn/articles/2008/1118/1226978922083_1.html)
发表评论
-
生产者消费者
2018-03-26 14:58 0package com.namibank.qyl; i ... -
耦合方法重构小技巧: 内部类
2018-02-28 10:16 0打发点 -
CompletableFuture源码赏析
2018-01-29 17:26 3517文章原创,转载请注明出处:http://abc080100 ... -
Function 对代码封装带来的改变
2017-12-18 16:40 705java 8 Function特性也出现了很久了,在项目用 ... -
java 8 Stream list to Map key 重复 value合并到Collection
2017-08-09 10:38 14484关于把list转换成key value的map有很多博客上 ... -
LinkedHashMap理解
2016-11-16 14:55 998注: 下面的源码理解均基于jdk1.8的源码 ... -
泛型的使用
2016-06-22 15:08 544public class ClassTest { p ... -
关于String的问题
2015-03-05 14:07 694关于String的经典问题很多,不过弄清楚jvm如果创建和存 ... -
复习遇到的问题
2015-03-03 21:31 01 Object的clone方法没有new对象的效率高 ... -
java高并发下的唯一性验证
2014-11-21 14:03 7803做java ee程序基本上都会遇到唯一性的问题,我们通常不 ... -
java静态方法是否可以被重写
2014-11-18 17:40 2334首先来看一段代码: ... -
深入java虚拟机 异常,异常表, finally
2014-11-12 17:36 2558每个异常表入口包含 ... -
Intellij Idea + Maven 使用jstl遇到的问题
2014-11-11 10:27 3114请按照以下步骤操作: 1 在pom.xml文件中引入jst ... -
java 数组
2014-10-31 14:37 9461 数组是引用类型 2 java虚拟机在装入数组时, ... -
Amazon AWS S3 上传文件 并获取公用url
2014-06-20 13:38 52497最近在用aws的s3做云存储,把文件上传上去,在 ... -
File Path 相对路径
2014-06-07 10:32 2314最近在项目中想使用相对路径存放上传的a ... -
java Tuple 元组
2014-05-30 18:01 22050场景:当在一个方法中, 你需要返回几个对象,这几个 ... -
JodaTime 时间处理
2014-05-30 13:47 1822最近看别人在谈项目中时间处理的问题,jdk提供的Dat ... -
同步与java内存模型(转载)
2014-05-22 11:11 8391 原子性 除了long型字段和double型字段 ... -
ThreadLocal 管理 HttpSession
2014-04-24 15:52 2025最近在用spring security控制系统的权限, ...
相关推荐
本文将深入探讨Java中解析XML的四种主要方法:DOM、SAX、StAX和JAXB。 1. DOM(Document Object Model) DOM是一种基于树形结构的API,它将整个XML文档加载到内存中,形成一个节点树。你可以通过遍历这个树来访问和...
### Java解析XML的四种方式详解 #### 一、DOM(Document Object Model) DOM是一种平台和语言中立的接口,它将XML文档表示为一个树结构,使得程序可以创建、读取、更新或删除树中的元素。DOM实现了W3C的标准,能够...
本项目“java解析xml四种方式完整项目”旨在全面介绍和实现利用Java语言解析XML的四种主要方法:DOM、SAX、JDOM和DOM4J。下面将详细阐述这四种解析器的工作原理、优缺点以及如何在实际项目中应用。 1. DOM...
Java作为一种广泛使用的后端编程语言,提供了多种方式来解析XML文档,使得处理多级嵌套的数据变得可能。本文将详细讲解如何在Java中解析XML,特别是针对多级结构的情况。 首先,Java提供了两种主要的API来处理XML:...
本篇将详细介绍Java解析XML的四种常见方法,帮助你更好地理解和应用这些技术。 1. DOM(Document Object Model)解析 DOM解析器将整个XML文档加载到内存中,形成一个树形结构,称为DOM树。这种方式适合小型XML文件...
Java解析XML的四种经典方法是XML处理中常用的技术,它们分别是DOM、SAX、StAX和JDOM。每种方法都有其独特的特性和适用场景,下面将详细介绍这四种方法。 1. DOM(Document Object Model)解析: DOM是W3C制定的一种...
### Java解析XML字符串 在给定的代码示例中,我们看到了如何使用JDOM库来解析一个XML字符串,并对其进行操作。下面我们将详细解析这个过程: 1. **初始化XML源**:首先,将XML字符串转化为`StringReader`对象,这...
本文将详细讲解四种解析XML文件的方法,旨在帮助初学者更好地理解和掌握XML处理技术。 1. DOM解析器(Document Object Model) DOM解析器将整个XML文档加载到内存中,构建一个树形结构,称为DOM树。这个方法的优点...
Java解析XML时,主要有四种方法:DOM(Document Object Model)、SAX(Simple API for XML)、StAX(Streaming API for XML)以及JAXB(Java Architecture for XML Binding)。这四种方法各有特点,适用于不同的场景...
SAX解析器以事件驱动的方式处理XML文件,只在需要时读取数据,节省内存。它适合处理大型XML文件。Java提供了`org.xml.sax.helpers.DefaultHandler`类作为事件处理器。 ```java SAXParserFactory saxFactory = ...
本文将深入探讨Java解析XML的四种主要方法。 1. DOM(Document Object Model)解析: DOM解析器将整个XML文档加载到内存中,创建一个树形结构,允许开发者通过节点遍历和操作XML。例如,Java的`javax.xml.parsers....
在"Java解析XML性能对比分析Demo"中,你可以通过运行这些解析器的示例代码,观察它们在处理相同XML文件时的内存占用、处理速度等指标,以了解哪种解析方式更适合你的项目需求。例如,如果你处理的XML文件较小,DOM或...
使用DOM方法读取XML文件,需要创建DocumentBuilderFactory对象,获取DocumentBuilder对象,然后解析XML文件得到Document对象。最后,使用Document对象的getElementsByTagName方法获取指定标签的节点列表,并遍历节点...
在Java中,有多种方式来解析XML,主要包括SAX、JDOM和DOM4J。下面我们将详细介绍这三种方法。 1. SAX(Simple API for XML) SAX是一种基于事件驱动的解析器,它不会一次性加载整个XML文档到内存,而是逐行读取,当...
Java JDOM解析XML是Java开发中处理XML文档的一种方法,JDOM全称为Java Document Object Model,它是一个基于Java语言的API,用于创建、修改和读取XML文档。JDOM为XML处理提供了一种高效且方便的解决方案,尤其适用于...
以上就是Java中解析XML的四种常见方法,每种方法都有其适用场景。根据项目需求和文件大小,可以选择最合适的解析器。在实际开发中,还可以结合使用jar文件,如`comSample`,来包含和调用相关的解析库。理解并掌握...
Java解析XML的四种经典方法主要涵盖DOM、SAX、StAX和JDOM这四种方式,每种方法都有其独特的优势和适用场景。 1)DOM(JAXP Crimson 解析器) DOM(Document Object Model)是W3C推荐的一种XML解析标准,它将XML...
Java在线解析XML是一种常见的编程任务,特别是在处理Web服务、数据交换或者从XML文件中提取信息时。XML(Extensible Markup Language)是一种结构化数据格式,它允许数据以自定义的标签进行组织,使得数据的传输和...
在Java中,有多种方式可以解析XML文档,主要包括DOM(Document Object Model)、SAX(Simple API for XML)和StAX(Streaming API for XML)。每种方法都有其优缺点,适用于不同的场景。 1. DOM解析:DOM是将整个...
StAX是另一种基于流的解析器,它允许程序员以迭代方式处理XML。使用`javax.xml.stream.XMLInputFactory`和`XMLStreamReader`进行读取,`XMLOutputFactory`和`XMLStreamWriter`进行写入,适合处理大文件。 7. **...