自定义MVC之框架问题优化

 1.在编写代码时,子控制器中初始化代码会有重复问题,于是用一个xml文件代替Map

Cpu(中央核心)

package com.zking.frame;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.beanutils.PropertyUtils;

import com.zking.web.BookCupi;
import com.zking.web.GoodsCupi;

/**
 * 目标: 根据自定义mvc框架的原理图 完成 框架的研发
 * 
 * Cpu中央控制器
 * 
 * @author 花火
 *
 *         寻找子控制器
 */
@WebServlet("*.action")
public class Cpu extends HttpServlet {
//子控制器不只一个,有专门存放子控制器的地方

	//private Map<String, CupiE> ie = new HashMap<String, CupiE>();
	private ConfigModel com=null;
	
//初始化子控制器集合,经过初始化,ie容器就有子控制器集合
//init ,Serviet, destroy

	
	/**
	 * & 缺陷:指的是需要改变别人的代码,并伴随风险性
	 * 目标:
	 *  1.解决子控制器中初始化代码重复问题
	 *  需求:
	 *   增加一个商品的增删改查
	 *  步骤:
	 *  	改动init中代码
	 *  思考:
	 *  	能不能不改动代码完成这个解决子控制器中初始化需求
	 *	参考DBAccess的数据源配置文件config.properties
	 *		1.减少代码改动的风险性
	 *		2.减少代码的编译次数(对于已经部署到服务器后)
	 *	解决方案
	 * 	改成子控制器可配置
	 * 		解决步骤:
	 * 			1.必须有配置文件config.xml
	 * 			2.配置文件config.xml中包含处理业务的子控制器
	 * 			3.读取到配置文件config.xml中对应的处理浏览器请求的子控制器
	 * 		编码
	 * 
	 */
	
	
	@Override
	public void init() throws ServletException {
		// 初试化子控制器
		try {
			com=ConfigModelFactory.build();
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		/*ie.put("/book", new BookCupi());
		ie.put("/goods", new GoodsCupi());*/
	}

	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		doPost(req, resp);
	} 

	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		// 寻找子控制器
		// 浏览器:http//localhost:8080/MVC/book.action?methodName=add
		// 目标:BookCupiE.add();
		/**
		 * 思路 1.从浏览器URL中获取"/book"字符串 2.在子控制器容器中拿到Cupie 3.找到方法
		 */
		// 获取uri
		String uri = req.getRequestURI();
		// 截取
		uri = uri.substring(uri.lastIndexOf("/"), uri.lastIndexOf("."));
		/*CupiE c = ie.get(uri);*/
		ActionModel acm = com.pop(uri);
		String type = acm.getType();
		CupiE c=null;
		try {
			c = (CupiE)Class.forName(type).newInstance();
			if(c instanceof ModelDriver) {
				ModelDriver m=(ModelDriver) c;
				Object obj = m.getModel();
				//有对象
				//接受所有的前端Jsp传递到后台的参数
				Map<String, String[]> pm = req.getParameterMap();
				//对对象赋值
				//PropertyUtils.getProperty(obj, name)
				BeanUtils.populate(obj, pm);
			}
			String res = c.execute(req, resp);
			ForwardModel pc = acm.pop(res);
			if(pc.isRedirect()) {
				resp.sendRedirect(req.getContextPath()+pc.getPath());
				System.out.println(req.getContextPath()+pc.getPath());
			}else {
				req.getRequestDispatcher(pc.getPath()).forward(req, resp);
			}
			/**
			 * 思路
			 * 1.方法执行完毕,必须要有返回值
			 * 2.通过返回值是否要重定向还是转发
			 * 3.通过返回值决定要跳那个页面
			 */
		} catch (Exception e) {
			e.printStackTrace();
		} 
		
		
	}
	//YUXIG
}

2.实现实体类自动化实例化 &解决转发req和重定向resp代码重复问题

package com.zking.web;

import java.io.IOException;
import java.lang.reflect.Field;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.zking.entity.Book;
import com.zking.frame.CupiE;
import com.zking.frame.ModelDriver;

public class BookCupi extends CupiE implements ModelDriver<Book> {

	private Book b = new Book();

