dom解析器机制 web基本概念 tomcat

时间:2023-03-09 01:10:29
dom解析器机制  web基本概念  tomcat

0 作业[cn.itcast.xml.sax.Demo2]
  1)在SAX解析器中,一定要知道每方法何时执行,及SAX解析器会传入的参数含义

1 理解dom解析器机制

1)dom解析和dom4j原理一致
  2)Node是所有元素的父接口
  3)常用的API:

   DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();取得DOM解析器工厂
DocumentBuilder domParser = factory.newDocumentBuilder();取得DOM解析器
domParser.parse(*.xml)加载需要解析的XML文件
Document.getDocumentElement()取得XML文件的根元素/节点
Element.getNodeName():取得根元素
Element.getElementsByTagName("汽车")取得"汽车"元素的集合
NodeList.item(i)取得第N个元素,从0开始
Element.getTextContent():取得元素的文本内容
Element.getAttributes().getNamedItem("出产时间").getTextContent():取得元素中某属性的值
document.createElement("汽车");创建新元素
Element.setTextContent("我的汽车");设置元素的内容
Element.appendChild(newCarElement);在尾部添加元素
Element.insertBefore(newCarElement,
rootElement.getElementsByTagName("汽车").item(1));在指定的元素前添加元素
TransformerFactory tf = TransformerFactory.newInstance();创建输出工厂
Transformer transformer = tf.newTransformer();创建输出对象
Source source = new DOMSource(document);创建内存的document对象
Result result = new StreamResult(new File("src/cn/itcast/xml/dom/car.xml"));指定输出的目标地点
transformer.transform(source,result);将document对象输出到xml文件中
Element.setTextContent("深圳");更新元素的内容
Element.removeChild(secondCarElement);在父元素基础上删除直接子元素

4)dom解析器会将空白字符当作有效元素对待 
  5)要让dom解析器将空白字符忽略,必须满足二条件

a)对XML文件必须写一个DTD约束

b)factory.setIgnoringElementContentWhitespace(true); 
  6)dom类解析器和sax类解析器

a)dom是一次性加载到内容,形成document对象,人工导航,适合curd

b)sax是分次性加载到内容,sax解析器导航,但程序员需要编写sax处理器,必须扩展DefaultHandler类,适合r

package cn.itcast.xml.dom;

import java.io.File;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList; //使用DOM解析器解析XML文件
public class Demo1 {
public static void main(String[] args) throws Exception {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder domParser = factory.newDocumentBuilder();
Document document = domParser.parse(new File("src/cn/itcast/xml/dom/car.xml"));
Element rootElement = document.getDocumentElement();
System.out.println("根元素为:"+rootElement.getNodeName());
NodeList nodeList = rootElement.getElementsByTagName("汽车");
System.out.println("共有:" + nodeList.getLength()+"辆汽车");
System.out.println("++++++++++++++++++++++++++");
for(int i=0;i<nodeList.getLength();i++){
Element element = (Element) nodeList.item(i);
String band = element.getElementsByTagName("车牌").item(0).getTextContent();
String place = element.getElementsByTagName("产地").item(0).getTextContent();
String price = element.getElementsByTagName("单价").item(0).getTextContent();
String time = element.getElementsByTagName("车牌").item(0).getAttributes().getNamedItem("出产时间").getTextContent(); System.out.println("车牌:" + band);
System.out.println("产地:" + place);
System.out.println("单价:" + price);
System.out.println("出产时间:" + time);
System.out.println("-------------------------");
}
}
}
package cn.itcast.xml.dom;

