`

GT-FrontController, 一个简陋的MVC控制器的设计思路

阅读更多
在给GT-Grid做前后台结合的例子时, 为了"快速开发"以及"0依赖",
自己动手写了一个MVC的机制, 实践了一个想法.
在这里把这个 MVC的机制 和大家分享一下,  欢迎大家提出一些改进的建议, 也欢迎一起来拍我.

这不是一个框架, 只是用一下午的时间 写出的一个习作,
它是一个 无配置0注释 (当然 web.xml里的配置还是有的) 的简单的前端控制器,
每个action只需要继承 BaseAction ,并且符合一定的规则 就可以run起来.
具体如下:

=========================

web.xml 里配置:
   <servlet>
   	<servlet-name>FrontController</servlet-name>
   	<servlet-class>com.fins.gt.action.FrontController</servlet-class>
		<init-param>
			<param-name>actionBasePath</param-name>
			<param-value>demo.grid.action</param-value>
		</init-param>
		<init-param>
			<param-name>viewBasePath</param-name>
			<param-value>/views</param-value>
		</init-param>
		<init-param>
			<param-name>dispatchMethod</param-name>
			<param-value>doMethod</param-value>
		</init-param>
   </servlet>
   <servlet-mapping>
   	<servlet-name>FrontController</servlet-name>
   	<url-pattern>*.do</url-pattern>
   </servlet-mapping>	


之后, 你所有的action都要放到  demo.grid.action 下(可以有子包, 通过actionBasePath设定)

所有的view文件(jsp html)等等 都要放到 /views (通过viewBasePath设定)

doMethod的就是 使用action方法映射时使用的属性名(这个太绕口,其实就和struts的dispatchAction 里的那个 method 类似., 通过dispatchMethod设定)

例如:
我写了一个action类 : demo.grid.action.usermanage.UserQuery

那么我在地址栏里输入

http://.127.0.0.1:8080/webapp/usermanage.userQuery.do
就是访问这个action (默认执行action里的 service方法)

http://.127.0.0.1:8080/webapp/usermanage.userQuery.do?doMethod=queryAll 
则是执行这个action里的 queryAll 方法.

所有的action都继承自 一个BaseAction的抽象类.
action里封装了大量的操作 request 和response 的方法.
同时 这个action不是单例的, 这样就可以保证 每个action的代码做到很精简.


public class UserQuery extends BaseAction {
	
	public void queryAll() throws ServletException, IOException {

		// Map paramMap  = getParameterMap();

		// String ...= getRequest().getParameter("...");

		// println("....");

		// forward("list");

		// redirect("login");
	}
}



上面示例里的那些方法 不用多说大家也能明白

需要说明的就是 forward 和 redirect 的参数
forward("list") 将会 forward 到 一个jsp页面, 那个页面的位置是:
/views/usermanage/userQuery/list.jsp 文件
如果要forward到别的位置的文件 那么 只需要以"/"开头 并且写出全路径(不包含/views)即可. 例如: forward("/login/loginTimeout")
今后还可以对 forward参数的前缀做各种扩充 以实现不同的需求, 例如参数
如果以 "//" 开头 那么...
如果以 ".." 开头 那么...
如果以"w:"开头 那么...

=========================
再总结一下:

http://.127.0.0.1:8080/webapp/usermanage.userQuery.do?doMethod=queryAll
将会调用
demo.grid.action.usermanage.UserQuery 类 的 queryAll 方法

queryAll 方法 中的 forward("list"),将会forward到
/views/usermanage/userQuery/list.jsp 文件

demo.grid.action 通过web.xml里的 actionBasePath 参数设定
/views 通过web.xml里的 viewBasePath 参数设定
doMethod 通过web.xml里的 dispatchMethod 参数设定

整个mvc机制 除了web.xml里配置的那几行信息之外, 其他的都是靠"约定和规则"来实现的.做到了"无配置0注释"


这就是未来GT-Grid与j2ee集合的demo中 后台使用的mvc机制,
欢迎大家给这个简陋的机制提出一些改进的建议  谢谢了.
7
0
分享到:
评论
4 楼 fins 2008-07-08  
确实如你说所 我文中提及的只是 FrontController 部分

而FrontController  恰恰只是我在这里要讲的东西

其他的东西目前还没有写或者还没有写完
3 楼 hatedance 2008-07-08  
把类名.方法名(参数)写在url里,然后通过反射调用对应的方法。这个方法我也试过,的确很容易实现。
但是仅仅如此的话跟MVC还没有直接关系。
这个算C,那么M和V呢?
2 楼 fins 2008-07-07  
在 FrontController 里
1 根据url 找到 需要调用的action的class full Name
2 Class.forName( class full Name ) (有缓存 不会每次都去forName)
3 BaseAction action= actionClass.newInstance()
4 action.init(request,response)

BaseAction 里存有request,response

这里的action是有状态的非单例对象 , 所以就不用把request,response传来传去了
forward方法里直接就能读到request,response

REST形式的url的支持我也有考虑 下一步有时间的话试一试 呵呵.


1 楼 cats_tiger 2008-07-07  
建议加入REST的支持,http://.127.0.0.1:8080/webapp/user调用xx.actions.user.UserAction的index方法,/user/list调用list方法,这样比较清爽和时髦。对了,如果是/user/list.json就返回Json数据...
另外有一个问题,forward和redirect的时候如何取得request和response呢,办法当然有,但是怎样更合理就需要动脑筋了。

相关推荐

    mysql-front5.3

    今天安装了Mysql5.5,并且通过dos命令连接上了数据库,但是使用sql-front总是提示:Zugriffservletzung bei Adresse 004C985C in Modul 'SQL-Front.exe'. Lesen von Adresse 0000015A。 后来各种找资料,下了各种的...

    MySQL-Front 安装包+注册码

    总之,MySQL-Front作为一个强大的MySQL客户端工具,为数据库管理和开发提供了便捷的图形界面,结合"MySQL-Front_Setup.exe"安装包和"MySQL-Front注册码.txt",用户可以获得完整的安装和激活体验,从而高效地进行...

    mysql-front 6.1

    总的来说,MySQL-Front 6.1是一个强大的MySQL客户端,它通过图形化界面降低了数据库管理的复杂性,适合数据库管理员、开发者以及对MySQL有一定基础的用户使用。通过熟悉并掌握这些功能,用户可以更加高效地管理和...

    MySQL-Front 免安装 绿色版

    MySQL-Front是一款流行的数据库管理工具,专为MySQL数据库系统设计,提供了一个用户友好的图形界面,使得数据库管理和操作更为便捷。这款3.2版本(Build 13.0)是免安装的绿色版本,意味着它不需要传统的安装过程,...

    SQL-Front(原mysql-front)

    它提供了一个直观的图形用户界面(GUI),使得数据库管理员和开发人员可以更加高效地进行数据查询、编辑、管理和分析。在本文中,我们将深入探讨SQL-Front的主要功能、特点以及如何使用它来提升MySQL操作的便捷性。 ...

    MySQL-Front-Setup.rar

    在收到的“MySQL-Front-Setup.rar”压缩包中,包含了一个名为“MySQL-Front_Setup.exe”的可执行文件,这是MySQL-Front的安装程序。首先,你需要解压这个RAR文件,然后双击运行“MySQL-Front_Setup.exe”,按照安装...

    MySQL-Front_Setupv6.1.zip

    这里我为大家提供2019年1月的最后一个版本。且用钱珍惜。下面是作者停止mysql-fornt的声明文稿 MySQL-Front is not longer available Hello, my name is Nils. 18 years, I developed the application „MySQL-...

    MySQL-Front_V5 绿色版

    新增更新: -新集成进一个PHP隧道,这样即使你得isp不允许你从自己的工作站连接数据库,你也可以连接了 -允许缓存数据库架构,加速mysql-front 运行速度 -无需数据库请求即可内部排序数字 -SQL编辑器用有自动完成...

    MySQL-Front_Setup

    它为数据库管理员和开发人员提供了一个直观的界面,使他们能够轻松地执行SQL查询、管理数据库对象以及进行数据导入导出等任务,而无需直接通过命令行交互。在"MySQL-Front_Setup"中,我们将探讨MySQL-Front的安装...

    SQL-Front 5.3

    3. 数据迁移:在不同数据库系统间进行数据迁移时,SQL-Front可以作为桥梁,帮助用户将数据从一个系统迁移到另一个系统。 4. 教学与学习:对于学习SQL的新手,SQL-Front提供了一个良好的实践环境,通过实际操作来...

    MySQL-Front_V5.4.4.153_Setup.rar

    MySQL-Front是一款强大的MySQL数据库管理工具,专为MySQL开发人员设计。它提供了用户友好的图形界面,使得数据库的管理和操作更为便捷。这个压缩包“MySQL-Front_V5.4.4.153_Setup.rar”包含的是MySQL-Front的安装...

    MySQL-Front v5.0 Build 1.0 官方中文版序列号

    根据提供的信息,我们可以了解到“MySQL-Front v5.0 Build 1.0 官方中文版序列号”涉及的是一个用于管理和操作MySQL数据库的应用程序。接下来,我们将详细解析这一工具的功能、特点以及如何使用等内容。 ### MySQL-...

    MySQL-Front安装包

    2. **SQL编辑器**:提供了一个强大的SQL编辑环境,支持编写、执行和调试SQL语句。用户可以创建复杂的查询,进行数据更新、删除和插入操作,以及管理索引和视图。 3. **数据库设计**:MySQL-Front允许用户进行数据库...

    mysql客户端MySQL-Front

    MySQL-Front是一款功能丰富的图形化MySQL数据库管理工具,专为MySQL服务器设计,提供了一个直观、易用的界面,使得数据库的管理和操作变得更加便捷。这款客户端软件适用于初学者和专业人士,可以大大提高工作效率,...

    Mysql管理利器SQL-Front5.3(安装后点更新会自动升级中文版)

    SQL-Front 5.3是该软件的一个版本,它提供了用户友好的界面,使得数据库管理变得更加直观和高效。 SQL-Front 5.3的主要特点包括: 1. **图形化用户界面**:与命令行界面相比,SQL-Front提供了更加直观的图形化界面...

    FISCO-BCOS及WeBase-Front中间件安装包.zip

    总的来说,FISCO-BCOS与WeBase-Front的组合为开发者提供了一个强大的区块链开发环境。通过WeBase-Front,开发者可以更便捷地管理和监控FISCO-BCOS区块链网络,提高开发效率,推动企业级区块链应用的快速落地。在实际...

    SQL-Front 安装

    在安装过程中,你需要确保你的计算机已经安装了MySQL服务器,因为SQL-Front是一个前端客户端,用于连接并管理MySQL数据库。如果你还没有安装MySQL,可以从MySQL官方网站下载并安装适合你操作系统的版本。MySQL是流行...

    MySQL-Front安装.doc

    - **登录信息**:在“一般”选项卡中输入一个易于识别的名称(如“localhost”),这将作为该连接的标识。 ##### 2. 配置连接参数 - **服务器地址**:在“连接”选项卡中输入MySQL服务器的IP地址或域名。 - **端口...

    SQL-Front_Setup MySql

    在查询编写和执行方面,SQL-Front拥有一个强大的SQL编辑器。它支持自动完成代码、语法高亮、错误检查等功能,使得编写SQL语句更为便捷。用户可以编写并运行各种类型的SQL语句,包括SELECT、INSERT、UPDATE、DELETE,...

Global site tag (gtag.js) - Google Analytics