	private void add(HttpServletRequest req, HttpServletResponse resp) {
		// TODO Auto-generated method stub
		System.out.println("bookDao.add()..");
	}

	private String delete(HttpServletRequest req, HttpServletResponse resp) {
		System.out.println("bookDao.delete()..");
		/**
		 * 需求:删除成功后跳转到书籍展示页面
		 * 缺陷:1.出现大量重复代码
		 * 		2.不好管理(增删改重新跳到查询页面)
		 * 解决方案://YUXIG在一个地方统一管理重定向还是转发,并定位是跳到哪一个页面
		 */
		/*try {
			req.getRequestDispatcher("/book.jsp").forward(req, resp);
			this.list(req, resp);
			resp.sendRedirect("/book.jsp");
		} catch (Exception e) {
			e.printStackTrace();
		}*/
		return "toList"; 
	}

	private void edit(HttpServletRequest req, HttpServletResponse resp) {
		// TODO Auto-generated method stub
		System.out.println("bookDao.edit()..");
	}

	private void ref(HttpServletRequest req, HttpServletResponse resp) {
		// 解决参数实体类封装问题
		/**
		 * 缺陷://YUXIG对于前端传参,实体类属性值封装req.getParammeter("")代码是重复的 需求:做一个book的新增功能
		 * 思考:将jsp参数塞进实体类的属性中,问题是每一个实体类的属性是不一样的,没办法做到代码的完全重复 不知道是哪一个实体类->泛型
		 * 不知道这个实体类有哪些属性,但又要给这些属性赋值->反射动态设置属性值 解决:泛型+反射 编码:模型驱动接口:ModelDriver
		 *
		 *//*
			 * 
			 * Field[] ds = b.getClass().getDeclaredFields();
			 * b.setBname(req.getParameter("bname")); b.setPrice(req.getParameter("price"));
			 * b.setAuthor(req.getParameter("author"));
			 * b.setPublish(req.getParameter("publish"));
			 */
		System.out.println(b);
		System.out.println("bookDao.ref()..");
	}

	private void load(HttpServletRequest req, HttpServletResponse resp) {
		// TODO Auto-generated method stub
		System.out.println("bookDao.load()..");
	}
	
	private String list(HttpServletRequest req, HttpServletResponse resp) throws Exception{
		
		// TODO Auto-generated method stub
		System.out.println("bookDao.list()..");
		return "list";
	}

	@Override
	public Book getModel() {
		// //YUXIG  TODO Auto-generated method stub
		return b;
	}

}

xml

<?xml version="1.0" encoding="UTF-8"?>
<config>
	<action path="/book" type="com.zking.web.BookCupi">
		<forward name="list" path="/book.jsp" redirect="false" />
<!-- 		//YUXIG增删改操作之后要再一次查询数据库的新的数据做展示 -->
		<forward name="toList" path="/book.action?methodName=list" redirect="true" />
	</action>
</config>

切合方法

package com.zking.web;

import java.io.IOException;
import java.lang.reflect.Field;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.zking.entity.Book;
import com.zking.frame.CupiE;
import com.zking.frame.ModelDriver;

public class BookCupi extends CupiE implements ModelDriver<Book> {

	private Book b = new Book();

	private void add(HttpServletRequest req, HttpServletResponse resp) {
		// TODO Auto-generated method stub
		System.out.println("bookDao.add()..");
	}

	private String delete(HttpServletRequest req, HttpServletResponse resp) {
		System.out.println("bookDao.delete()..");
		/**
		 * 需求:删除成功后跳转到书籍展示页面
		 * 缺陷:1.出现大量重复代码
		 * 		2.不好管理(增删改重新跳到查询页面)
		 * 解决方案://YUXIG在一个地方统一管理重定向还是转发,并定位是跳到哪一个页面
		 */
		/*try {
			req.getRequestDispatcher("/book.jsp").forward(req, resp);
			this.list(req, resp);
			resp.sendRedirect("/book.jsp");
		} catch (Exception e) {
			e.printStackTrace();
		}*/
		return "toList"; 
	}

	private void edit(HttpServletRequest req, HttpServletResponse resp) {
		// TODO Auto-generated method stub
		System.out.println("bookDao.edit()..");
	}

