自定义mvc框架

本文介绍了自定义MVC框架的概念及其重要性,包括结构清晰、可维护性和可扩展性的优势。通过一个施工人员的比喻,解释了自定义MVC的工作流程,强调了子控制器(子类)必须通过主控制器(门禁)进行操作,并提供了Java代码示例来展示如何实现。最后,文章指出学习编程思想和理解流程能提升开发效率。
摘要由CSDN通过智能技术生成

目录

1.什么是自定义mvc?

2.自定义mvc架构

2.1 为什么要学习自定义MVC框架自定义MVC框架的重要性主要体现在以下几个方面:

2.自定义MVC工作原理

3、自定义MVC实例流程

3.1自定义mvc开发流程

3.2子控制器(老板:发布任务)

3.3子控制器的子类(打工人:执行任务):

3.3主控制器(门禁)

3.4jsp界面

 4.总结:


1.什么是自定义mvc?

MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计模式,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。
MVC 把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller)。
MVC 的目标是将业务逻辑从用户界面的考虑中分离。这样,开发者就可以更容易地改变每一部分而不会影响其他。
 

2.自定义mvc架构

自定义MVC(Model-View-Controller)框架是一种能够帮助开发者构建和组织应用程序的软件框架,它基于MVC设计模式。

2.1 为什么要学习自定义MVC框架
自定义MVC框架的重要性主要体现在以下几个方面:

结构清晰:MVC框架将应用程序的不同部分进行了划分,使得代码的结构更加清晰和可读性更高。通过明确定义模型、视图和控制器的职责,可以使开发人员更容易理解和维护应用程序的代码。

可维护性:由于MVC框架使代码结构变得清晰,因此应用程序变得更容易维护。当需要进行修改或者添加新功能时,开发人员可以更加准确地找到和理解相关代码的位置,从而提高代码的可维护性。

可扩展性:MVC框架将应用程序的不同部分解耦,使得各个部分可以独立进行开发和测试。这意味着当需要添加新功能或者进行需求变更时,只需要修改相应的模型、视图或控制器,而不会对其他部分造成影响,从而提高了代码的可扩展性。

代码复用:通过合理使用MVC框架,可以将一些通用的代码逻辑封装在模型、视图或控制器中,从而实现代码的复用。例如,多个视图可以共享同一个模型来展示不同的数据,或者多个控制器可以共享同一个模型来处理相同的请求。这样可以减少冗余代码的编写,提高开发效率。

2.自定义MVC工作原理

 

开发者可以根据MVC模式自定义属于自己的MVC框架,并根据实际情况进行相应的优化和扩展。

3、自定义MVC实例流程

3.1自定义mvc开发流程

   👨‍💻 首先我给大家讲一个生活中的案例,假如我是一个施工人员,只有施工证才能进行施工。那么我要进行施工,每次都要经过施工点的门禁,门禁则根据施工证进行存档,通过了才能到达施工点,听从安排进行具体任务施工。

        那么这里的的施工人员就是一个个子控制器子类,必须要继承实现父类子控制器的执行方法,才有资格进行操作,而我们子控制器子类真正要实现功能,要每次都经过主控制器的控制过滤,才能到指定子类进行施工,分发任务的就是子控制器了。


3.2子控制器(老板:发布任务)

package com.xzs.formwork;

import java.lang.reflect.Method;

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

public class Action {
	public void execute(HttpServletRequest request, HttpServletResponse response) throws Exception {
		// 获取methodName值,这里指前端点击功能传来的方法名
		String methodName = request.getParameter("methodName");
 
		/**
		 * this--->BookAction/BlogAction/PermissionAction...可能是很多对象
		 * 所以需要通过反射找到对象带request,response参数的methidName方法
		 */
		Method m = this.getClass().getDeclaredMethod(methodName, HttpServletRequest.class, HttpServletResponse.class);
		m.setAccessible(true);
		// 动态调用其方法
		m.invoke(this, request, response);
	}
 


}

3.3子控制器的子类(打工人:执行任务):

package com.xzs.servlet;

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

import com.xzs.formwork.Action;

public class BookAction extends Action {
	public void query(HttpServletRequest req, HttpServletResponse resp) {
		System.out.println("查询的业务逻辑");
	}
 
	public void edit(HttpServletRequest req, HttpServletResponse resp) {
		System.out.println("修改的业务逻辑");
	}
 
	public void delete(HttpServletRequest req, HttpServletResponse resp) {
		System.out.println("删除的业务逻辑");
	}
 
	public void add(HttpServletRequest req, HttpServletResponse resp) {
		System.out.println("新增的业务逻辑");
	}


}

施工证就是 : public class BookAction extends Action如果我没有继承Action父类子控制器,我是没有这个方法的,那么就不能进行施工操作…

3.3主控制器(门禁)

package com.xzs.formwork;

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 com.xzs.servlet.BookAction;

/**
 * Servlet implementation class DisPathServlet
 */
@WebServlet("*.action")
public class DisPathServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
	
	//实例化集合作为储存
	private Map<String, Action> actionMap = new HashMap<String, Action>();
 
	@Override
	public void init() throws ServletException {
		/**
		 * 初始化存值就是给每个施工员根据施工证进行存档:
		 */
		actionMap.put("book", new BookAction());
	}
 
	protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doPost(request, response);
	}
 
	protected void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		// http://localhost:8080/MVC_project/book.action?methodName=delete...
		/**
		 * 获取请求路径
		 */
		String uri = request.getRequestURI();
		// 截取book
		uri = uri.substring(uri.lastIndexOf("/") + 1, uri.lastIndexOf("."));
		// 通过截取后的key(url)在map集合中找到指定的类进行处理
		Action action = actionMap.get(uri);
		try {
			action.execute(request, response);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

}

3.4jsp界面

<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	<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=query">查询</a>
	<a href="${pageContext.request.contextPath }/book.action?methodName=load">回显</a>
</body>
</html>

最后的结果:

 点击按钮:

 4.总结:

学好编程先学会编程思想,分析流程才能提高效率,本篇只是简单的介绍及流程,自定义MVC框架主要是促进了代码的重用性、可维护性和可扩展性。将代码进行分离,明确定义它们的职责。因此可以更容易地进行单元测试和集成测试。此外,当某个组件需要变更时,也只需要修改该组件而不影响其他组件。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值