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标准目录结构:
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结构:程序和数据绑定在服务端
6 观察http协议
1)超文本的传输协议,是基于TCP/UDP协议(底层)
2)有二个版本
a)HTTP/1.0(一次用户请求,服务端响应后,立即断开)
b)HTTP/1.1(一次用户请求,服务端响应后,会保持一定的时间,在该一定时间后,用户可以再次请求)
3)为了让客户端响应速度快,在满足业务需求的情况下,尽量减少HTTP请求数的发送