摘要:自定義框架一實現自定義的體系結構圖模式開發應用時,分兩種情況純技術方式開發方式開發模式開發的不足頁面中嵌入大量的代碼,可讀性差。模型,主要用于數據和業務的處理。控制器,用于流程控制。顯示與邏輯控制分離。
自定義MVC框架
一、 實現自定義MVC的體系結構圖
1、Model I模式開發Web應用時,分兩種情況:
*純JSP技術方式開發
*JSP+JavaBean方式開發
2、Model I模式開發的不足:
*JSP頁面中嵌入大量的Java代碼,可讀性差。
*大量代碼在JSP中難以復用。
*后期維護及擴展的難度大。
3、為了克服Model I模式的缺陷,引入了Model II的模式開發
*Model II模式體現了基于MVC(Model-View-Controller,模型-視圖-控制器)的設計模式,簡單的說,Model II模式就是將數據顯示、流程控制和業務邏輯處理分離,使之相互獨立。
4、MVC設計模式由3個部分組成各部分的作用。
*Model:模型,主要用于數據和業務的處理。
*View:視圖,用于數據顯示。
*Controller:控制器,用于流程控制。
5、MVC設計模式的特點
*一個模型可以對應多個視圖。
*顯示與邏輯控制分離。
*分層控制,減低了代碼間的耦合。
二、 我們如何創建一個自己的MVC框架??
(一)我們要在lib里面準備一個夾包
dom4j-1.6.1.jar 主要作用:解析xml文件
(二)準備配置文檔(在src下)
]>
解釋:
解釋:根據上述約束完成的“*”代表該節點可以出現多次
success.jsp login.jsp
(三)自己準備一個Action接口,用于放入結果集和執行方法
package cn.framework;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public interface Action {
public final String SUCCESS = "success"; public final String ERROR = "error"; public final String LOGIN = "login"; public final String INPUT = "input"; public String execute(HttpServletRequest request, HttpServletResponse response);
}
(四)定義一個ResultMapping用來存放result節點
package cn.framework;
public class ResultMapping {
//result節點名字 private String name; //是否重定向 private boolean redirect; //跳轉的頁面 private String url; public ResultMapping() { } public ResultMapping(String name, boolean redirect, String url) { this.name = name; this.redirect = redirect; this.url = url; } public String getName() { return name; } public void setName(String name) { this.name = name; } public boolean isRedirect() { return redirect; } public void setRedirect(boolean redirect) { this.redirect = redirect; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; }
}
(五)定義一個ActionMapping用來存放Action節點
package cn.framework;
import java.util.HashMap;
import java.util.Map;
public class ActionMapping {
// Action名稱 private String name; // Action名稱對應的Action的類的全稱 private String className; // result集合 private Mapresults = new HashMap (); public ActionMapping() { } public ActionMapping(String name, String className, Map results) { super(); this.name = name; this.className = className; this.results = results; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getClassName() { return className; } public void setClassName(String className) { this.className = className; } public Map getResults() { return results; } public void setResults(Map results) { this.results = results; }
}
(六)準備一個ActionMappingManager是用來管理ActionMapping的
package cn.framework;
import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class ActionMappingManager {
MapactionMapping = new HashMap (); public ActionMappingManager() { init(); } public ActionMapping getActionMapping(String actionName) { return actionMapping.get(actionName); } public ActionMappingManager(String fileName) { } public Map getActionMapping() { return actionMapping; } public void setActionMapping(Map actionMapping) { this.actionMapping = actionMapping; } public static void main(String[] args) { new ActionMappingManager().init(); } public void init() { InputStream is = this.getClass().getResourceAsStream("/myframework.xml"); SAXReader sr = new SAXReader(); try { Document doc = sr.read(is); Element elRoot = doc.getRootElement(); List listActions = elRoot.elements(); for (Element elActions : listActions) { List listAction = elActions.elements(); for (Element elAction : listAction) { ActionMapping aMapping = new ActionMapping(); Attribute attName = elAction.attribute("name"); Attribute attClass = elAction.attribute("class"); aMapping.setName(attName.getValue()); aMapping.setClassName(attClass.getValue()); List listResult = elAction.elements(); for (Element elResult : listResult) { ResultMapping rMapping = new ResultMapping(); Attribute attResultName = elResult.attribute("name"); Attribute attResultRedirect = elResult.attribute("redirect"); rMapping.setName(attResultName.getValue()); rMapping.setRedirect(Boolean.parseBoolean(attResultRedirect.getValue())); rMapping.setUrl(elResult.getTextTrim()); aMapping.getResults().put(rMapping.getName(), rMapping); } actionMapping.put(aMapping.getName(), aMapping); } } } catch (Exception e) { e.printStackTrace(); } }
}
(七)利用反射機制找到自己的實列
package cn.framework;
public class ActionManager {
public static Action createAction(String className) { Class> clz = null; try { clz = Thread.currentThread().getContextClassLoader().loadClass(className); } catch (Exception ex) { ex.printStackTrace(); } try { if (clz == null) { clz = Class.forName(className); } } catch (Exception ex) { ex.printStackTrace(); } Action action = null; try { action = (Action) clz.newInstance(); } catch (Exception ex) { ex.printStackTrace(); } return action; }
}
(八)寫一個業務邏輯
package cn.action;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import cn.framework.Action;
public class LoginAction implements Action {
@Override public String execute(HttpServletRequest request, HttpServletResponse response) { return "success"; }
}
(九)核心控制器Servlet
package cn.framework;
import java.io.IOException;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class MVCServlet extends HttpServlet {
private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } ActionMappingManager amanager = null; @Override public void init(ServletConfig config) throws ServletException { amanager = new ActionMappingManager(); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { ActionMapping am = amanager.getActionMapping(getActionName(request)); Action action = ActionManager.createAction(am.getClassName()); String r = action.execute(request, response); ResultMapping rm = am.getResults().get(r); if (rm.isRedirect()) { response.sendRedirect(rm.getUrl()); } else { request.getRequestDispatcher(rm.getUrl()).forward(request, response); } } public String getActionName(HttpServletRequest request) { String actionName = null; String uri = request.getRequestURI(); String contentPath = request.getContextPath(); String actionPath = uri.substring(contentPath.length()); actionName = actionPath.substring(1, actionPath.indexOf(".")).trim(); return actionName; }
}
(十)修改web.xml
MVCServlet cn.framework.MVCServlet MVCServlet *.action
(十一)準備一個login.jsp頁面
(十二)發布到Tomcat運行
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/76761.html
摘要:最初編寫于年,是一個面向移動應用的前端框架,版本進行了大量的重構或重寫,并盡可能的保持了和之前版本類似的,是一個極輕量的框架,相較目前主流的類似的框架,更為輕量,希望為開發人員提供多一種的選擇。 Mokit 最初編寫于 2012 年,是一個面向移動應用的前端 mvc 框架,v3 版本進行了大量的重構或重寫,并盡可能的保持了和之前版本類似的 API,v3 是一個「極輕量」的 MVVM 框...
摘要:最初編寫于年,是一個面向移動應用的前端框架,版本進行了大量的重構或重寫,并盡可能的保持了和之前版本類似的,是一個極輕量的框架,相較目前主流的類似的框架,更為輕量,希望為開發人員提供多一種的選擇。 Mokit 最初編寫于 2012 年,是一個面向移動應用的前端 mvc 框架,v3 版本進行了大量的重構或重寫,并盡可能的保持了和之前版本類似的 API,v3 是一個「極輕量」的 MVVM 框...
摘要:它通過數據模型進行鍵值綁定及事件處理,通過模型集合器提供一套豐富的用于枚舉功能,通過視圖來進行事件處理及與現有的通過接口進行交互。 本人兼職前端付費技術顧問,如需幫助請加本人微信hawx1993或QQ345823102,非誠勿擾 1.為初學前端而不知道怎么做項目的你指導 2.指導并扎實你的JavaScript基礎 3.幫你準備面試并提供相關指導性意見 4.為你的前端之路提供極具建設性的...
閱讀 2907·2021-11-15 18:02
閱讀 3801·2021-10-14 09:43
閱讀 3733·2021-09-08 10:41
閱讀 2522·2019-08-30 15:53
閱讀 1804·2019-08-30 14:14
閱讀 1943·2019-08-29 16:12
閱讀 3139·2019-08-29 14:03
閱讀 1280·2019-08-29 13:46