XML

Extensible Markup Language 可扩展标记语言

功能:配置文件,在网络中传输

基本语法
1.xml文档的后缀名.xml
2.xml第一行必须定义为文档声明
3.xml文档中有且仅有一个跟标签
4.属性值使用引号引起来
5.标签必须正确关闭
6.xml标签名称区分大小写
<?xml version='1.0' ?>

<users>
<user id='1'>
<name>张三</name>
<age>23</age>
<gender>male</gender>
</user> <user id='2'>
<name>李四</name>
<age>24</age>
<gender>female</gender>
<code>
<!--CDATA区的code会原样展示-->
<![CDATA[if(a<b&&a>c){}]]>
</code>
</user>
</users>
约束 :规定xml文档的书写规则
dtd约束:

dtd约束

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE students SYSTEM "student.dtd"> <students>
<student number="s001">
<name>张三</name>
<age>23</age>
<sex>男</sex>
</student> <student number="s002">
<name>李四</name>
<age>24</age>
<sex>女</sex>
</student>
</students>
引入schema文档

<?xml version="1.0" encoding="UTF-8" ?>
<!--
1.填写xml文档的根元素
2.引入xsi前缀. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
3.引入xsd文件命名空间. xsi:schemaLocation="http://www.itcast.cn/xml student.xsd"
4.为每一个xsd约束声明一个前缀,作为标识 xmlns="http://www.itcast.cn/xml" -->
<students xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.itcast.cn/xml"
xsi:schemaLocation="http://www.itcast.cn/xml student.xsd"
>
<student number="heima_0001">
<name>tom</name>
<age>18</age>
<sex>male</sex>
</student> </students>
<?xml version="1.0"?>
<xsd:schema xmlns="http://www.itcast.cn/xml"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.itcast.cn/xml" elementFormDefault="qualified">
<xsd:element name="students" type="studentsType"/>
<xsd:complexType name="studentsType">
<xsd:sequence>
<xsd:element name="student" type="studentType" minOccurs="0" maxOccurs="unbounded"/>
</xsd:sequence>
</xsd:complexType>
<xsd:complexType name="studentType">
<xsd:sequence>
<xsd:element name="name" type="xsd:string"/>
<xsd:element name="age" type="ageType" />
<xsd:element name="sex" type="sexType" />
</xsd:sequence>
<xsd:attribute name="number" type="numberType" use="required"/>
</xsd:complexType>
<xsd:simpleType name="sexType">
<xsd:restriction base="xsd:string">
<xsd:enumeration value="male"/>
<xsd:enumeration value="female"/>
</xsd:restriction>
</xsd:simpleType>
<xsd:simpleType name="ageType">
<xsd:restriction base="xsd:integer">
<xsd:minInclusive value="0"/>
<xsd:maxInclusive value="256"/>
</xsd:restriction>
</xsd:simpleType>
<xsd:simpleType name="numberType">
<xsd:restriction base="xsd:string">
<xsd:pattern value="heima_\d{4}"/>
</xsd:restriction>
</xsd:simpleType>
</xsd:schema>
xml_解析

操作xml文档,将文档中的数据读取到内存中

解析方式:

1.DOM:将标记语言文档一次性加载进内存,在内存中形成一个dom数

2.SAX:逐行读取,基于事件驱动的

常见解析器:

1.JAXP 2.DOM4J 3.Jsoup。

Jsoup使用步骤

1.导入jar包

2.获取Document对象

3.获取对应的标签

4.获取数据

<?xml version="1.0" encoding="UTF-8" ?>
<students>
<student number="s001">
<name id="a">张三</name>
<age>23</age>
<sex>男</sex>
</student> <student number="s002">
<name>李四</name>
<age>24</age>
<sex>女</sex>
</student>
</students>
package data;

import org.jsoup.Jsoup;