import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.junit.Test;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList; public class Demo2 {
//dom是否将空白字符当作一个有效的元素对待
public static void main(String[] args) throws Exception{
Document document = getDocument();
Element rootElement = document.getDocumentElement();
NodeList nodeList = rootElement.getChildNodes();
System.out.println("共有" + nodeList.getLength()+"个直接元素");
}
@Test
public void create() throws Exception{
Document document = getDocument();
Element newCarElement = document.createElement("汽车");
newCarElement.setTextContent("我的汽车");
Element rootElement = document.getDocumentElement();
//rootElement.appendChild(newCarElement);
rootElement.insertBefore(
newCarElement,
rootElement.getElementsByTagName("汽车").item(1));
write2xml(document);
}
@Test
public void update() throws Exception{
Document document = getDocument();
Element secondCarElement = (Element) document.getElementsByTagName("汽车").item(1);
secondCarElement.getElementsByTagName("产地").item(0).setTextContent("深圳");
secondCarElement.getElementsByTagName("车牌").item(0).getAttributes().getNamedItem("出产时间").setTextContent("2012年");
write2xml(document);
}
@Test
public void delete() throws Exception{
Document document = getDocument();
Element rootElement = document.getDocumentElement();
Element secondCarElement = (Element) rootElement.getElementsByTagName("汽车").item(1);
rootElement.removeChild(secondCarElement);
write2xml(document);
}
private void write2xml(Document document)throws Exception {
//将内存中的document对象写到外存的xml文件
TransformerFactory tf = TransformerFactory.newInstance();
Transformer transformer = tf.newTransformer();
//源
Source source = new DOMSource(document);
//目
Result result = new StreamResult(new File("src/cn/itcast/xml/dom/car.xml"));
transformer.transform(source,result);
}
private static Document getDocument() throws Exception {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
//设置dom解析器将空白字符过滤
factory.setIgnoringElementContentWhitespace(true);
DocumentBuilder domParser = factory.newDocumentBuilder();
Document document = domParser.parse(new File("src/cn/itcast/xml/dom/car.xml"));
return document;
}
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 车辆清单 [
<!ELEMENT 车辆清单 (汽车+)>
<!ELEMENT 汽车 (车牌,产地,单价)>
<!ELEMENT 车牌 (#PCDATA)>
<!ELEMENT 产地 (#PCDATA)>
<!ELEMENT 单价 (#PCDATA)>
<!ATTLIST 车牌
出产时间 CDATA #REQUIRED>
]>
<车辆清单>
<汽车>
<车牌 出产时间="2010年">奥迪</车牌>
<产地>北京</产地>
<单价>30</单价>
</汽车>
<汽车>
<车牌 出产时间="2012年">本田</车牌>
<产地>深圳</产地>
<单价>60</单价>
</汽车>
</车辆清单>
2 web基本概念

1)JavaWeb是用Java技术开发基于Web的应用

2)在Internet上运行的资源有二大类:

a)静态资源

无论何时何地以何种身份访问该资源,显示的结果一样

HTML或XHTML或XML,CSS,JavaScript,...

b)动态资源

无论何时何地以何种身份访问该资源,有可以结果不一样

Servlet,Jsp,...

package cn.itcast.web.base;

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket; //使用JavaSocket编程,读取abc.html文件,写给每个浏览器客户端
public class Demo1 {
public static void main(String[] args) throws Exception {
ServerSocket ss = new ServerSocket(9999);
while (true) {
Socket s = ss.accept();
// 得到输入流
InputStream is = s.getInputStream();
// 将字节流包装成高级字符流,目的是行行读
BufferedReader br = new BufferedReader(new FileReader(
"d:\\abc.html"));
// 得到输出流
OutputStream os = s.getOutputStream();
String line = null;
// 循环读取abc.html文件中的内容
while ((line = br.readLine()) != null) {
// 输出到每个浏览器
os.write(line.getBytes());
}
br.close();
os.close();
s.close();
}
/*
* 项目在一定放在try-catch-finally中在非空的情况下关闭 br.close(); is.close();
* os.close(); s.close(); ss.close();
*/
}
}
*3 安装tomcat web服务器

1)将某个文件提外界用户访问,必须有一个类似的网络应用程序来接收和响应用户的请求
  2)web服务器有多种类型

java开源:tomcat6/7。。。

商用:weblogic,websphere

获取Tomcat安装程序包

  • tar.gz文件是Linux操作系统下的安装版本
  • exe文件是Windows系统下的安装版本(上线)
  • zip文件是Windows系统下的压缩版本(开发)绿色

