黑马程序员__dom4j解析XML文档

本文概述了Java和Android的培训课程,包括DOM4J的使用、SAX解析、XML文档操作等核心内容,旨在提供全面的学习路径指导。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

---------------------- android培训java培训、期待与您交流! ----------------------

dom4j的特点:必须一层一层获取。

package cn.itcast.sax;

import java.io.IOException;

import java.util.ArrayList;

import java.util.List;

import javax.xml.parsers.ParserConfigurationException;

import javax.xml.parsers.SAXParser;

import javax.xml.parsers.SAXParserFactory;

import org.xml.sax.Attributes;

import org.xml.sax.SAXException;

import org.xml.sax.XMLReader;

import org.xml.sax.helpers.DefaultHandler;

public class Demo3 {

public static void main(String[] args) throws IOException, SAXException, ParserConfigurationException {

// 获得解析工厂

SAXParserFactory factory = SAXParserFactory.newInstance();

// 得到解析器

SAXParser sp = factory.newSAXParser();

// 得到读取器

XMLReader reader = sp.getXMLReader();

// 设置内容处理器(implements Contenthandlerextends DefaultHandler)

reader.setContentHandler(new BeanListHandler());

// 读取XML文档内容

reader.parse("src/book.xml");

// XML文档中的每一本书封装到一个book对象,并把多个book对象放在一个list集合返回

}

}

class BeanListHandler extends DefaultHandler {

private List list = new ArrayList();

private String currentTag;

private Book book;

@Override

public void startElement(String uri, String localName, String name,

Attributes attributes) throws SAXException {

// TODO Auto-generated method stub

currentTag = name;

if ("".equals(currentTag)) {

book = new Book();

}

}

@Override

public void characters(char[] ch, int start, int length)

throws SAXException {

if ("书名".equals(currentTag)) {

String name = new String(ch, start, length);

book.setName(name);

}

if ("作者".equals(currentTag)) {

String author = new String(ch, start, length);

book.setAuthor(author);

}

if ("售价".equals(currentTag)) {

String price = new String(ch, start, length);

book.setAuthor(price);

}

}

@Override

public void endElement(String uri, String localName, String qName)

throws SAXException {

if ("".equals("name")) {

list.add(book);

book = null;

}

currentTag = null;

}

public List getList(){

return list;

}

}

publicclass Demo1 {

/* @Test

public void readAttr() throws DocumentException{

SAXReader reader=new SAXReader();

Document document=reader.read(new File("src/book.xml"));

Element root=document.getRootElement();

Element book=(Element)root.element("").get(1);

String value=book.element("书名").attribute("name").getValue();

System.out.println(value);

}*/

@Test

publicvoid add() throws DocumentException, IOException{

SAXReader reader=new SAXReader();

Document document=reader.read(new File("src/book.xml"));

Element book=document.getRootElement().element("");

book.addElement("售价").setText("209");

OutputFormat format=OutputFormat.createPrettyPrint();

format.setEncoding("UTF-8");

XMLWriter writer=new XMLWriter(new FileOutputStream("src/book.xml"),format);

writer.write(document);

writer.close();

}

}

//在第一本书指定位置添加一个新的售价:<售价>209</售价>--更改保存了所有孩子的list集合的顺序

@Test

publicvoid add2() throws DocumentException, IOException{

SAXReader reader=new SAXReader();

Document document=reader.read(new File("src/book.xml"));

Element book=document.getRootElement().element("");

List list=book.elements();

Element price=DocumentHelper.createElement("售价");

price.setText("309");

list.add(2,price);

OutputFormat format=OutputFormat.createPrettyPrint();

format.setEncoding("UTF-8");

XMLWriter writer=new XMLWriter(new FileOutputStream("src/book.xml"),format);

writer.write(document);

writer.close();

}

//删除指定节点

@Test

publicvoid delete() throws DocumentException, IOException{

SAXReader reader=new SAXReader();

Document document=reader.read(new File("src/book.xml"));

Element price=document.getRootElement().element("").element("售价");

price.getParent().remove(price);

OutputFormat format=OutputFormat.createPrettyPrint();

format.setEncoding("UTF-8");

XMLWriter writer= new XMLWriter(new FileOutputStream("src/book.xml"),format);

writer.write(document);

writer.close();

}

//更新信息

publicvoid update() throws Exception{

SAXReader reader=new SAXReader();

Document document=reader.read(new File("src/book.xml"));

Element book=(Element) document.getRootElement().elements("").get(1);

book.element("作者").setText("黎活明");

OutputFormat format=OutputFormat.createPrettyPrint();

format.setEncoding("UTF-8");

XMLWriter writer= new XMLWriter(new FileOutputStream("src/book.xml"),format);

writer.write(document);

writer.close();

}

XPath

XPath模拟登陆