import  org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements; import java.io.File;
import java.net.URL; public class jsoupDemo1 {
public static void main(String[] args) {
//获取student.xml的path
//可以使用字节码对象来获取类加载器
Class ac1ass = jsoupDemo1.class;
ClassLoader aclassLoader=ac1ass.getClassLoader();
//获取资源位置
URL aurl=aclassLoader.getResource("student.xml");
//获取字符串表示形式的路径
String path = aurl.getPath();
//解析xml文档,加载文档进内存,获取dom树
//parse方法需要一个File对象和字符集作为参数
//parde返回的是一个Document对象
try {
Document aDocument=Jsoup.parse(new File(path),"utf-8");
//获取元素对象
Elements aElement=aDocument.getElementsByTag("name");
System.out.println(aElement.size());
Element element=aElement.get(0);
System.out.println(element);
System.out.println("----------------");
//通过标签属性名来获取元素
Elements aElements1 = aDocument.getElementsByAttribute("id");
System.out.println(aElements1);
} catch (Exception e) {
e.printStackTrace();
} }
}

快捷查询方式:

1.selector,选择器

2.xpath;

选择器的演示

package data;

import org.jsoup.Jsoup;

import  org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements; import java.io.File;
import java.net.URL; public class jsoupDemo1 {
public static void main(String[] args) {
//获取student.xml的path
//可以使用字节码对象来获取类加载器
Class ac1ass = jsoupDemo1.class;
ClassLoader aclassLoader=ac1ass.getClassLoader();
//获取资源位置
URL aurl=aclassLoader.getResource("student.xml");
//获取字符串表示形式的路径
String path = aurl.getPath();
//解析xml文档,加载文档进内存,获取dom树
//parse方法需要一个File对象和字符集作为参数
//parde返回的是一个Document对象
try {
Document aDocument=Jsoup.parse(new File(path),"utf-8");
//查询name标签
Elements elements = aDocument.select("name");
System.out.println(elements+"通过标签查找");
System.out.println("=====================================");
//查询属性id值为a
Elements elements1 =aDocument.select("#a");
System.out.println(elements1+"通过属性值a查找");
System.out.println("=========================================");
//获取student标签下的属性值为s002下的age
Elements elements2 = aDocument.select("student[number=s002]>age");
System.out.println(elements2);
System.out.println("===========================================");
//只要纯文本
String s1 = elements2.text();
System.out.println(s1);
} catch (Exception e) {
e.printStackTrace();
} }
}

XPath的演示(需要额外导入jar包)

package data;

import cn.wanghaomiao.xpath.exception.XpathSyntaxErrorException;
import cn.wanghaomiao.xpath.model.JXDocument;
import cn.wanghaomiao.xpath.model.JXNode;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document; import java.io.File;
import java.io.IOException;
import java.util.List; public class jsoupDemo4 {
public static void main(String[] args) throws IOException {
String path = jsoupDemo4.class.getClassLoader().getResource("student.xml").getPath();
Document document = Jsoup.parse(new File(path) ,"utf-8");
//创建JXDocument对象
JXDocument jxDocument = new JXDocument(document);
//结合XPath语法查询
//查询所有student标签
try {
List<JXNode> jxNodes = jxDocument.selN("//student");
for(JXNode jxNode:jxNodes){
System.out.println(jxNode);
}
System.out.println("===========================");
//查询student标签下带有属性的name标签
List<JXNode> jxNodes1 = jxDocument.selN("//student/name[@id]");
for(JXNode jxNode:jxNodes1){
System.out.println(jxNode);
}
} catch (XpathSyntaxErrorException e) { e.printStackTrace();
}
}
}
tomcat

web服务器软件

配置

部署项目的方式

第一种方式.直接将项目放在webapps目录下

第二种方式:配置conf/server.xml文件,在标签中配置

第三种方式:在conf\catalina\localhost创建任意名称的xml文件,在文件中编写虚拟的目录

第三种部署项目方式演示

