「javaxml测试」javaxml解析
本篇文章给大家谈谈javaxml测试,以及javaxml解析对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、有关java和xml的
- 2、java 单元测试spring的xml事物设置某个方法只读不起作用怎么回事
- 3、如何用一个java程序来判断一个xml文件是否符合一个DTD的要求
- 4、关于Java Dom4j解析xml文档的问题。我用Junit测试的时候有错误 好像是路径的错误 反正就是运行不出来。
- 5、用java解析获得xml中的值
- 6、JAVA 读取XML文件
有关java和xml的
一般情况是使用DOM,SAX这是2个开原的插件,你只要在你的程序里导入就可以了JDOM或者DOM4J的JAR包就可以了。
下载的 这2个插件都有自己的网站,建议使用JDOM这个比较简单的,至于如何读和写,网上有很多的例子.
XML作为全球通用的结构化语言,越来越受人们青睐,各种开发平台(比如Microsoft Studio系列、Oracle系列、Inprise Borland系列等)也都把支持XML开发作为宣传口号之一 。由于笔者所从事的电子政务开发较早的引入了XML,所以尝到了许多甜头,在许多项目中利用XML数据交换信息,省去了许多麻烦事,不用制定繁锁的数据格式,利用XML数据易于表达,也利于一线开发者跟踪调试。
笔者先前也曾发表过相关的文章,比如《简析Delphi中的XML编程》一文,有兴趣的读者可以到Google网()去搜索一下,有很多媒体转载。今天笔者想探讨的是关于JAVA中的XML编程,希望对正在或想要学习XML编程的新老读者有所帮助。
在XML应用中,最常用也最实用的莫过于XML文件的读写,所以笔者通过一个简单的XML文件读写来作简要分析。可以在任何文本编辑器中先建立如下结构的XML文件,类似于HTML结构,但XML语义比较严格,起始标记必须配对,比如"〈学生花名册〉"与"〈/学生花名册〉"对应,空格多少可不必在意,但一般都以缩格形式书写,便于阅读。把此文件命名为Input.xml,可以在任何支持XML的浏览器中打开测试一下,如果输入正确,在浏览中可以看到此文件的树形表示结构。如果您还对XML结构感到比较陌生,建议先看看《简析Delphi中的XML编程》一文中关于XML文件的说明。
Input.xml
[code:1:af65f1d5b3]
?xml version="1.0" encoding="GB2312"?
学生花名册
学生 性别 = "男"
姓名李华/姓名
年龄14/年龄
电话6287555/电话
/学生
学生 性别 = "男"
姓名张三/姓名
年龄16/年龄
电话8273425/电话
/学生
/学生花名册
[/code:1:af65f1d5b3]
准备工作做完后,接着就开始写实质性的JAVA代码了。为保存从XML文件读入的信息,需要先建一个简单的Bean来保存学生信息,命名为StudentBean,代码如下所示:
StudentBean.java
[code:1:af65f1d5b3]
public class StudentBean {
private String sex; //学生性别
private String name; //学生姓名
private int age; //学生年龄
private String phone; //电话号码
public void setSex(String s) {
sex = s;
}
public void setName(String s) {
name = s;
}
public void setAge(int a) {
age = a;
}
public void setPhone(String s) {
phone = s;
}
public String getSex() {
return sex;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
public String getPhone() {
return phone;
}
}
[/code:1:af65f1d5b3]
之后写XML的测试类,
TESTXml.java
[code:1:af65f1d5b3]
import java.io.*; //Java基础包,包含各种IO操作
import java.util.*; //Java基础包,包含各种标准数据结构操作
import javax.xml.parsers.*; //XML解析器接口
import org.w3c.dom.*; //XML的DOM实现
import org.apache.crimson.tree.XmlDocument; //写XML文件要用到
public class XMLTest {
Vector student_Vector;
XMLTest() {
}
//为了保存多个学生信息,还得借助一个集合类(并不是单纯意义上的集合,JAVA中的集合是集合框架的概念,包含向量、列表、哈希表等),这里采用Vector向量类。定义在XMLTest测试类中,命名为student_Vector。然后定义两个方法readXMLFile和writeXMLFile,实现读写操作。代码如下:
private void readXMLFile(String inFile) throws Exception {
//为解析XML作准备,创建DocumentBuilderFactory实例,指定DocumentBuilder
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = null;
try {
db = dbf.newDocumentBuilder();
}
catch (ParserConfigurationException pce) {
System.err.println(pce); //出异常时输出异常信息,然后退出,下同
System.exit(1);
}
Document doc = null;
try {
doc = db.parse(inFile);
}
catch (DOMException dom) {
System.err.println(dom.getMessage());
System.exit(1);
}
catch (IOException ioe) {
System.err.println(ioe);
System.exit(1);
}
//下面是解析XML的全过程,比较简单,先取根元素"学生花名册"
Element root = doc.getDocumentElement();
//取"学生"元素列表
NodeList students = root.getElementsByTagName("学生");
for (int i = 0; i students.getLength(); i++) {
//依次取每个"学生"元素
Element student = (Element) students.item(i);
//创建一个学生的Bean实例
StudentBean studentBean = new StudentBean();
//取学生的性别属性
studentBean.setSex(student.getAttribute("性别"));
//取"姓名"元素,下面类同
NodeList names = student.getElementsByTagName("姓名");
if (names.getLength() == 1) {
Element e = (Element) names.item(0);
Text t = (Text) e.getFirstChild();
studentBean.setName(t.getNodeValue());
}
NodeList ages = student.getElementsByTagName("年龄");
if (ages.getLength() == 1) {
Element e = (Element) ages.item(0);
Text t = (Text) e.getFirstChild();
studentBean.setAge(Integer.parseInt(t.getNodeValue()));
}
NodeList phones = student.getElementsByTagName("电话");
if (phones.getLength() == 1) {
Element e = (Element) phones.item(0);
Text t = (Text) e.getFirstChild();
studentBean.setPhone(t.getNodeValue());
}
student_Vector.add(studentBean);
}
}
private void writeXMLFile(String outFile) throws Exception {
//为解析XML作准备,创建DocumentBuilderFactory实例,指定DocumentBuilder
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = null;
try {
db = dbf.newDocumentBuilder();
}
catch (ParserConfigurationException pce) {
System.err.println(pce);
System.exit(1);
}
Document doc = null;
doc = db.newDocument();
//下面是建立XML文档内容的过程,先建立根元素"学生花名册"
Element root = doc.createElement("学生花名册");
//根元素添加上文档
doc.appendChild(root);
//取学生信息的Bean列表
for (int i = 0; i student_Vector.size(); i++) {
//依次取每个学生的信息
StudentBean studentBean = (StudentBean) student_Vector.get(i);
//建立"学生"元素,添加到根元素
Element student = doc.createElement("学生");
student.setAttribute("性别", studentBean.getSex());
root.appendChild(student);
//建立"姓名"元素,添加到学生下面,下同
Element name = doc.createElement("姓名");
student.appendChild(name);
Text tName = doc.createTextNode(studentBean.getName());
name.appendChild(tName);
Element age = doc.createElement("年龄");
student.appendChild(age);
Text tAge = doc.createTextNode(String.valueOf(studentBean.
getAge()));
age.appendChild(tAge);
Element phone = doc.createElement("电话");
student.appendChild(phone);
Text tPhone = doc.createTextNode(studentBean.getPhone());
phone.appendChild(tPhone);
}
//把XML文档输出到指定的文件
FileOutputStream outStream = new FileOutputStream(outFile);
OutputStreamWriter outWriter = new OutputStreamWriter(outStream);
( (XmlDocument) doc).write(outWriter, "GB2312");
outWriter.close();
outStream.close();
}
//最后加入测试主函数,如下:
public static void main(String[] args) throws Exception {
//建立测试实例
XMLTest xmlTest = new XMLTest();
//初始化向量列表
xmlTest.student_Vector = new Vector();
System.out.println("开始读Input.xml文件");
xmlTest.readXMLFile("Input.xml");
System.out.println("读入完毕,开始写Output.xml文件");
xmlTest.writeXMLFile("Output.xml");
System.out.println("写入完成");
System.in.read();
}
}[/code:1:af65f1d5b3]
了,保存好StudentBean和XMLTest,把Input.xml保存到工作目录下。如果您输入很仔细,没敲错字母的话,可以看到"写入完成"了,去瞧瞧Output.xml文件和Input.xml文件是不是一样吧。如果您在调试过程中发现有什么问题,欢迎通过E-Mail:nbDeveloper@hotmail.com与笔者取得联系。 [/code]
java 单元测试spring的xml事物设置某个方法只读不起作用怎么回事
1,首先保证你的spring配置了该方法的事物。
2,在该事物管理的方法中有非读操作。
代码如下:
//配置文件
bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
property name="dataSource" ref="dataSource"/
/bean
tx:advice id="TestAdvice" transaction-manager="transactionManager"
tx:attributes
tx:method name="query*" propagation="REQUIRED" read-only="true"/
!--这里对update开头的方法加上read-only 用于测试--
tx:method name="update*" propagation="REQUIRED" read-only="true"/
/tx:attributes
/tx:advice
aop:config
aop:pointcut id="transaction" expression="execution(* com.straw.spring.service.*.*(..))"/
aop:advisor advice-ref="TestAdvice" pointcut-ref="transaction"/
/aop:config
//java service implements
package com.straw.spring.service;
import com.straw.spring.model.User;
/**
* Created by Administrator on 2017/3/28.
*/
public interface UserService {
User queryUserbyId(int id);
User updateAndQueryUserbyId(int i, String hai);
}
//实现类
package com.straw.spring.service.impl;
import com.straw.spring.dao.UserDao;
import com.straw.spring.model.User;
import com.straw.spring.service.UserService;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.HashMap;
import java.util.Map;
/**
* Created by Administrator on 2017/3/28.
*/
@Service
public class UserServiceImpl implements UserService {
@Resource
UserDao userDao;
public User queryUserbyId(int id) {
System.out.println(1111);
//return super.queryUserbyId(id);
return userDao.selectByPrimaryKeyForUpdate(id);
}
public User updateAndQueryUserbyId(int id, String userName) {
System.out.println(2222);
MapString, Object params = new HashMapString, Object();
params.put("id", id);
params.put("userName", userName);
//修改操作
userDao.updateUserbyId(params);
User user = userDao.selectByPrimaryKeyForUpdate(id);
return user;
}
}
//dao层
package com.straw.spring.dao;
import com.straw.spring.model.User;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.stereotype.Repository;
import java.util.Map;
public interface UserDao extends BaseRepositoryUser {
}
//基础dao
package com.straw.spring.dao;
import com.straw.spring.model.Organization;
import com.straw.spring.model.User;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.stereotype.Repository;
import java.io.Serializable;
import java.util.Map;
/**
* Created by Administrator on 2017/3/28.
*/
public interface BaseRepositoryM extends Serializable {
public void save(M m);
public abstract M selectByPrimaryKeyForUpdate(int id);
public int updateUserbyId(Map params);
}
//mapper 配置文件
mapper namespace="com.straw.spring.dao.UserDao"
resultMap id="BaseResultMap" type="com.straw.spring.model.User"
id column="id" property="id" jdbcType="INTEGER"/
result column="user_name" property="userName" jdbcType="VARCHAR"/
result column="pass_word" property="passWord" jdbcType="VARCHAR"/
/resultMap
update id="updateUserbyId" parameterType="java.util.Map"
update t_user set user_name = #{userName} where id=#{id}
/update
!--主键查询--
select id="queryUserbyId" resultMap="BaseResultMap" parameterType="java.lang.Long"
select t_user.*
from t_user
trim prefix="where" prefixOverrides="AND |OR "
id = #{id,jdbcType=BIGINT}
/trim
/select
!--加锁查询--
select id="selectByPrimaryKeyForUpdate" resultMap="BaseResultMap" parameterType="java.lang.Long"
select t_user.*
from t_user t_user
trim prefix="where" prefixOverrides="AND |OR "
id = #{id,jdbcType=BIGINT}
/trim
for update
/select
/mapper
//测试类
package com.straw;
import com.straw.spring.model.User;
import com.straw.spring.service.UserService;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Configurable;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:spring-mybatis.xml"})
@Configurable
public class TestMain {
@Autowired
UserService userService;
@Test
public void test1(){
User user = userService.queryUserbyId(1);
if (user != null ){
System.out.println(user.getUserName());
System.out.println(user.getUserExt().getId());
}
}
@Test
public void test2(){
User user = userService.updateAndQueryUserbyId(1,"hai");
if (user != null ){
System.out.println(user.getUserName());
System.out.println(user.getUserExt().getId());
}
}
}
// test2 运行结果
### Cause: java.sql.SQLException: Connection is read-only. Queries leading to data modification are not allowed
如何用一个java程序来判断一个xml文件是否符合一个DTD的要求
javax.xml.validation API 使用三个类来验证文档:SchemaFactory、Schema 和 Validator。
还大量使用了 TrAX 的 javax.xml.transform.Source 接口来表示 XML 文档。简言之,SchemaFactory 读取模式文档(通常是 XML 文件)并创建 Schema 对象。
Schema 创建一个 Validator 对象。最后,Validator 对象验证表示为 Source 的 XML 文档。
具体代码请参加一下地址:
关于Java Dom4j解析xml文档的问题。我用Junit测试的时候有错误 好像是路径的错误 反正就是运行不出来。
new File("/Web_01/src/cn/itcast/xml_03/book.xml")
这个是绝对路径。如果和java.exe不在同一个盘符里面,就可能出错了。
getClass().getResourceAsStream("/Web_01/src/cn/itcast/xml_03/book.xml") 比较好
用java解析获得xml中的值
package com.applet;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.StringReader;
import java.util.Iterator;
import java.util.List;
import org.apache.commons.lang.StringUtils;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class B {
public static void main(String[] args) {
String inputBizInfo = "?xml version=\"1.0\" encoding=\"utf-8\"?\n"
+ "EAS\n"
+ " Header\n"
+ " TransIDe688030e-f86f-455b-b143-58871084670b/TransID\n"
+ " TransTime2015-05-29 02:12:15/TransTime\n"
+ " DataTypeVendor/Customer/DataType\n"
+ " OptCatalogSingle/OptCatalog\n"
+ " OptTypeUpdate/Create/OptType\n"
+ " RowCount1/RowCount\n" + " /Header\n"
+ " MasterData\n" + " Field name=\"UnitClass\"\n"
+ " !--单位分类--2000 单位分类 测试一下\n" + " /Field\n"
+ " Field name=\"AccountGroup\"\n" + " !--账户组--\n"
+ " /Field\n" + " Field name=\"Name1 \"\n"
+ " !--单位全称--1111 文具公司\n" + " /Field\n"
+ " /MasterData\n" + " ChangeDetail\n"
+ " ChangeFields name=\"Name1\"\n"
+ " OldValue文具/OldValue\n"
+ " NewValue皮包/NewValue\n"
+ " OperationType修改/OperationType\n"
+ " /ChangeFields\n" + " /ChangeDetail\n" + "/EAS";
// 我想获得这个xml中遍历分别获得
// 2000 单位分类 测试一下 ,空, 1111 文具公司 这样的3组值,每组值中的数据 用空格隔开放到数组中去,应该怎么办呢
try {
SAXReader reader = new SAXReader();
String txt = inputBizInfo.replaceAll("\n", "");
// Document doc = reader.read(new StringReader(txt));
// Document doc = reader.read(new
// File("F:\\zz\\FileRecv\\MyWebSocket\\src\\com\\applet\\NewFile.xml"));
// Document doc = reader.read(new ByteArrayInputStream(txt
// .getBytes("UTF-8")));
// System.err.println(txt);
// System.err.println(root.attribute(0).getName());
Document doc = DocumentHelper.parseText(txt);
Element root = doc.getRootElement();
// System.out.println("Root: " + root.getName());
List projects = root.selectNodes("MasterData/Field");
// System.err.println(projects.size());
Iterator it = projects.iterator();
while (it.hasNext()) {
Element elm = (Element) it.next();
// System.out.println("index:"+elm.attributeValue("index")+" level:"+elm.attributeValue("level")+" nickname:"+elm.attributeValue("nickname")+" country:"+elm.attributeValue("country")+" weiwang:"+elm.attributeValue("weiwang"));
// System.err.println(elm.attributeValue(elm.attribute(0).getName()));
// System.err.println(elm.getTextTrim());
String text = elm.getTextTrim();
if (StringUtils.isNotBlank(text)) {
String[] split = text.split(" ");
for (String string : split) {
//放入数组省略
System.err.println(string);
}
}
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
JAVA 读取XML文件
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class XmlTester {
public static void main(String[] args) throws DocumentException {
// 使用了dom4j解析xml
// 读取目录下用来测试的test.xml文件,取得xml主内容
Document document = new SAXReader().read("src/abc/test.xml").getDocument();
int i = 1;
// 遍历文档根节点(wuxialist)下的子节点列表,即txtbook节点的集合
for(Element txtbook : (ListElement)document.getRootElement().elements()){
//取得txtbook节点下的name节点的内容
System.out.println(i+"."+txtbook.element("name").getText());
i++; //原来这里少些了这一行,先补上
}
}
}
关于javaxml测试和javaxml解析的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。