1.XML介绍
可扩展标记语言
可扩展标记语言是一种很像超文本标记语言的标记语言。
超文本标记语言旨在显示信息;而XML旨在传输信息,它是独立于软件和硬件的信息传输工具。
它被设计用来传输和存储数据.(作为配置文件)。
html就是一种xml,不过他不规范。
2书写规范:
1.区分大小写
2.应该有一个根标签
3.标签必须关闭
<xx></xx>
<xx/>空标签必须加/代表结束
4.属性必须用引号引起来,key=value的形式
<xx att="value"/>
5.标签体中的空格或者换行或者制表符等内容都是作为数据内容存在的
<xx>aa</xx>这两个不同
<xx> aa </xx>
6.特殊字符必须转义
eg: < > &
满足上面规范的文件我们称之为是一个格式良好的xml文件.可以通过浏览器浏览
后缀名:
.xml
3.xml组成部分:
1. 声明:
作用:告诉别人我是一个xml文件
格式:
<?xml ..... ?>
例如:
<?xml version="1.0" encoding="UTF-8"?>//这种ide会自动生成
<?xml version='1.0' encoding='utf-8' standalone="yes|no"?>//或者这种,不过很少用
要求:
必须在xml文件的第一行
必须顶格写
2. 元素(标签):
格式:
<xx></xx>
<xx/>
要求:
1.必须关闭
2.标签名不能 xml Xml XML 等等开头
3.标签名中不能出现" "或者":"等特殊字符.也不能加空格,加空格是属性的意思
4.必须有根标签eg:<bean>
</bean>
3. 属性:
格式:
<xx 属性名="属性值"/>
要求:
属性必须用引号引起来
4. 注释:
和html一样
<!-- 注释内容 -->
5.CDATA:
xml文件的特殊字符必须转义
通过cdataky 保证数据原样输出
格式:
<![CDATA[
原样输出的内容
]]>
4.xml解析:
解析方式:
1.sax:特点:逐行解析,只能查询.
2.dom:特点:一次性将文档加载到内容中,形成一个dom树.可以对dom树curd操作解析技术:
JAXP:sun公司提供支持DOM和SAX开发包
JDom:dom4j兄弟
jsoup:一种处理HTML特定解析开发包
★dom4j:比较常用的解析开发包,hibernate底层采用dom4j技术进行查询操作.
使用步骤:
1.导入jar包
2.创建一个核心对象 SAXReader
new SAXReader();
3.将xml文档加载到内存中形成一棵树
Document doc=reader.read(文件)
4.获取根节点
Element root=doc.getRootElement();
5.通过根节点就可以获取其他节点(文本节点,属性节点,元素节点)
获取所有的子元素
List<Element> list=root.elements()
获取元素的指定属性内容
String value=root.attributeValue("属性名");
获取子标签标签体:遍历list 获取到每一个子元素
String text=ele.elementText("子标签名称")//获取root的version属性 public class dom4jDemo { public static void main(String[] args) throws Exception { //创建核心对象 SAXReader reader = new SAXReader(); //获取dom树 Document doc = reader.read("E:\\eclipse\\day03\\xml\\web.xml"); //获取根节点 Element root=doc.getRootElement(); //获取其他节点 List<Element> list = root.elements(); //遍历集合 for (Element ele : list) { //获取servlet-name的标签体 String text = ele.elementText("servlet-name"); } //获取root的version属性值 String value = root.attributeValue("version"); System.out.println(value); } }
5.xpath解析技术(对dom4j的扩展,获取任意的节点)
依赖于dom4j
使用步骤:
1.导入jar包(dom4j和jaxen-1.1-beta-6.jar)
2.加载xml文件到内存中
3.使用api
selectNode("表达式");
selectSingleNode("表达式");
表达式的写法:
1. / 从根节点选取 2. // 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
例如一个标签下有一个id属性且有值 id=2;
//元素名[@属性名='属性值']
//元素名[@id='2']
补充:list,导包了,用到了集合public class XpathDemo { public static void main(String[] args) throws DocumentException { //加载dom树 Document doc=new SAXReader().read("E:\\eclipse\\day03\\xml\\web.xml"); //获取节点 //List<Element> list = doc.selectNodes("/web-app/servlet/servlet-name"); //Element ele = list.get(0); Element ele=(Element) doc.selectSingleNode("//servlet/servlet-name"); System.out.println(ele.getText()); } }
通过解析web.xml中的<servlet-class>后的全限定名
这个东西可以创建一个对象,调用方法 这个过程称为反射
6.反射
https://www.cnblogs.com/ysocean/category/1007230.html
1.获取对应的class对象
方式1:★
Class clazz=Class.forName("全限定名");
方式2:
Class clazz=类名.class;
方式3:
Class clazz==对象.getClass();
2.通过class对象创建一个实例对象(相当于 new 类())
Object clazz.newInstance();
3.通过class对象获取一个方法(public修饰的)
Method method=clazz.getMethod("方法名",Class .... paramType);
paramType为参数的类型
4.让方法执行:
method.invoke(Object 实例对象,Object ... 参数);
Object 实例对象:以前调用方法的对象 就是a
Object ... 参数:该方法运行时需要的参数 就是 10和30
执行这个方法 相当于
a.add(10,30);
例如:
method.invoke(a,10,30)@Test //调用空参的add方法 public void f3() throws Exception{ Class clazz = Class.forName("com.itheima.HelloMyServlet"); //通过字节码对象创建一个实例对象(相当于调用空参的构造器) HelloMyServlet a =(HelloMyServlet) clazz.newInstance(); //获取方法对象 Method method = clazz.getMethod("add"); //让方法对象执行 obj调用这个方法的实例,相当于a ,args是该方法执行时候所需要的参数 a.add() method.invoke(a);//相当于 a.add() }
RTTI,即Run-Time Type Identification,运行时类型识别。
首先需要知道类型信息在运行时是如何表示的,这是由Class对象来完成的,它包含了与类有关的信息。Class对象就是用来创建所有“常规”对象的,Java使用Class对象来执行RTTI,即使你正在执行的是类似类型转换这样的操作。
每个类都会产生一个对应的Class对象,也就是保存在.class文件。所有类都是在对其第一次使用时,动态加载到JVM的,当程序创建一个对类的静态成员的引用时,就会加载这个类。Class对象仅在需要的时候才会加载,static初始化是在类加载时进行的。
//TODO待补充
小案例:
可以通过Xpath的解析xml文件得到其中的全限定名和url-pattern里的内容
从而将他们放入到Map集合,用可以 用key value的形式得到他们
得到class对象去调用方法
7.xml约束:
作用:规定xml中可以出现那些元素及那些属性,以及他们出现的顺序.
约束的分类:
DTD约束:struts hiebernate等等
SCHEMA约束:tomcat spring等等
DTD约束
DTD约束:
和xml的关联 (一般都会提供好,复制过来即可,有时候连复制都不需要.)
方式1:内部关联
格式:
<!DOCTYPE 根元素名 [dtd语法]>
方式2:外部关联-系统关联
格式:
<!DOCTYPE 根元素名 SYSTEM "约束文件的位置">
例如:
<!DOCTYPE web-app SYSTEM "web-app_2_3.dtd">
方式3:外部关联-公共关联
格式:
<!DOCTYPE 根元素名 PUBLIC "约束文件的名称" "约束文件的位置">dtd语法(了解)
元素:
<!Element 元素名称 数据类型|包含内容>
数据类型:
#PCDATA:普通文本 使用的时候一般用()引起来
包含内容:
该元素下可以出现那些元素 用()引起来
符号:
* 出现任意次
? 出现1次或者0次
+ 出现至少1次
| 或者
() 分组
, 顺序
属性:
格式:
<!ATTLIST 元素名 属性名 属性类型 属性是否必须出现>
属性类型:
ID:唯一
CDATA:普通文本
属性是否必须出现
REQUIRED:必须出现
IMPLIED:可以不出现
一个xml文档中只能添加一个DTD约束
SCHEMA约束:可以添加多个schema约束
一个xml文档中可以添加多个schema约束
xml和schema的关联.
格式:
<根标签 xmlns="..." ...>
<根标签 xmlns:别名="..." ...>
名称空间:
关联约束文件
规定元素是来源于那个约束文件的
例如:
一个约束文件中规定 table(表格) 表格有属性 row和col
还有一个约束文件规定 table(桌子) 桌子有属性 width和height
在同一个xml中万一我把两个约束文件都导入了,
在xml中我写一个table,这个table有什么属性????
我们为了避免这种情况的发生,可以给其中的一个约束起个别名
使用的时候若是没有加别名那就代表是来自于没有别名的约束文件
例如 table(表格) 给他起个别名 xmlns:a="..."
在案例中使用 a:table 代表的是表格
若在案例中直接使用 table 代表的是桌子
在一个xml文件中只能有一个不起别名;注意: schema约束本身也是xml文件. eg: <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" 期中搞得xsi就起别名了 这个东西是spring里的xml +++++++++++++ 模板: <web-app xmlns="http://www.example.org/web-app_2_5" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.example.org/web-app_2_5 web-app_2_5.xsd" version="2.5"> xmlns:引入一个名称空间,约束文件的名称 instance:声明当前的xml文件是一个xml实例 http://www.example.org/web-app_2_5:约束的名称空间 web-app_2_5.xsd:约束文件的位置
8.tomcat
服务器:
硬件服务器和软件服务器
web服务器:
提供资源供别人访问
web:
网页的意思,资源.
web资源分类:
动态的web资源:内容有可能发生改变的
静态的web资源:内容是一成不变的.(几乎看不到)
web开发技术:
动态的web开发技术:servlet jsp php .net
静态的web开发技术:html css ....
什么叫javaweb
通过java语言编写的网页称之为javaweb
web通信机制:
基于请求响应机制.
一次请求一次响应,先有请求后有响应
常见的web服务器:
服务器名称 厂商 特点
weblogic oracle 大型的收费的支持javaee所有规范的服务器
webspere IBM 大型的收费的支持javaee所有规范的服务器
tomcat apache组织 中小型的免费的支持servlet和jsp规范的服务器
tomcat:
下载:
.tar .tar.gz: 提供给linux系统
.zip .exe:提供给window系统
安装:
解压apache-tomcat-7.0.52.zip即可
启动:
tomcat/bin目录下
双击 startup.bat
打开浏览器:
http://localhost:8080
退出:
方式1:点 x
方式2:ctrl+c
方式3:双击 shutdown.bat
tomcat目录结构:(了解)
bin:存放的可执行程序
conf:配置文件
lib:存放的是tomcat和项目运行时需要的jar包
logs:日志 注意:catalina
temp:临时文件
★★webapps:存放项目的目录
★work:存放jsp文件在运行时产生的java和class文件
web项目的目录结构:★★★
myweb(项目名称) web2.5版本标准的目录结构
|
|---- html css js image等目录或者文件
|
|---- WEB-INF(特点:通过浏览器直接访问不到 目录)
| |
| |--- lib(项目的第三方jar包)
| |--- classes(存放的是我们自定义的java文件生成的.class文件)
| |--- web.xml(当前项目的核心配置文件)
| |
访问路径:
http://主机:端口号/项目名称/资源路径
例如:我的项目 myweb
资源 myweb有一个1.html
http://localhost:80/myweb/1.html
常用的项目发布方式:(虚拟目录映射)
★方式1:将项目放到tomcat/webapps下
(了解)方式2:修改 tomcat/conf/server.xml
大概130行:
在host标签下 添加如下代码
<Context path="/项目名" docBase="项目的磁盘目录"/>
例如:
<Context path="/my" docBase="G:\myweb"/>
(了解)方式3:
在tomcat/conf/引擎目录/主机目录下 新建一个xml文件
文件的名称就是项目名 文件的内容如下:
<Context docBase="G:\myweb"/>
eclipse和tomcat的整合
步骤1:获得服务器运行环境配置,Window/Preferences/Server/Runtime Environmen
步骤2:添加服务器(选择自己对应的版本)
步骤3:选择服务器在硬盘的地址,然后所有的都是确定/Next/Finish
步骤4:完成成功
步骤5:设置发布位置&修改为webapps
发布web项目:
1. 项目右键/Run As/Run on Server
2.选择WEB服务器执行程序
3.选择或添加文本框
修改右键new的内容
目前需要展示的
常见问题(配置):
1.启动的时候一闪而过 正确配置:JAVA_HOME
2.端口冲突问题
修改tomcat的端口号.
打开tomcat/conf/server.xml
大概70行左右 有如下代码:
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
修改port后面的值就可以了.注意:1024以下的端口号留给系统用的
80端口是留给http协议用的.我们可以使用这个端口号
3.有可能出现的问题(在环境变量中配置CATALINA_HOME)
删除4.端口号冲突
访问localhost:8080进不去apache页面,我的当时修改为8081正常访问,自己8080端口号被占用了。
5.新建项目没有server选项
help->install new software
然后选择对应的内容进行下载,我全部下载了,费了很长时间,中间还卡顿半天,最后才下好,最后记得重启就可以了。