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. Java JavaMail通过SMPT发送邮件

    概述 本讲讲述如何使用JavaMail工具包,通过SMPT协议,在Java代码中发送邮件. 一.JavaMail简介 JavaMail API提供了一个独立于平台且与协议无关的框架来构建邮件和消息传递 ...

  2. 如何实现Springboot+camunda+mysql的集成

    本文介绍基于mysql数据库,如何实现camunda与springboot的集成,如何实现基于springboot运行camunda开源流程引擎. 一.创建springboot工程 使用IDEA工具, ...

  3. JS:逗号运算符

    逗号运算符: 会把逗号隔开的表达式全部执行 最后一个运行的表达式的结果就是逗号运算符的结果   例: var a = (1, 2, 3, 4, 5, 6); console.log(a); //6 隐 ...

  4. 一篇文章带你使用Typescript封装一个Vue组件

    一.搭建项目以及初始化配置 vue create ts_vue_btn 这里使用了vue CLI3自定义选择的服务,我选择了ts.stylus等工具.然后创建完项目之后,进入项目.使用快捷命令code ...

  5. Linux用户、组 管理

    Linux安全模型 3A: Authentication:认证,验证用户身份 Authorization:授权,不同的用户设置不同权限 Accouting|Audition:审计 Linux用户: 管 ...

  6. Java中将对象或者集合对象转换成json字符串

    1.对象和字符串相互转换 2.集合对象和字符串相互转换

  7. 7.Spark SQL

    1.分析SparkSQL出现的原因,并简述SparkSQL的起源与发展. SparkSQL出现是因为关系数据库已经不能满足各种在大数据时代新增的用户需求.首先,用户需要在不同的结构化和非结构化数据中执 ...

  8. 编写可维护的webpack配置

    为什么要构建配置抽离成npm包 通用性 业务开发者无需挂住配置 统一团队构建脚本 可维护性 构建配置合理的拆分 README文档, chan 构建配置管理的可选方案 通过多个配置管理不同环境的构建, ...

  9. CSS进阶内容—盒子和阴影详解

    CSS进阶内容 在学习了CSS基本知识之后,我们需要进一步了解CSS,因此写下了这篇文章 当然如果没有学习之前的知识,可以到我的主页中查看之前的文章:秋落雨微凉 - 博客园 CSS三大特性 首先我们先 ...

  10. Graphics2D类

    Graphics2D类 Java语言在Graphics类提供绘制各种基本的几何图形的基础上,扩展Graphics类提供一个Graphics2D类,它拥用更强大的二维图形处理能力,提供.坐标转换.颜色管 ...