「javaxml测试」javaxml解析

博主:adminadmin 2023-01-28 23:12:10 665

本篇文章给大家谈谈javaxml测试,以及javaxml解析对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

有关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解析的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。