3)安装tomcat

    a)配置JDK正确版本[至少是JDK5]和路径

b)执行tomcat/bin/startup.bat启动Web服务器 
    c)CATALINA_HOME指明需要启动哪台tomcat服务器 
    错误案例:

a)tomcat端口被占用,可以通过server.xml文件修改默认端口号 <Con>

b)查看当前进程使用情况,工具Fport.exe 
    c)窗口一闪而过,JAVA_HOME目录设置出错 
  4)tomcat目录的含义:

*bin/启动和停止tomcat的脚本文件

*conf/配置tomcat的文本,以xml文件为主

*lib/tomcat用到的第三方jar包

logs/tomcat服务器操作相关的日志文件

temp/tomcat运行时用到的一些临时文件 
    **webapps/tomcat能被外界访问的符合标准目录结构的web应用

work/tomcat运行的工作目录

5)Web标准目录结构:

dom解析器机制  web基本概念  tomcat

6)Web常用的编号

404:客户端请求的资源,服务端找不到

*4 配置虚拟主机和目录

1)虚拟目录:在tomcat/conf/server.xml文件中设置如下代码:

    <Context path="/qq" docBase="d:\mail"/>

path="以/开头,表示虚拟目录"    
    docBase="web应用的真实目录"

附加: reloadable="false"服务端会自动监视/WEB-INF/classes或lib目录下的变化情况,一旦变化,服务湍在设置成true的情况下,自动加载最新的内容,如果设置成false,服务端无法加载最新的资源,需要手工重新启动服务器,开发阶段设置为true,上线阶段设置为false。unpackWAR="true"服务器会自动将web压缩文件解压成标准的web目录结构

2)设置默认web应用 |缺省的Web应用程序

    <Context path="" docBase="d:\mail"/>

3)设置默认web资源 |缺省的web资源

mail-WEB-INF-web.xml文件中设置如下代码:

<welcome-file-list>

<welcome-file>mail.html</welcome-file>

<welcome-file>mail.htm</welcome-file>

<welcome-file>mail.jsp</welcome-file> 
        </welcome-file-list> 
  4)设置虚拟主机:在tomcat/conf/server.xml文件中设置如下代码:

<Host name="www.163.com"  appBase="d:\sina">

<Context path="" docBase="d:\sina\mail"/>

<Context path="/news" docBase="d:\sina\news"/>

</Host>

name表示虚拟主机名,与HOSTS文件中定义的一致   
      appBase虚拟主机对应的Web应用根目录

\表示真实目录

/表示外界通过浏览器访问的目录   
      以windowXP为例:C:\WINDOWS\system32\drivers\etc\HOSTS文件 
  5)位于webapps/目录下的标准web应用,服务器会自动映射成一个虚拟目录

<Context path="/day04" docBase="d:\apache-tomcat-6.0.29\webapps\day04"/>   
  6)某些旧版的tomcat服务器,可能无法自动映射webapps/目录下的标准web应用,需要加上WEB-INF/web.xml文件才行

5 理解C/S和B/S结构的特点

1)Domain Name Service

  2)DNS是电信内部的一个域名和IP地址的映射关系

3)在查询DNS之前,先查看本地操作系统对应的HOSTS文件,是否能找到对应的IP,如果能找到,不会查DNS了,只有在

查找不到的情况下,再连网找DNS服务器

4)CS结构:程序和数据分离在不同的端

*BS结构:程序和数据绑定在服务端

dom解析器机制  web基本概念  tomcat

6 观察http协议

1)超文本的传输协议,是基于TCP/UDP协议(底层)

  2)有二个版本

a)HTTP/1.0(一次用户请求,服务端响应后,立即断开)

b)HTTP/1.1(一次用户请求,服务端响应后,会保持一定的时间,在该一定时间后,用户可以再次请求)

3)为了让客户端响应速度快,在满足业务需求的情况下,尽量减少HTTP请求数的发送