XML建模

建模的由来:

就是将指定的xml字符串当作对象来操作
           好处在于,只需要调用指定的方法就可以完成预定的字符串获取;

建模的一个思路:

1、分析需要被建模的文件中有那几个对象
            2、每个对象拥有的行为以及属性
            3、定义对象从小到大(从里到外)
            4、通过23种的设计模式中的工厂模式,解析xml生产出指定对象

注:属性为String类型,子元素标签则是map的值,子元素标签的唯一标识则为map的值

  建模分两步: 

1、以面向对象的编程思想,描述xml资源文件

2、将xml文件中内容封装进model实体对象。

实列:

实列是通过对一个web.xml文件进行建模

web.xml文件信息

<?xml version="1.0" encoding="UTF-8"?>

<web-app>

<servlet>

<servlet-name>jrebelServlet</servlet-name>

<servlet-class>com.zking.xml.JrebelServlet</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>jrebelServlet</servlet-name>

<url-pattern>/jrebelServlet</url-pattern>

</servlet-mapping>

<servlet>

<servlet-name>jrebelServlet2</servlet-name>

<servlet-class>com.zking.xml.JrebelServlet2</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>jrebelServlet2</servlet-name>

<url-pattern>/jrebelServlet2</url-pattern>

<url-pattern>/jrebelServlet3</url-pattern>

</servlet-mapping>

</web-app>

分析出xml文件中的属性以及行为,创建Model(模型)对象

.分析出以下所有对象

ServletNameModel   (servlet-name)

package com.zking.ServletModel;

public class ServletNameModel {

    private String context;

    public String getContext() {
return context;
} public void setContext(String context) {
this.context = context;
} }

ServletClassModel   (servlet-class)

package com.zking.ServletModel;

public class ServletClassModel {

    private String context;

    public String getContext() {
return context;
} public void setContext(String context) {
this.context = context;
} }

ServletUrlpatternModel  (url-pattern)

package com.zking.ServletModel;

public class ServletUrlPatternModel {

    private String context;

    public String getContext() {
return context;
} public void setContext(String context) {
this.context = context;
} }

ServletModel     (servlet)

package com.zking.ServletModel;

public class ServletModel {

    private ServletNameModel servletNameModel;
private ServletClassModel servletClassModel; public ServletNameModel getServletNameModel() {
return servletNameModel;
} public void setServletNameModel(ServletNameModel servletNameModel) {
this.servletNameModel = servletNameModel;
} public ServletClassModel getServletClassModel() {
return servletClassModel;
} public void setServletClassModel(ServletClassModel servletClassModel) {
this.servletClassModel = servletClassModel;
} }

ServletMappingModel   (servlet-Mapping)

package com.zking.ServletModel;

import java.util.ArrayList;
import java.util.List; import org.w3c.dom.ls.LSInput; public class ServletMappingModel { private ServletNameModel servletNameModel;
private List<ServletUrlPatternModel> servletUrlPatternModels= new ArrayList<>(); public ServletNameModel getServletNameModel() {
return servletNameModel;
} public void pushUrlPatternModel(ServletUrlPatternModel urlPatternModel) {
servletUrlPatternModels.add(urlPatternModel);
} public void setServletNameModel(ServletNameModel servletNameModel) {
this.servletNameModel = servletNameModel;
} public List<ServletUrlPatternModel> getServletUrlPatternModels() {
return servletUrlPatternModels;
} }

ServletWebAppModel   (web-app)

package com.zking.ServletModel;

import java.util.ArrayList;
import java.util.List; public class ServletWebAppModel { private List<ServletModel> servletModels=new ArrayList<>();
private List<ServletMappingModel> servletMappingModels = new ArrayList<>(); public List<ServletModel> getServletModels() {
return servletModels;
} public List<ServletMappingModel> getServletMappingModels() {
return servletMappingModels;
} public void pushServletModel(ServletModel servletModel) {
servletModels.add(servletModel);
} public void pushServletMappingModel(ServletMappingModel servletMappingModel) {
servletMappingModels.add(servletMappingModel);
} }

用的是23种设计模式中的工厂模式,Factory

package com.zking.ServletModel;