	private void ref(HttpServletRequest req, HttpServletResponse resp) {
		// 解决参数实体类封装问题
		/**
		 * 缺陷://YUXIG对于前端传参,实体类属性值封装req.getParammeter("")代码是重复的 需求:做一个book的新增功能
		 * 思考:将jsp参数塞进实体类的属性中,问题是每一个实体类的属性是不一样的,没办法做到代码的完全重复 不知道是哪一个实体类->泛型
		 * 不知道这个实体类有哪些属性,但又要给这些属性赋值->反射动态设置属性值 解决:泛型+反射 编码:模型驱动接口:ModelDriver
		 *
		 *//*
			 * 
			 * Field[] ds = b.getClass().getDeclaredFields();
			 * b.setBname(req.getParameter("bname")); b.setPrice(req.getParameter("price"));
			 * b.setAuthor(req.getParameter("author"));
			 * b.setPublish(req.getParameter("publish"));
			 */
		System.out.println(b);
		System.out.println("bookDao.ref()..");
	}

	private void load(HttpServletRequest req, HttpServletResponse resp) {
		// TODO Auto-generated method stub
		System.out.println("bookDao.load()..");
	}
	
	private String list(HttpServletRequest req, HttpServletResponse resp) throws Exception{
		
		// TODO Auto-generated method stub
		System.out.println("bookDao.list()..");
		return "list";
	}

	@Override
	public Book getModel() {
		// //YUXIG  TODO Auto-generated method stub
		return b;
	}

}

 

index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	目前多数人增删改查的代码
	<a href="${pageContext.request.contextPath}/book/add">增加</a>
	<a href="${pageContext.request.contextPath}/book/delete">删除</a>
	<a href="${pageContext.request.contextPath}/book/edit">修改</a>
	<a href="${pageContext.request.contextPath}/book/list">查询</a>
	<hr>
2.0增删改查的代码
	<a href="${pageContext.request.contextPath}/book.action?methodName=add">增加</a>
	<a href="${pageContext.request.contextPath}/book.action?methodName=delete">删除</a>
	<a href="${pageContext.request.contextPath}/book.action?methodName=edit">修改</a>
	<a href="${pageContext.request.contextPath}/book.action?methodName=list">查询</a>
<hr>
3.0
<a href="${pageContext.request.contextPath}/book.action?methodName=load">测试</a>
<a href="${pageContext.request.contextPath}/book.action?methodName=ref">关联</a>

<hr>
演示初始化控制器的缺陷
<a href="${pageContext.request.contextPath}/goods.action?methodName=add">增加</a>
	<a href="${pageContext.request.contextPath}/goods.action?methodName=delete">删除</a>
	<a href="${pageContext.request.contextPath}/goods.action?methodName=edit">修改</a>
	<a href="${pageContext.request.contextPath}/goods.action?methodName=list">查询</a>
<hr>
 解决参数实体类封装问题
 <form action="${pageContext.request.contextPath}/book.action?methodName=ref" method="post">
	<input type="text" name="bid" value="2">
	<input type="text" name="bname" value="name">
	<input type="text" name="price" value="jia">
	<input type="text" name="author" value="asa">
	<input type="text" name="publish" value="lish">
	<input type="text" name="bz" value="bz">
	<input type="submit">
</form>

</body>
</html>

