MVC是由Model(模型)、View(视图)、Controller(控制器)三个模块组成

视图:用于做数据展示以及和用户交互的一个界面(html页面)

控制层:能够接受客户端的请求,具体的业务功能还是需要借助于模型组件来完成(Controllers中央控制器)

模型层:模型分为很多种:有比较简单的值对象pojo/vo(value object),有业务模型组件(bo),有数据访问层组件(dao)

    业务模型组件(bo),有数据访问层组件(dao)的区别:

          数据访问层组件(dao):DAO中的一个方法就只考虑一个操作,比如单纯的添加操作,单纯的删除操作

          业务模型组件(bo):BO中的一个方法可以调用多个DAO中的方法,比如注册方法(向用户积分表添加数据,消息表添加数据,日志表添加记录....)

IOC:

1)耦合/依赖

  依赖是指,某个类离不开某个类,耦合是指:层与层之间有依赖  

  我们写程序要做到高内聚低耦合。(层与层内部要高度聚合,二层与层之间应该是低耦合的,最好是没有耦合 )

2)IOC(控制反转) / DI(依赖注入)

  控制反转(IOC):

  • 之前在Servlet类中,创建service对象,FruitService fruitService = new FruitServiceImpl();(1.如果出现在某个方法中,那么fruitService 的作用域(生命周期)就是方法级别的;

                                           2.如果在类中,为成员变量,那么fruitService 的作用域(生命周期)就是类级别的)

  • 之后在applicationContext.xml中定义了这个fruitService。然后通过解析XML,产生fruitService实例,存放在beanMap中,这个beanMap在一个BeanFactory中,因此,转移(改变)了之前的      service实例、dao实例等等他们的生命周期。控制权从程序员转移到BeanFactory。这个现象我们称之为控制反转  

DI(依赖注入)

  • 之前我们在控制层出现代码:FruitService fruitService = new FruitServiceImpl();那么,控制层和service层存在耦合。

之后,我们将代码修改成FruitService fruitService = null ;然后,在配置文件中配置:

配置文件(applicationContext.xml)

<?xml version="1.0" encoding="utf-8"?>
<beans>
<bean id="fruitDAO" class="fruit.dao.impl.FruitDAOImpl"/>
<bean id="fruitService" class="fruit.servlet.impl.FruitServiceImpl">
<property name="fruitDAO" ref="fruitDAO"/>
</bean>
<bean id="fruit" class="controllers.FruitControllers">
<property name="fruitService" ref="fruitService"/>
</bean>
</beans>

xml文件的开头一定要用

<?xml version="1.0" encoding="utf-8"?>
否则会报配置文件的错误,这句话的前面;也不可以有空格

解析XML(ClassPathXmlApplicationContext.class)