publicclass Demo5 {

publicstaticvoid main(String[] args) throws Exception{

String username="aaa";

String password="123";

//检测XML文档是否有匹配的用户名和密码

SAXReader reader=new SAXReader();

Document document=reader.read(new File("src/users.xml"));

Node node=document.selectSingleNode("//user[@username='"+username+"' and @password='"+password+"']");

if(node==null){

System.out.println("您输入的用户名或密码有误");

}

else{

System.out.println("登陆成功");

}

}

}

XML Schema

XML Schema文件自身就是一个XML文件,扩展名为.xsd

一个XML Schema文档通常称之为模式文档(约束文档),遵循这个文档书写的XML文件称之为实例文档!

XML Schema中,每个约束模式文档都可以被赋以一个唯一的名称空间,名称空间用一个唯一的URIUniform Resource Identifier,统一资源标识符)表示。

Schema 语法:

定义简单元素:<xs:element name=”XXXX” type=”yyy”/>

XXX:元素的名称,yyy:元素的数据类型

最常用的类型:

xs:string /xs:decimal/xs:integer/xs:boolean/xs:date/xs:time

一道打印M的面试题(平面图形题--通用解题方案:利用二维数组)

publicclass MTest {

publicstaticvoid main(String[] args){

int x=2;

int y=0;

boolean flag=true;

int arr[][]=newint[3][9];

for(int i=1;i<=9;i++){

arr[x][y]=i;

y++;

if(flag==false){

x--;

}

if(flag==true){

x++;

}

if(x<0){

flag=true;

x+=2;

}

if(x>2){

flag=false;

x-=2;

}

}

for(int i=0;i<arr.length;i++){

for(int j=0;j<arr[i].length;j++){

if(arr[i][j]==0){

System.out.print(" ");

}else{

System.out.print(arr[i][j]);

}

}

System.out.println();

}

}

}

---------------------- android培训java培训、期待与您交流! ----------------------详细请查看:http://edu.youkuaiyun.com/heima

### 使用SSM框架开发云借阅图书管理系统的教程 #### 1. 系统概述 基于SSM(Spring, Spring MVC, MyBatis)框架构建的云借阅图书管理系统是一个典型的三层架构应用程序。该系统不仅能够满足图书馆日常管理和读者服务需求,而且可以部署到云端提供更广泛的服务范围[^1]。 #### 2. 技术栈介绍 - **前端技术**:HTML/CSS/JavaScript用于页面展示;JQuery简化DOM操作。 - **后端技术**:采用Java语言编写业务逻辑层和服务接口;利用MyBatis实现数据持久化访问数据库中的书籍信息表、会员资料库等实体对象映射关系处理。 - **中间件配置**:Tomcat服务器承载Web应用发布上线运行环境搭建工作;MySQL数据库存储所有必要的元数据记录支持高效查询检索机制建立。 #### 3. 关键组件解析 ##### 3.1 Controller 控制器类设计 控制器负责接收HTTP请求并调用相应Service方法来执行具体的操作流程。例如,在`BookController.java`文件里定义了针对书籍资源的各种RESTful API路径映射规则: ```java @Controller @RequestMapping("/books") public class BookController { @Autowired private IBookService bookService; @GetMapping("/{id}") public String getBookById(@PathVariable Integer id, Model model){ Book book = this.bookService.selectByPrimaryKey(id); model.addAttribute("book", book); return "show"; } } ``` 此处代码片段展示了如何获取单本图书详情的功能实现方式[^2]。 ##### 3.2 Service 层的设计模式 为了提高代码可维护性和扩展性,通常会在service包下创建多个接口及其对应的实现类来进行分层解耦合。比如下面这段伪代码描述了一个简单的增删改查CRUD操作模板: ```java @Service @Transactional(readOnly=true) public interface IUserService extends IService<User> {} @Service @Transactional(rollbackFor=Exception.class) class UserServiceImpl implements IUserService{ @Override public List<User> selectAll(){ //... } @Override @Transactional(readOnly=false) public int insert(User user){ //... } } ``` 这里通过声明式事务管理确保每次修改操作都能安全可靠地提交至DBMS中保存下来。 ##### 3.3 Mapper 映射文件说明 MyBatis的核心在于SQL语句与POJO之间的转换桥梁作用。因此需要为每一个DAO写好XML形式的结果集映射文档,像这样: ```xml <mapper namespace="com.example.mapper.BookMapper"> <!-- 查询全部 --> <select id="selectAllBooks" resultType="com.example.model.Book"> SELECT * FROM t_book; </select> <!-- 插入新纪录 --> <insert id="addNewBook" parameterType="com.example.model.Book" useGeneratedKeys="true" keyProperty="id"> INSERT INTO t_book(title, author,...) VALUES (#{title}, #{author},...); </insert> </mapper> ``` 上述例子给出了基本的数据存取API原型供开发者快速上手实践。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值