本篇文章给大家谈谈javaxml文件头,以及java 文件头对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
1、java如何读取xml文件2、详解 xml 文件头部的 xmlns:xsi3、JAVA 读取XML文件4、spring的xml配置文件的xml文件头详解5、java怎么解析xml文件?
java如何读取xml文件
xml解析还是用dom4j方便,
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class XMLPaser {
public static void main(String[] args) {
paserXML();
}
public static void paserXML(){
SAXReader reader = new SAXReader();
try {
// 读取XML文件
Document doc = reader.read(“NewFile.xml”);
Element root = doc.getRootElement();
System.out.println(root.getName());
ListElement param = root.elements();
for (Element element : param) {
if(element.attributeValue(“name”).equals(“a”)){
System.out.println(element.getText());
}
}
} catch (DocumentException e) {
e.printStackTrace();
}
}
}
详解 xml 文件头部的 xmlns:xsi
原文在此,写的比较通俗易懂,特转发一下,向原作者致敬~
一套Xml中元素的定义规范;
指定xml文档中元素所隶属的命名空间;
一个XSD的实例,就好比new了一个object 出来;
上面这行的语法其实是, xsi:schemaLocation = “键” “值”,用来说明XSD的命名空间和定义文件;
初学者看到如上的内容应当有如下困惑点:
一个 xml 文档中如果包含如下两种定义不同, 但是名称相同的元素, xml 解析器是无法解析的, 因为它不能确定当你调用 document.getElementsByTagName(“book”) 时应该返回哪个元素。
显然, 如果给他们的名字添加一个前缀, 则命名冲突的问题就可以解决。
但是, 在一个拥有众多元素的文档中, 仅仅拥有前缀, 也不能完全避免命名冲突的问题。
此时, 命名空间就诞生了, 我们可以为元素定义一个命名空间, 将一个很长的, 可以保证 全局唯一性的字符串 与该元素关联起来。这样就可以避免命名冲突了。
但是如何保证那个较长的字符串全局唯一呢, 最好的方式莫过于使用 统一资源标识符(Uniform Resource Identifier,URI) 了, 而我们最常见的 URI 就是平时经常访问的网址 URL 了。
应用到我们所举的例子中就是:
回到我们的 POM 文档头中,你会发现 project xmlns:xsi=”” 中的 可以访问到一个正常的页面, 但是如果访问 xmlns=”” 中的 就会得到一个 PAGE NOT FOUND 错误, 页面未获取到。
细心的童鞋会注意到, project 元素前面并没有前缀。 这里实际上使用的是 默认命名空间(default naming space) 。 它的语法如下:
例如我们的 project 元素定义 和下面的例子
使用默认命名空间的作用是, 该元素内部的子元素都会默认属于该命名空间下, 我们不需要为他们一一添加命名空间前缀。
现在来看文件头中剩下的, 看上去更为复杂的部分。
根据之前的知识我们可以理解, xmlns:xsi 定义了一个命名空间前缀 xsi 对应的唯一字符串 。 但是读者会发现, 这个 xmlns:xsi 在不同的 xml 文档中似乎都会出现。 这是因为, xsi 已经成为了一个业界默认的用于 XSD((XML Schema Definition) 文件的命名空间。 而 XSD 文件(也常常称为 Schema 文件)是用来定义 xml 文档结构的。
那么, 有了上述的理解, 再来看
上面这行的语法其实是, xsi:schemaLocation = “键” “值”
即 xsi 命名空间下 schemaLocation 元素的值为一个由空格分开的键值对。
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++; //原来这里少些了这一行,先补上
}
}
}
spring的xml配置文件的xml文件头详解
在spring的xml配置文件中,在头部会出现如下的东西
这些奇怪的xmlns和很长的url的作用是什么呢?
首先,介绍一下 xmlns 的作用,如下所示,一个 xml 文档中如果包含如下两种定义不同, 但是名称相同的元素, xml 解析器是无法解析的, 因为它不能确定当你调用document.getElementsByTagName(“book”) 时应该返回哪个元素。
这时候可以通过在名称增加前缀解决这个问题
由此,引入一个概念 命名空间 ,通过增加前缀表示不同的那是不同命名空间下的table,从而解决了矛盾,但是不同的人都有自己创建的不同的命名空间来描述同样的东西,不利于xml文件信息的解析,比如说,同样都是水果,可以从颜色和香味不同角度来定义成如下两种形式:
为此,w3c(万维网联盟)对于一些类型,定义了对应的命名空间和这些类型的标准,xml解释器碰到这些类型的时候就会通过这些标准去解析这类型的标签,为了确保命名空间的唯一,所以不同的命名空间的通常使用URL作为被识别的id,如下例子:
这句话的作用是当前引入了一个叫做xsi的命名空间,xsi可以在接下来要使用该命名空间时所使用的,如下:
而 这个很长的字符串,则是xsi这个名称空间被xml解释器内部所识别的时候所真正使用的id,但也本身只是被当做一个字符串名字去处理,xml解释器根据这个id去获取它对应的标准,从而知道这个命名空间定义有什么样的标签(xml解释器自带有一些通用的命名空间的标准),这个字符串虽然看起来是URL,但是和对应的网页上的信息没有关系,只是用来提供命名空间 唯一性 的作用,网址有时可以被打开,上面会有关于该命名空间的信息。
所以,spring配置文件中这三句话分别表示,引入了三个命名空间。
其中第一个xmlns后面没有空间名的,表示引入了一个默认的名称空间,下文中不使用命名空间前缀的都默认使用这个命名空间,这个默认的命名空间,其真正的id是 ” ” 。
引入的第二个命名空间叫做xsi,其真正的id是 ” ”
引入的第三个命名空间叫做context,其真正的id是 ” ”
在最后可以看到xsi:schemaLocation,这句话的意思表示使用命名空间xsi下的schemaLocatioin,设置了它对应的值为后面很多很多的URL,schemaLocation中存储的值每两个为一组, 第一个代表命名空间,第二个代表该命名空间的标准的文件位置 ,如下所示,这句话就是说明命名空间 的标准文件是 *
因为xml解释器不一定含有所有命名空间的标准,通过这样设置就可以告诉xml解释器不同命名空间的对应的标准是什么了,而这也是xsi这个命名空间的作用,要用到其schemaLocation。
最后,对应一般的xml解释器的工作流程中,xml解释器识别到有 “ ” 这个通用的名称空间后,明白知道要引入一些不同命名空间,就会从其schemaLocation中获取不同命名空间和其对应的标准。
java怎么解析xml文件?
String xml=”xmlToUserName![CDATA[toUser]]/ToUserName”
+”FromUserName![CDATA[fromUser]]/FromUserName”
+”CreateTime12345678/CreateTime”
+”MsgType![CDATA[text]]/MsgType”
+”Content![CDATA[你好]]/Content/xml”;
try {
//加载xml字符串
org.dom4j.Document document=org.dom4j.DocumentHelper.parseText(xml);
//获取根节点
org.dom4j.Element root=document.getRootElement();
//获取值 ==toUser
String toUserName=root.elementText(“ToUserName”);
System.out.println(toUserName);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
关于javaxml文件头和java 文件头的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。