package myssm.io;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map; public class ClassPathXmlApplicationContext implements BeanFactory{
private Map<String,Object> beanMap=new HashMap<>();
public ClassPathXmlApplicationContext(){
try {
InputStream inputStream=getClass().getClassLoader().getResourceAsStream("/com/applicationContext.xml");
DocumentBuilderFactory documentBuilderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder documentBuilder = documentBuilderFactory.newDocumentBuilder();
Document document = documentBuilder.parse(inputStream);
//4.获取所有的bean节点
NodeList beanNodeList = document.getElementsByTagName("bean");
for (int i = 0; i < beanNodeList.getLength(); i++) {
Node beanNode=beanNodeList.item(i);
if(beanNode.getNodeType()==Node.ELEMENT_NODE){
Element beanElement=(Element)beanNode;
String id = beanElement.getAttribute("id");
String className=beanElement.getAttribute("class");//controllers1.FruitControllers
Class beanClass=Class.forName(className);
Object beanObj=beanClass.newInstance(); beanMap.put(id,beanObj);
}
}
//5.组装bean之间的依赖关系
for (int i = 0; i < beanNodeList.getLength(); i++) {
Node beanNode=beanNodeList.item(i);
if(beanNode.getNodeType()==Node.ELEMENT_NODE){
Element beanElement=(Element)beanNode;
String beanId = beanElement.getAttribute("id");
NodeList beanChildNodeList=beanElement.getChildNodes(); for (int j = 0; j < beanChildNodeList.getLength(); j++) {
Node beanChildNode=beanChildNodeList.item(j);
//如果是个元素节点&&元素的值是property
if(beanChildNode.getNodeType()==Node.ELEMENT_NODE&&"property".equals(beanChildNode.getNodeName())){
Element propertyElement=(Element) beanChildNode; String propertyName = propertyElement.getAttribute("name");
String propertyRef = propertyElement.getAttribute("ref");//1.找到propertyRef对应的实例
Object refObj=beanMap.get(propertyRef);
//2.将refObj设置到当前bean对应的实例的property属性上去
Object beanObj=beanMap.get(beanId);
Class beanClazz=beanObj.getClass();
Field propertyFieId=beanClazz.getDeclaredField(propertyName);
propertyFieId.setAccessible(true);
propertyFieId.set(beanObj,refObj);
}
}
}
}
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {//*****
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (NoSuchFieldException e) {
e.printStackTrace();
}
}
@Override
public Object getBean(String id) {
return beanMap.get(id);
}
}

          

        

  

                                       

Java Web中MVC设计模式与IOC的更多相关文章

  1. Java Web开发中MVC设计模式简介

    一.有关Java Web与MVC设计模式 学习过基本Java Web开发的人都已经了解了如何编写基本的Servlet,如何编写jsp及如何更新浏览器中显示的内容.但是我们之前自己编写的应用一般存在无条 ...

  2. Java Web自定义MVC框架详解 (转)

    转自:http://blog.csdn.net/jackfrued/article/details/42774459 最近给学生讲Java Web,希望他们能够在学完这部分内容后自己实现一个MVC框架 ...

  3. Java Web中的mapper,service,controller,model

    Java Web中的mapper,service,controller,model作用分别是:java web中mapper是对象持久化映射层,一般会继承ibatis或者mybatisservive是 ...

  4. Java Web 中使用ffmpeg实现视频转码、视频截图

    Java Web 中使用ffmpeg实现视频转码.视频截图 转载自:[ http://www.cnblogs.com/dennisit/archive/2013/02/16/2913287.html  ...

  5. JDBC在Java Web中的应用

    JDBC在Java Web中的应用 制作人:全心全意 在Java Web开发中,JDBC的应用十分广泛.通常情况下,Web程序操作数据库都是通过JDBC实现,即使目前数据库方面的开源框架层出不穷,但其 ...

  6. Java Web 中 过滤器与拦截器的区别

    过滤器,是在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts的 action进行业务逻辑,比如过滤掉非法u ...

  7. JAVA WEB 中的编码分析

    JAVA WEB 中的编码分析 */--> pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-co ...

  8. Java web中常见编码乱码问题(一)

    最近在看Java web中中文编码问题,特此记录下. 本文将会介绍常见编码方式和Java web中遇到中文乱码问题的常见解决方法: 一.常见编码方式: 1.ASCII 码 众所周知,这是最简单的编码. ...

  9. Java web中常见编码乱码问题(二)

    根据上篇记录Java web中常见编码乱码问题(一), 接着记录乱码案例: 案例分析:   2.输出流写入内容或者输入流读取内容时乱码(内容中有中文) 原因分析: a. 如果是按字节写入或读取时乱码, ...

随机推荐

  1. Django——表单

    一.前言 看了下教程,以为表单很简单呢,结果搞了一两个钟才弄懂,哈哈哈,所以说不要小瞧每一件事. 先说明下HTTP请求: HTTP协议以"请求-回复"的方式工作.客户发送请求时,可 ...

  2. SQLite数据库损坏及其修复探究

    数据库如何发生损坏   SQLite 数据库具有很强的抗损坏能力.在执行事务时如果发生应用程序崩溃.操作系统崩溃甚至电源故障,那么在下次访问数据库文件时,会自动回滚部分写入的事务.恢复过程是全自动的, ...

  3. SAP ABAP 快速入门之 开发环境 (Environment)

    报表是学习ABAP 原则和工具的很好的 起点.ABAP 报表在许多领域都有使用,本章将介绍简单ABAP 报表的开发. Hello ABAP 让我们以'Hello World' 开始. 每一个abap ...

  4. UiPath选择器之动态选择器的介绍和使用

    一.动态选择器的介绍 使用通配符, 能够替换字符串中的零个或多个字符的符号.这些在处理选择器中的动态更改的属性时非常有用. 二.动态选择器在UiPath中的使用 1.在设计库中新建一个Sequence ...

  5. UiPath文本操作Get Text的介绍和使用

    一.Get Text操作的介绍 从指定的UI元素提取文本值 二.Get Text在UiPath中的使用 1. 打开设计器,在设计库中新建一个Sequence,为序列命名及设置Sequence存放的路径 ...

  6. 阿里云体验有奖:使用PolarDB-X与Flink搭建实时数据大屏

    体验简介 场景将提供一台配置了CentOS 8.5操作系统的ECS实例(云服务器).通过本教程的操作带您体验如何使用PolarDB-X与Flink搭建一个实时数据链路,模拟阿里巴巴双十一GMV大屏. ...

  7. 效率效率!如何使用Python读写多个sheet文件

    前言 怎么样使用Python提高自己的工作效率,今天就给大家分享这个吧. 我们经常用pandas读入读写excel文件,经常会遇到一个excel文件里存在多个sheet文件,这个时候,就需要一次性读取 ...

  8. Python 中生成器的原理

    生成器的使用 在 Python 中,如果一个函数定义的内部使用了 yield 关键字,那么在执行函数的时候返回的是一个生成器,而不是常规函数的返回值. 我们先来看一个常规函数的定义,下面的函数 f() ...

  9. Linux shell脚本进阶使用

    shell的循环控制语句 - continue:提前结束某次循环,重新开始下一次 - break:提前结束某层循环 范例: #求100以内的奇数和 #!/bin/bash sum=0 for i in ...

  10. 近期碰到的一些面试题--WPF、C#、数据库

    最近想换工作的念头特别强烈,面了几家公司没有拿到满意的offer,心仪的公司面完锁HC,有点无奈,感觉今年有点卷,把碰到过的面试题总结下. WPF相关: 1.定义依赖属性需要注意哪些地方? (1)依赖 ...