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. Hadoop实战-使用Eclipse开发Hadoop API程序(四)

    一.准备运行所需Jar包 1)avro-1.7.4.jar 2)commons-cli-1.2.jar 3)commons-codec-1.4.jar 4)commons-collections-3. ...

  2. SpringBoot-(5)-properties的使用

    项目中经常需要进行一些配置,一般会使用springboot默认的application.properties文件,也可以自己创建配置文件 一,application.properties配置 logg ...

  3. UVA10655 Contemplation! Algebra —— 推公式、矩阵快速幂

    题目链接:https://vjudge.net/problem/UVA-10655 题意: a+b.ab的值分别为p.q,求a^n+b^n. 题解: 1.a.b未知,且直接求出a.b也不太实际. 2. ...

  4. Codeforces Round #379 (Div. 2) D. Anton and Chess —— 基础题

    题目链接:http://codeforces.com/contest/734/problem/D D. Anton and Chess time limit per test 4 seconds me ...

  5. 一套完整的前台页面增删改查以及js(easyui)

    增加页面: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEnc ...

  6. Spring MVC 和 Struts2 的区别?

    1.请求拦截级别 struts2框架是类级别的拦截,每次来了请求就创建一个Action,然后调用setter getter方法把request中的数据注入 struts2实际上是通过setter ge ...

  7. Python: PS 滤镜--水波特效

    本文用 Python 实现 PS 滤镜中的 水波特效 import numpy as np from skimage import img_as_float import matplotlib.pyp ...

  8. python中元组tuple

    python中列表(list)和元组(tuple)有很多相似的地方,它们都是容器,由一系列的对象构成,都可以包含任意类型的元素,甚至是一个序列.   list和tuple的不同首先体现在写法上: li ...

  9. Field 'CID' doesn't have a default value

    解决:在数据库客户端navicat中设计表勾选自动递增

  10. 将DotNetBar添加到工具箱中

    一.首先得安装DotNetBar; 二.在工具箱的空白处右击=====>添加选项卡(图一)======>命名为DotNetBar(图二) 图一 图二 三.右击DotNetBar====== ...