import java.io.InputStream;
import java.util.List; import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class ServletWebFactory { public static ServletWebAppModel buildWebAppModel() {
String xmlPath = "/web.xml";
return buildWebAppModel(xmlPath);
} /**
* 建模
*
* @param xmlPath
* @return
*/
public static ServletWebAppModel buildWebAppModel(String xmlPath) {
InputStream in = ServletWebFactory.class.getResourceAsStream(xmlPath);
SAXReader saxReader = new SAXReader();
ServletWebAppModel webAppModel = new ServletWebAppModel();
try {
Document doc = saxReader.read(in);
/*
* 将servlet的标签内容填充进WebApp
*/
List<Element> servletEles = doc.selectNodes("/web-app/servlet");
for (Element servletEle : servletEles) {
ServletModel servletModel = new ServletModel(); /*
* 给ServletModel填充xml的内容
*/
Element servletNameEle = (Element) servletEle.selectSingleNode("servlet-name");
Element servletClassEle = (Element) servletEle.selectSingleNode("servlet-class");
ServletNameModel servletNameModel = new ServletNameModel();
ServletClassModel servletClassModel = new ServletClassModel();
servletNameModel.setContext(servletNameEle.getText());
servletClassModel.setContext(servletClassEle.getText()); servletModel.setServletNameModel(servletNameModel);
servletModel.setServletClassModel(servletClassModel); webAppModel.pushServletModel(servletModel);
} /*
* 将servlet-mapping的标签内容填充进WebApp
*/
List<Element> servletMappingEles = doc.selectNodes("/web-app/servlet-mapping");
for (Element servletMappingEle : servletMappingEles) {
ServletMappingModel servletMappingModel = new ServletMappingModel(); /*
* 给ServletMappingModel填充xml的内容
*/
Element servletNameEle = (Element) servletMappingEle.selectSingleNode("servlet-name");
ServletNameModel servletNameModel = new ServletNameModel();
servletNameModel.setContext(servletNameEle.getText());
servletMappingModel.setServletNameModel(servletNameModel); List<Element> urlPatternEles = servletMappingEle.selectNodes("url-pattern");
for (Element urlPatternEle : urlPatternEles) {
ServletUrlPatternModel urlPatternModel = new ServletUrlPatternModel();
urlPatternModel.setContext(urlPatternEle.getText());
servletMappingModel.pushUrlPatternModel(urlPatternModel);
} webAppModel.pushServletMappingModel(servletMappingModel);
} } catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return webAppModel;
} /**
* 通过浏览器输入的网址自动找到对应的后台处理类
* @param webAppModel 建模后的实体类
* @param url 浏览器访问的网址
* @return
*/
public static String getServletClassByUrl(ServletWebAppModel webAppModel, String url) {
String servletClass = "";
/*
* 找到浏览器网址对应的servlet-name
*/
String servletName = "";
List<ServletMappingModel> servletMappingModels = webAppModel.getServletMappingModels();
for (ServletMappingModel servletMappingModel : servletMappingModels) {
List<ServletUrlPatternModel> urlPatternModels = servletMappingModel.getServletUrlPatternModels();
for (ServletUrlPatternModel urlPatternModel : urlPatternModels) {
if(url.equals(urlPatternModel.getContext())) {
ServletNameModel servletNameModel = servletMappingModel.getServletNameModel();
servletName = servletNameModel.getContext();
}
}
} /*
* 找到servlet-name对应的后台处理类
*/
List<ServletModel> servletModels = webAppModel.getServletModels();
for (ServletModel servletModel : servletModels) {
ServletNameModel servletNameModel = servletModel.getServletNameModel();
if(servletName.equals(servletNameModel.getContext())) {
ServletClassModel servletClassModel = servletModel.getServletClassModel();
servletClass = servletClassModel.getContext();
}
}
return servletClass;
} public static void main(String[] args) {
ServletWebAppModel webAppModel = ServletWebFactory.buildWebAppModel();
String res = getServletClassByUrl(webAppModel, "/jrebelServlet");
String res2 = getServletClassByUrl(webAppModel, "/jrebelServlet2");
String res3 = getServletClassByUrl(webAppModel, "/jrebelServlet3");
System.out.println(res);
System.out.println(res2);
System.out.println(res3); } }

运行代码得到结果:

