カスタムMVCフレームワーク[A]

思考のMVCフレームワーク

?1. MVC何ですか
、MVCフルネームはモデルビューコントローラであるモデル(モデル)である-ビュー(ビュー) -略語コントローラ(コントローラ)、および
それがビジネスロジックで、ソフトウェアの設計モデルである、データ、インタフェース組織コードを分離する方法を示しています。

MVCの核となるアイデア:職務、それは、それぞれが行っています。

2、MVC構造

M:エンティティドメインモデル(名詞)、プロセス・ドメイン・モデル(動詞)
V:JSP / iOS版/ Androidの
C:サーブレット/アクション

Webブラウザが要求し配布しない
サービスコール処理DAOプロジェクト運営の
DAOのデータベース操作を

注1:あなたがいないクロス層の呼び出しが可能
注2:あなただけのトップダウンの外観を呼び出すことができます

MVCフレームワークでは、その作業概略を知るために最初の考えの前提を理解する[コア]は
ここに画像を挿入説明
、中央制御動的呼び出しサブコントローラは、特定のビジネスロジックを達成するために呼び出し

概要:
中央コントローラ:あなたはサブコントローラを呼び出す場合のリクエストを処理するために、ユーザーの要求を処理するためのサブコントローラがあるかどう;ないエラーの場合、それは要求を処理できません。
サブコントローラは、ユーザ要求で処理されます。

ケーススタディ

コンピュータの基本的な機能のメインコントローラと、サブコントローラ用いて
エンティティ・クラスカルを

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(String num1, String num2) {
		super();
		this.num1 = num1;
		this.num2 = num2;
	}
	public Cal() {
		super();
	}
}

メインコントローラ

/**
 * 主控制器
 * @author zhouyanpeng
 *
 */
public class DispatcherServlet extends HttpServlet {

	private static final long serialVersionUID = -7094025920085803724L;
	private Map<String, Action> actionMap=new HashMap<>();
	
	//初始化方法
	public void init() {
		//添加子控制器
		actionMap.put("/addCal", new AddCalAction());
		actionMap.put("/delCal", new DelCalAction());
		actionMap.put("/chenCal", new ChenCalAction());
		actionMap.put("/chuCal", new ChuCalAction());
	}	
	@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 {
		init();//初始化
		String url = req.getRequestURI();//MVC/xxx.action
		url = url.substring(url.lastIndexOf("/"), url.lastIndexOf("."));
//		相当于向上转型
		Action action = actionMap.get(url);//根据url获取子控制器  
		action.execute(req, resp);
	}
}

サブコントローラインタフェース

/**
 * 子控制器
 *    专门用来处理业务逻辑
 * @author zhouyanpeng
 *
 */
public interface Action {
	void execute(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException ;
}

Mathクラスを書きます

追加

public class AddCalAction implements Action {
	@Override
	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 DelCalAction implements Action {
	@Override
	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 ChenCalAction implements Action {
	@Override
	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 {
	@Override
	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);
	}
}

ウェブを構成します

 <servlet>
 	<servlet-name>dispatcherServlet</servlet-name>
 	<servlet-class>com.zyp.framework.DispatcherServlet</servlet-class>
 </servlet>
 
 <servlet-mapping>
 	<servlet-name>dispatcherServlet</servlet-name>
 	<url-pattern>*.action</url-pattern>
 </servlet-mapping>

テスト

<script type="text/javascript">
	function doSub(value){
		if(value==1){
			calForm.action="${pageContext.request.contextPath}/addCal.action";
		}
		else if(value==2){
			calForm.action="${pageContext.request.contextPath}/delCal.action";
		}
		else if(value==3){
			calForm.action="${pageContext.request.contextPath}/chenCal.action";
		}
		else{
			calForm.action="${pageContext.request.contextPath}/chuCal.action";
		}
		calForm.submit();
	}
	
</script>

</head>
<body>
	<form id="claForm" name="calForm" action="">
		num1:<input type="text" name="num1" /><br/>
		num2:<input type="text" name="num2" /><br/>
		<input type="button" onclick="doSub(1)" value="+" />
		<input type="button" onclick="doSub(2)" value="-" />
		<input type="button" onclick="doSub(3)" value="x" />
		<input type="button" onclick="doSub(4)" value="/" />
	</form>

請求書番号を入力します。
ここに画像を挿入説明

出力
ここに画像を挿入説明

おすすめ

転載: blog.csdn.net/zyp_baoku/article/details/91044881