j

 结果

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: ASP.NET MVC是一种用于构建Web应用程序的开发框架,它使用C#作为主要的编程语言。ASP.NET MVC是微软公司推出的一种模型-视图-控制器(Model-View-Controller)架构模式的实现。 在ASP.NET MVC中,开发人员将应用程序分为三个主要组件:模型(Model)、视图(View)和控制器(Controller)。模型是应用程序的数据层,用于处理数据逻辑和持久化数据。视图是应用程序的用户界面,用于渲染数据并向用户显示信息。控制器负责接收用户请求,并根据请求调用适当的模型和视图,并对用户请求进行处理和响应。 ASP.NET MVC具有很多优点。首先,它提供了良好的可维护性和可测试性,因为它将应用程序分为独立的组件。这使得开发人员可以轻松地对每个组件进行测试和修改,而不会对其他组件产生影响。其次,ASP.NET MVC具有丰富的功能和灵活的扩展性,开发人员可以根据项目需求自定义和扩展框架。此外,ASP.NET MVC具有良好的性能和安全性,可以处理大量并发请求,并防止网络攻击。 为了使用ASP.NET MVC进行开发,开发人员需要具备一定的C#编程知识。C#是一种面向对象的编程语言,与ASP.NET MVC紧密集成。开发人员可以使用C#编写模型、控制器和视图,并使用C#提供的丰富的类库和框架来处理数据和逻辑。C#还具有强类型和类型安全性,可以提高代码的可靠性和性能。 总而言之,ASP.NET MVC是一个强大且灵活的Web开发框架,其结合了C#编程语言和模型-视图-控制器架构模式。它提供了可维护、可测试、高性能和安全的解决方案,适用于构建各种规模的Web应用程序。 ### 回答2: ASP.NET MVC(Model-View-Controller)是一种Web应用程序开发模式,通过将应用程序分为三个主要组件:模型(Model)、视图(View)和控制器(Controller),帮助开发人员更好地分离关注点和组织代码。 模型(Model)是应用程序的核心组件,它负责处理应用程序的数据逻辑和业务逻辑。模型通常是与数据库或其他数据存储互动的组件,它负责数据的获取、处理和存储。模型可以包含实体类、数据访问层和业务逻辑处理。 视图(View)负责呈现应用程序的用户界面,它是用户与应用程序交互的地方。视图通常是由HTML和其他前端技术组成,开发者可以使用视图模板语言来动态渲染数据。视图的主要职责是显示模型中的数据,并为用户提供交互操作的界面。 控制器(Controller)负责处理用户请求和控制应用程序的流程。它接收来自用户的请求,根据请求的类型和数据,调用适当的模型进行数据处理和业务逻辑处理,最后将数据传递给视图进行展示。控制器在MVC模式中扮演了协调器的角色,它负责将用户输入映射到模型和视图之间。 ASP.NET MVC为开发人员提供了一种清晰的结构和良好的组织方式,可以更好地管理应用程序的代码和资源。使用ASP.NET MVC,开发人员可以轻松实现URL路由、权限控制、数据校验和错误处理等功能。同时,ASP.NET MVC还提供了可扩展的机制和工具,使开发人员能够定制和优化应用程序的性能和功能。 总之,ASP.NET MVC是一种优秀的Web应用程序开发框架,它通过模型-视图-控制器的设计模式,使开发人员能够更好地组织和管理代码,提高应用程序的开发效率和质量。 ### 回答3: ASP.NET MVC是一种基于MVC(Model-View-Controller)架构的Web应用程序开发框架。它结合了传统Web Forms和ASP.NET的特点,提供了一种更加灵活和可控的开发模式。 ASP.NET MVC采用了分层的开发模式,其中Model层用于处理数据的操作,View层用于展示数据,并处理用户的输入和界面交互,Controller层用于处理业务逻辑和协调Model和View之间的交互。这种分层使得各个部分的职责清晰明确,提高了代码的可维护性和可测试性。 在ASP.NET MVC中,控制器负责接收用户的请求,并根据请求的内容决定要执行哪些操作,或者调用适当的Model来处理数据。然后,控制器将处理的结果传递给View层进行展示。通过这种方式,控制器起到了桥接Model和View的作用。 ASP.NET MVC还提供了强大的路由功能,通过路由表将URL映射到对应的控制器和操作上,使得开发者可以更加灵活地定义URL和页面之间的关系。 除了以上的特点,ASP.NET MVC还具有以下优点: 1. 更加灵活:通过MVC的模式,开发者可以根据自己的需求灵活地选择使用哪些组件和功能,没有多余的开销。 2. 可测试性:因为MVC将应用程序分成了独立的组件,所以每个组件都可以独立地进行测试,提高了代码的质量和稳定性。 3. 简化开发过程:ASP.NET MVC提供了很多通用的功能和组件,例如表单验证、身份验证和数据绑定等,这些可以帮助开发者快速构建应用程序。 4. 跨平台支持:ASP.NET MVC可以运行在Windows和Linux等多个平台上,为开发者提供了更多的选择。 总之,ASP.NET MVC是一个功能强大、灵活和可扩展的Web开发框架,它可以帮助开发者快速构建高质量的Web应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值