XML建模实列的更多相关文章

  1. AD域控Dsquery查询命令实列

    注:请以管理员的身份运行cmd程序,要不然某些命令不生效 AD域控Dsquery查询命令实列 查询技术支持二部的所有用户          dsquery user OU=技术支持二部,OU=技术部, ...

  2. Flask常用实列化参数

    Flask中实列化配置: app = Flask( __name__, template_folder=’temp’ , ...... ) >template_folder = "te ...

  3. Xml解析作业与Xml建模andXml建模作业

    作业:config.xml解析 1.获取所有action中的type的值 public static void main(String[] args) throws Exception { Input ...

  4. docker中启动2个mysql实列

    一.mac环境安装docker容器 在docker官网中下载docker容器,地址:https://www.docker.com/products/docker-desktop 具体安装教程及设置网络 ...

  5. 实列+JVM讲解类的实列化顺序

    刨根问底---类的实列化顺序 开篇三问 1什么是类的加载,类的加载和类的实列有什么关系,什么时候类加载 2类加载会调用构造函数吗,什么时候调用构造函数 3什么是实列化对象,实列化的对象有什么东西. 我 ...

  6. 美化传奇NPC对话框添加图片显示实列

    NPC对话框一般都是文字显示,有些GM想突出版本特色,在NPC对话框加些专业图片,彰显独特之处,其实这是很简单的.下面为你讲解美化传奇NPC对话框添加图片显示实列 我们要添加你要放入npc图片的补丁. ...

  7. UML基础与Rose建模实训教程

    目  录 第1章  初识UML. 1 1.1 初识UML用例图... 1 1.2 初识UML类图... 3 第2章  Rational Rose工具... 6 2.1 安装与配置Rational Ro ...

  8. 利用XML语法 SQL 列转行

    --行转列 固定xml语法 declare @xml xml ; set @xml=cast('<v>2</v><v>4</v><v>3&l ...

  9. xml建模

    1.建模的由来 就是将指定的xml字符串当作对象来操作 如果说当对一个指定的xml格式字符串完成了建模操作, 好处在于,只需要调用指定的方法就可以完成预定的字符串获取: 2.建模的思路 1.分析需要被 ...

随机推荐

  1. Hystrix【入门】

    公共依赖配置: <parent> <groupId>org.springframework.boot</groupId> <artifactId>spr ...

  2. 关于python的一次性能调优过程

    问题 这两天在公司帮老大写一个程序功能,要求抓取从elasticsearch和kibana服务器上返回的数据,统计所有hits的数据字段ret_code为0的hit,并计算其占有率等一些功能. 功能倒 ...

  3. WUSTOJ 1332: Prime Factors(Java)

    题目链接:1332: Prime Factors Description I'll give you a number , please tell me how many different prim ...

  4. 【HC89S003F4开发板】 6crc校验

    HC89S003F4开发板crc校验 前言 第一次用有带crc的mcu 使用资料自带的demo @实现效果 通过PC向MCU发送5个8位数据,MCU返回CRC校验值 void main() { /** ...

  5. axios 内部原理学习记录

    前提:一次面试被问到了,axios有什么特点,对比一下ajax.答的很不满意. axios是一个基于Promise的http请求库,可用于浏览器和 Node.可以说是目前最为常用的http库,有必要了 ...

  6. 【转载】 C#中使用Count方法获取List集合中符合条件的个数

    很多时候操作List集合的过程中,我们需要根据特定的查询条件,获取List集合中有多少个实体对象符合查询条件,例如一批产品的对象List集合,如果这批产品的不合格数量大于10则重点备注.在C#中可以自 ...

  7. 关于Vue中,$this.router.push到当前页面,只是传入参数不同,页面不刷新的问题解决

    在页面的watch中,监听$router的变化 watch: { $route (to, from) { this.$router.go(0) } } 其中this.$router.go(0)为刷新页 ...

  8. python urllib应用

    urlopen 爬取网页 爬取网页 read() 读取内容 read() , readline() ,readlines() , fileno() , close() :这些方法的使用方式与文件对象完 ...

  9. unittest管理测试用例

    #coding=utf-8 from selenium import webdriver from time import sleep import unittest #导入unittest库 imp ...

  10. spark 机器学习 knn原理(一)

    1.knnK最近邻(k-Nearest  Neighbor,KNN)分类算法,在给定一个已经做好分类的数据集之后,k近邻可以学习其中的分类信息,并可以自动地给未来没有分类的数据分好类.我们可以把用户分 ...