自定义MVC

本文介绍了MVC设计模式,包括其核心思想和组件职责。Model代表实体域模型,View负责展示,Controller处理用户交互。文章详细阐述了自定义MVC的工作原理,强调主控制器动态调用子控制器来完成业务逻辑,并提供了相关请求路径的获取方法。通过实例展示了如何创建实体类、子控制器和主控制器,以及在JSP界面中实现交互。总结来说,主控制器负责查找并调用合适的子控制器处理用户请求,而子控制器则专注于执行具体的业务操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 什么是MVC

1.MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,它是一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码
Model1 jsp+jdbc
Model2 ->MVC
ps:核心思想:各司其职

2、MVC结构
M: 实体域模型(名词) 过程域模型(动词)
V :servlet/action
C: jsp/ios/android

web :做浏览器请求分发
service: 调用dao处理项目业务的
dao :操作数据库
注:不能跨层调用,只能出现由上而下的调用
3. 自定义MVC工作原理图主控制动态调用子控制器调用完成具体的业务逻辑(火车、控制台、车轨)请求、主控制器、子控制器
req.getServletPath() 单纯的一个请求
req.getContextPath() 项目名
req.getRequestURI() 项目名+请求
req.getRequestURL() 请求的全路径
以下图为参考:

在这里插入图片描述
实体类的创建(cal):

public class Cal {
	private String num1;
	private String num2;
	public String getNum1() {
		return num1;
	}
	public void setNum1(String num1) {
		this.num1 = num1;
	}
	public String getNum2() {
		return num2;
	}
	public void setNum2(String num2) {
		this.num2 = num2;
	}

	public Cal() {} 
	
	public Cal(String num1, String num2) {
		this.num1 = num1;
		this.num2 = num2;
	}
	
}

先子控制器:
专门用来处理业务逻辑的

public interface Action {
	 void execute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException ;
}

再创建主控制器:

public class DispatcherServlet extends HttpServlet{

	private static final long serialVersionUID = -7865425427339716224L;
	
	private Map<String, Action> actionMap = new HashMap<>();

	public void init() {
		actionMap.put("/addCal", new AddCalAction());
		actionMap.put("/delCal", new DelCalAction());
		actionMap.put("/cCal", new cCalAction());
		actionMap.put("/xCal", new xCalAction());
	}
	
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		doPost(req, resp);
	}
	
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		init();
		String url = req.getRequestURI();
		url = url.substring(url.lastIndexOf("/"), url.lastIndexOf("."));
		Action action = actionMap.get(url);//根据url获取子控制器
		action.execute(req, resp);
	}
}

实现Action类(增加,删除,乘法,除法):

public class AddCalAction implements Action {
	public void execute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		//增加类
		String num1 = req.getParameter("num1");
		String num2 = req.getParameter("num2");
		req.setAttribute("res", Integer.parseInt(num1)+Integer.parseInt(num2));
		req.getRequestDispatcher("calRes.jsp").forward(req, resp);
	}
}	


public class DelCalAction implements Action {
	public void execute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		//删除类
		String num1 =req.getParameter("num1");
		String num2 =req.getParameter("num1");
		req.setAttribute("res", Integer.valueOf(num1)-Integer.valueOf(num2));
		req.getRequestDispatcher("calRes.jsp").forward(req, resp);
	}
}

public class ChenCalAction implements Action {
	public void execute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
	 	//乘法类
		String num1=req.getParameter("num1");
		String num2=req.getParameter("num2");
		req.setAttribute("res", Integer.valueOf(num1)*Integer.valueOf(num2));
		req.getRequestDispatcher("calRes.jsp").forward(req, resp);
	}
}

public class ChuCalAction implements Action {
	public void execute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		//除法类
		String num1=req.getParameter("num1");
		String num2=req.getParameter("num2");
		req.setAttribute("res", Integer.valueOf(num1)/Integer.valueOf(num2));
		req.getRequestDispatcher("calRes.jsp").forward(req, resp);
	}
}

再在jsp界面实现:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
	function doSb(val) {
		if(val == 1){
			calForm.action ="${pageContext.request.contextPath }/addCal.action";
		}
		else if(val ==2){
			calForm.action ="${pageContext.request.contextPath }/delCal.action";
		}
		else if(val ==3){
			calForm.action ="${pageContext.request.contextPath }/chenCal.action";
		}
		else if(val ==4){
			calForm.action ="${pageContext.request.contextPath }/chuCal.action";
		}
		calForm.submit();
	}
	
</script>

</head>
<body>
<form id="calForm" name="calForm" action="${pageContext.request.contextPath }/addCal.action">
	num1:<input type="text" name="num1" ><br>
	num2:<input type="text" name="num2" ><br>
	<button onclick="doSb(1)">+</button>
	<button onclick="doSb(2)">-</button>
	<button onclick="doSb(3)">*</button>
	<button onclick="doSb(4)">/</button>
</form>

</body>
</html>

最后结果为:

<body>
结果 :${res }<br>
</body>

从而得到结论:
主控制器:查看是否有对应的子控制器来处理用户请求,如果就调用子控制器来处理请求,没有就报错,就处理不了请求
子控制器:就是处理用户请求用的。

在刚刚步入“多层结构”Web应用程序开发的时候,我阅读过几篇关于“asp.net三层结构开发”的文章。但其多半都是对PetShop3.0和Duwamish7的局部剖析或者是学习笔记。对“三层结构”通体分析的学术文章几乎没有。 2005年2月11日,Bincess BBS彬月论坛开始试运行。不久之后,我写了一篇题目为《浅谈“三层结构”原理与用意》的文章。旧版文章以彬月论坛程序中的部分代码举例,通过全局视角阐述了什么是“三层结构”的开发模式?为什么要这样做?怎样做?……而在这篇文章的新作中,配合这篇文章我写了7个程序实例(TraceLWord1~TraceLWord7留言板)以帮助读者理解“三层结构”应用程序。这些程序示例可以在随带的CodePackage目录中找到——   对于那些有丰富经验的Web应用程序开发人员,他们认为文章写的通俗易懂,很值得一读。可是对于asp.net初学者,特别是没有任何开发经验的人,文章阅读起来就感到非常困难,不知文章所云。甚至有些读者对“三层结构”的认识更模糊了……   关于“多层结构”开发模式,存在这样一种争议:一部分学者认为“多层结构”与“面向对象的程序设计思想”有着非常紧密的联系。而另外一部分学者却认为二者之间并无直接联系。写作这篇文章并不是要终结这种争议,其行文目的是希望读者能够明白:在使用asp.net进行Web应用程序开发时,实现“多层结构”开发模式的方法、原理及用意。要顺利的阅读这篇文章,希望读者能对“面向对象的程序设计思想”有一定深度的认识,最好能懂一些“设计模式”的知识。如果你并不了解前面这些,那么这篇文章可能并不适合你现在阅读。不过,无论这篇文章面对的读者是谁,我都会尽量将文章写好。我希望这篇文章能成为学习“三层结构”设计思想的经典文章!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值