xml&Tomcat
xml
作用:
1. 保存数据
2. 配置文件
3. 数据传输载体
定义:就是一个文件,后缀为.xml
文档声明:
- 简单声明,version:解析这个xml的时候,使用什么版本的解析器解析
<?xml version="1.0" ?>
- encording:解析xml中的文字的时候,使用什么解码来翻译
<?xml version="1.0" encording="gbk" ?>
- standalone:no - 该文档会依赖关联其他文档,yes - 这是一个独立的文档
<?xml version="1.0" encording="gbk" standalone="no" ?>
xml命名规则:
标签可以自定义
xml元素必须遵循以下命名规则:
名称可以含字母、数字以及其他的字符
名称不能以数字或者标点符号开始
名称不能以字符“xml”(或者XML、Xml)开始
名称不能包含空格
命名进尽量简单,见名知意
简单元素 & 复杂元素
简单元素:元素里面包含了普通的文字
复杂元素:元素里面还可以嵌套其他的元素
属性的定义
定义在元素里面,<元素名称 属性名称="属性的值"></元素名称>
xml注释:
与html的注释一样,但是xml的注释不允许放在文档的第一行,必须在文档声明的下面
<?xml version="1.0" encoding="UTF-8"?>
<!-- 这里有两个学生,一个叫张三一个叫李四 -->
<stus>
<stu id="10086">
<name>张三</name>
<age>24</age>
</stu>
<stu d="10086">
<name>李四</name>
<age>23</age>
</stu>
</stus>
CDATA区*非法字符
严格的讲,在xml中仅有字符"<"和"&"非法的。省略号、引号和大于号都是合法的,可以把他们替换成实体引用
< <
& &
如果某段字符串里面有过多的字符,并且里面包含了类似标签或者关键字的这种文字,不想让xml的解析器去解析,那么可以使用CDATA来包装,不过这个CDATA一般比较少看到,通常在服务器给客户段返回数据的时候
<des><!CDATA[<a=href="http://www.baidu.com">百度搜索</a>]]></des>
xml解析
获取元素里面的字符数据或者属性数据
解析方式(面试常问,有很多种常用种,常用两种)
DOM:document object model把整个xml全部读到内存当中,形成树状结构。整个文档称之为document对象,属性对应Attribute对象,所有的元素节点对应Element对象,文本特可以称之为Text对象,以上所有对象都可以称之为Node节点。如果xml特别大,那么将会造成内存溢出。可以对文档进行增删操作
SAX:Simple API for Xml 基于时间驱动。读取一行,解析一行,不会造成内存溢出,不可以进行增删,只能查询
针对以上两种解析方式的API,一些组织或者公司给出的解决方案:
jaxp sun公司 比较繁琐
jdom
dom4j 使用比较广泛
Dom4j基本用法
导入dom4j的jar包放在文件夹lib中buil path---add to buildpath
注意这里如果项目前面红色感叹号的问题可能是导入多余的jar包,右键工程到configure到library删除添加的jar,并把导错的压缩文件删掉,重新导入
element.element("stu"):返回该元素下的第一个元素
element.elements:返回该元素下的所有
1. 创建SaxReader对象
2. 指定解析的xml
3. 获取根元素
4. 根据根元素获取子元素或者下面的子孙元素
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class MainTest {
public static void main(String[] args) {
try {
//1.创建sax读取对象
SAXReader reader=new SAXReader();
//2.指定解析的xml源
Document ducument = reader.read("src/xml/stus.xml");
//3.得到根元素
Element rootElement = ducument.getRootElement();
/*4.得到根元素下面的子元素,根据stu标签名得到根元素stus下面第一个stu元素,
* 再通过stu获得下面age元素中的文本*/
System.out.println(rootElement.element("stu").element("age").getText());
//得到根元素下面的所有子元素,但不包括孙元素
List<Element> elements = rootElement.elements();
//再根据子元素获得下面的孙元素
for (Element element:elements) {
String name = element.element("name").getText();
String age = element.element("age").getText();
System.out.println("name="+name+" age="+age);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
XPath
xpath是xml的路径语言,支持在解析xml的时候,能够快速定位到具体的某一个元素
- 添加jar包依赖
导入jar包放在文件夹lib中buil path---add to buildpath
2.在查找指定节点的时候,根据XPath语法规则来查找(参考ZVON.org - XPath Tutorial中文手册)
路径以斜线 / 开始, 那么该路径就表示到一个元素的绝对路径;/AAA 选择根元素AAA ;/AAA/CCC 选择AAA的所有CCC子元素
路径以双斜线 // 开头, 则表示选择文档中所有满足双斜线//之后规则的元素(无论层级关系);//BBB 选择所有BBB元素 ;//DDD/BBB 选择所有父元素是DDD的BBB元素
3.后续的解析代码一样
import java.util.List;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class XPathTest {
public static void main(String[] args) {
try {
//1.创建sax读取对象
SAXReader reader=new SAXReader();
//2.指定解析的xml源
Document ducument = reader.read("src/xml/stus.xml");
//3.得到根元素
Element rootElement = ducument.getRootElement();
//若想使用XPath,需要先添加jar包 ,获取第一个,只返回一个name
Element nameElement =(Element)rootElement.selectSingleNode("//name");
System.out.println(nameElement.getStringValue());
//不论层级获得所有的age元素的集合
List<Element> list = rootElement.selectNodes("//age");
for (Element element : list) {
System.out.println(element.getText());
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
xml的约束
如下文档,属性的ID值是一样的,并且学生的姓名有好几个,一般生活中不可能出现或者很少。规定ID的唯一值、规定元素只能出现一次甚至只能出现具体的元素的名字,就是xml的文档约束
DTD
语法自成一派,文档类型定义(DTD)可定义合法的XML文档构建模块。它使用一系列合法的元素来定义文档的结构。 DTD 可被成行地声明于 XML 文档中,也可作为一个外部引用。
声明元素:<!ELEMENT 元素名称 类别> 或者 <!ELEMENT 元素名称 (元素内容)>
声明属性:<!ATTLIST 元素名称 属性名称 属性类型 默认值>
<?xml version="1.0" encoding="UTF-8"?>
1.引入网络上的DTD
<!-- 引入dtd来约束这个文档-->
<!-- 文档类型 根标签名字 网络上的dtd dtd的名称 dtd的路径
<!DOCTYPE stus PUBLIC "//UNKNOWN/" "unknown.dtd"> -->
2.引入本地的DTD
<!-- 引入本地dtd的:根标签的名字 引入本地的dtd dtd的位置
<!DOCTYPE stus SYSTEM "stus.dtd"> -->
3.直接在xml里面嵌入DTD的约束规则
<!-- xml文档里面直接嵌入dtd的约束法则 -->
<!DOCTYPE stus [
<!ELEMENT stus (stu)>
<!ELEMENT stu (name.age)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT age (#PCDATA)>
]>
<stus>
<stu id="10086">
<name>张三</name>
<age>24</age>
</stu>
<stu d="10086">
<name>李四</name>
<age>23</age>
</stu>
</stus>
<!ELEMENT stus (stu)+> stus下面有一个stu元素,但是只有一个
<!ELEMENT stu (name , age)> stu下面有两个元素name,age,顺序必须是name-age
<!ELEMENT name (#PCDATA)>
<!ELEMENT age (#PCDATA)>
<ATTLIST stu id CDATA #IMPLIED> stu有一个属性,文本类型,该属性可有可无
元素的个数:
+ 一个或者多个
* 零个或者多个
? 零个或者一个
属性的类型定义
CDATA:属性是普通文字
ID:属性值必须唯一
<!ELEMENT stu (name , age)> 按照顺序来
<!ELEMENT stu (name | age)> 两个中只能包含一个元素
Schema
其实是一个xml,使用xml语法规则,xml解析器解析起来比较方便,是为了替代DTD,但是Schema约束文本内容比DTD的内容还要多,所以目前没有真正意义上的替代
<?xml version="1.0" encoding="UTF-8"?>
<!-- xmlns xml namespace:名称空间/命名空间
targetNamespace:目标名称空间,下面定义不得那些元素都与这个名称空间绑定上
elementFormDefault:元素的格式化情况 -->
<schema xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.example.org/teacher"
elementFormDefault="qualified">
<element name="teachers">
<complexType>
<sequence maxOccurs="unbounded">
<!-- 这是一个复杂元素 -->
<element name="teacher">
<!-- 用于声明这个teacher元素是复杂元素 -->
<complexType>
<!-- 用于声明以下是有序的 -->
<sequence>
<!-- 以下两个是简单元素 -->
<element name="name" type="string"></element>
<element name="age" type="int"></element>
</sequence>
</complexType>
</element>
</sequence>
</complexType>
</element>
</schema>
xml
<?xml version="1.0" encoding="UTF-8"?>
<!-- xmlns:xsi 这里必须是这样的写法,固定的
xmlns 这是名称空间。也固定了,写的是schema里面的顶部目标名称空间
xsi:schemalocation 有两段:前半段是名称空间也是目标空间的值,后面是约束文档的路径 -->
<teachers
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.example.org/teacher"
xsi:schemalocation="http://www.example.org/teacher teacher.xsd"
>
<teacher>
<name>张三</name>name>
<age>29</age>
</teacher>
<teacher>
<name>张三</name>name>
<age>29</age>
</teacher>
<teacher>
<name>张三</name>name>
<age>29</age>
</teacher>
</teachers>
名称空间的作用
一个xml如果想指定它的约束规则,假设使用的是DTD,那这个xml只能指定一个DTD,不能饿指定多个DTD。但是如果一个xml的约束是定义在schema里面,并且是多个schema ,那么是可以的。简单的说:一个xml可以引用多个schema约束但是只能引用一个DTD约束。
名称空间的作用就是在写元素的时候可以指定元素使用的是哪一套约束规则。 默认情况下,如果只有一套规则,那么都可以写
<name>张三</name>name>
<aa:name></name>name>
<aa:name></name>name>
程序架构
C/S(client/server)
QQ 微信 LOL
优点:
有一部分代码写在客户端,用户体验较好
缺点:
服务器更新,客户端也要随着更新。占用资源大。
B/S(broeser/server)
网页游戏 WebQQ ...
优点:
客户端只要有浏览器就可以了,占用资源小,不用更新
缺点:
用户体验不佳
服务器
其实服务器就是一台电脑,配置比一般的要好
Web服务器软件
客户端在浏览器的地址栏上输入地址,然后web服务器软件接收请求,响应消息。
处理客户端的请求,返回资源|信息
Web应用 需要服务器支撑,常见的有
Tomcat apache
WebLogic BEA
Websphere IBM
IIS 微软
Tomcat安装
官网下载-解压-bin文件夹-startup.bat双击-出现黑窗口显示信息即为安装成功。为了确保万无一失,最好在浏览器的地址栏上输入http://localhost:8080 ,如果有看到内容说明安装成功
如果双击了startup.bat,看到一闪而过的情形,一般都是JDK的环境变量没有配置
问题记录:安装不成功,解决:在盘目录下新建一个文件夹,把下载安装包放到这个文件夹解压到当前文件夹再操作
Tomcat目录介绍
bin
包含了一些jar,bat文件。 startup.bat
conf
tomcat的配置 server.xml web.xml
lib
tomcat运行所需的jar文件
logs
运行的日志文件
temp
临时文件
webapps
发布到tomcat服务器上的项目,就存放在这个目录
work
jsp翻译成class文件存放地
发布项目到tomcat
需求:如何能让其他的狄安娜访问我这台电脑上的资源 stus.xml
1. 拷贝这个文件到webapps/ROOT下,在浏览器里面访问:(用的比较多)
http://localhost:8080/stu.xml
*在webapps下面新建一个文件夹xml,然后拷贝文件放在这个文件夹中,在浏览器里面访问:
http://localhost:8080/xml/stu.xml
http://localhost:8080 是对应到webapps/root
http://localhost:8080/xml/ 是对应到webapps/xml
使用IP地址访问
http://192.168.1.7:8080/XML/stus.xml
2. 配置虚拟路径
- 使用localhost:8080 打开tomcat首页,在左侧找到tomcat的文档入口,点击进去找到context
ocumentation-Tomcat 7.0 Configuration --> Containers-Context
http://localhost:8080/docs/config/context.html
-
找到Defining a context按照要求修改tomcat中的conf/server.xml,找到host元素节点,加入以下内容
<!-- docBace :项目的路径地址 如D:\xml\teacher.xml path :对应的虚拟路径,一定要以/开头 对应的访问方式为:http://localhost:8080/a/teacher.xml --> <Context docBase="D:\xml" path="/a"></Context>
- 在浏览器地址栏输入:http://localhost:8080/a/teacher.xml
问题记录:配置无法实现访问,发现是电脑版本不同导致修改txt文档为xml的时候没有修改过来因此无法访问
3. 配置虚拟路径
-
在tomcat/conf/catalina/localhost/文件夹下新建一个xml文件,名字可以自己定义 teacher.xml
-
在这个文件里面写入以下内容
<?xml version="1.0" encoding="UTF-8"?> <Context docBase="D:\xml"></Context>
-
在浏览器上面访问http://localhost:8080/teacher/xml的名字 即可
问题记录:同上
给eclipse配置tomcat
1. java ee窗口下,配置server
- servers右键新建server选择tomcat版本--选择tomcat安装路径,右键打开配置好的服务器找到server location选中use tomcat installation
- 也可以windows -- preference -- server -- runtime environment -- add -- 选择对应版本
2. 新建一个web工程
- 右键new -- other -- web -- dynamic web project -- next -- 命名新建一个web工程HelloWeb--版本--弹出窗口--yes
- 打开HelloWeb-webcontent-右键new新建一个html,hello.html
- 右键工程run on servert出现窗口选择--finish,在浏览器中访问localhost:8080/HelloWeb/hello.html 即可访问文件的内容
问题记录:配置无法访问,原因访问的文件放错了位置,应该放在WebContent目录下访问,WEB-INF是安全目录,客户端无法访问,只有服务端可以访问,方便开发者查看资源
总结
xml
定义
解析 dom4j解析 XPath解析
tomcat
会安装,会启动,会访问
会设置虚拟路径
给eclipse配置tomcat