笔记-JavaWeb学习之旅9的更多相关文章

  1. 笔记-JavaWeb学习之旅5

    CP30的演示 package cn.itcast.datasourcejdbc; import com.mchange.v2.c3p0.ComboPooledDataSource; import j ...

  2. 笔记-JavaWeb学习之旅7

    JavaScript基础 概念:一门客户端脚本语言,运行在客户端浏览器中,每一个浏览器都有JavaScript的解析引擎,是一个脚本语言,不需要编译,直接就可以被浏览器解析执行. JavaScript ...

  3. 笔记-JavaWeb学习之旅19

    Redis:redis是一款高性能的NOSQL系列的非关系型数据库 NOSQL: Not Only SQL ,意即"不仅仅是SQL",是一项全新的数据库理念,泛指非关系型数据库 r ...

  4. 笔记-JavaWeb学习之旅18

    AJAX:ASynchronous JavaScript And XML 异步的JavaScript 和XML 异步和同步:客户端和服务器端相互通信的基础上 同步:客户端操作后必须等待服务器端的响应, ...

  5. 笔记-JavaWeb学习之旅17

    1.过滤选择器 首元素选择器:first 获得选择的元素中的第一个元素 尾元素选择器:last获得选择元素中的最后一个元素 非元素选择器:not(selector) 不包括指定内容的元素 偶数选择器: ...

  6. 笔记-JavaWeb学习之旅16

    增强对象的功能 动态代理:在内存中形成代理类 实现步骤: 代理对象和真实对象实现相同的接口 代理对象 = Proxy.newProxyInstance(); 使用代理对象调用真实对象的方法 增强方法 ...

  7. 笔记-JavaWeb学习之旅15

    Filter:过滤器 概念:当访问服务器的资源是,过滤器可以将请求拦截下来,完成一些特殊的功能 快速入门: 步骤: 定义一个类,实现接口Filter 复写方法 配置拦截路径 package com.d ...

  8. 笔记-JavaWeb学习之旅14

    JSTL:JavaServer Pages Tag Library JSP标准标签库 if标签 <%@ page import="java.util.ArrayList" % ...

  9. 笔记-JavaWeb学习之旅10

    Servlet server applet运行在服务器端的小程序,servlet就是一个接口,定义了Java类被浏览器访问到的规则(Java类重写这个接口,就可以被浏览器(tomcat)识别) Ser ...

  10. 笔记-JavaWeb学习之旅13

    验证码案列 昨天晚上出现的500错误原因在于验证码没有获取到,获取验证码是应该获取的是共享域中的验证码,而我把获取值得键给写成了jsp中的键,而不是内存生成图片中,然后把图片上传到共享域中的键.这两个 ...

随机推荐

  1. 图片转base64存储

    图片转base64存储 base64.b64encode(r.content) url='http://www.heze.cn/info/themes/heze/Public/tel/?tel=MDU ...

  2. ckeditor html标签的class 等attribute属性都被屏蔽啦,替换成空的解决方案

    ckeditor 模块中自定义class 在ckeditor模块中,编辑内容时, 在源码中填写<div class="myclass">some content< ...

  3. Redis C语言操作封装

    #ifndef BOYAA_FOURLANDLORD_REDISCLASS_H_20130217 #define BOYAA_FOURLANDLORD_REDISCLASS_H_20130217 #i ...

  4. C++中如何计算程序运行的时间 (转载)

    转载地址:http://blog.csdn.net/wuxuguang123/article/details/8130081 一 个程序的功能通常有很多种方法来实现,怎么样的程序才算得上最优呢?举个例 ...

  5. 人生苦短之Python迭代器

     迭代 在Python中,如果给定一个list或者touple,我们可以通过for循环来遍历,将值依次取出,这种遍历称为迭代. 在Python中是通过for...in..来进行遍历的,在Java中则是 ...

  6. python 实用pickle序列化

    存储数据结构到一个文件中称为序列化.相json这样的格式需要定制的序列化数据的转换器.python提供了pickle模块以特殊的二进制格式保存和恢复数据对象. 还记得json解析datetime对象时 ...

  7. hdu-5734 Acperience(数学)

    题目链接: Acperience Time Limit: 4000/2000 MS (Java/Others)   Memory Limit: 65536/65536 K (Java/Others) ...

  8. java推荐书籍及下载

    前言 一直有这么个想法,列一下我个人认为在学习和使用Java过程中可以推荐一读的书籍,给初学者或者想深入的朋友一些建议,帮助成长.推荐的的都是我自己读过,也会推荐一些朋友读过并且口碑不错的书籍.以下的 ...

  9. Python的GIL是什么鬼,多线程性能究竟如何

    前言:博主在刚接触Python的时候时常听到GIL这个词,并且发现这个词经常和Python无法高效的实现多线程划上等号.本着不光要知其然,还要知其所以然的研究态度,博主搜集了各方面的资料,花了一周内几 ...

  10. vim 使用、设置笔记

    一.设置.vimrc( windows下通常为_vimrc) 1.设置vim中tab的缩进 set ts=4  (注:ts是tabstop的缩写,设TAB宽4个空格) set expandtab (注 ...