在给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机制,
欢迎大家给这个简陋的机制提出一些改进的建议 谢谢了.
分享到:
相关推荐
今天安装了Mysql5.5,并且通过dos命令连接上了数据库,但是使用sql-front总是提示:Zugriffservletzung bei Adresse 004C985C in Modul 'SQL-Front.exe'. Lesen von Adresse 0000015A。 后来各种找资料,下了各种的...
总之,MySQL-Front作为一个强大的MySQL客户端工具,为数据库管理和开发提供了便捷的图形界面,结合"MySQL-Front_Setup.exe"安装包和"MySQL-Front注册码.txt",用户可以获得完整的安装和激活体验,从而高效地进行...
总的来说,MySQL-Front 6.1是一个强大的MySQL客户端,它通过图形化界面降低了数据库管理的复杂性,适合数据库管理员、开发者以及对MySQL有一定基础的用户使用。通过熟悉并掌握这些功能,用户可以更加高效地管理和...
MySQL-Front是一款流行的数据库管理工具,专为MySQL数据库系统设计,提供了一个用户友好的图形界面,使得数据库管理和操作更为便捷。这款3.2版本(Build 13.0)是免安装的绿色版本,意味着它不需要传统的安装过程,...
它提供了一个直观的图形用户界面(GUI),使得数据库管理员和开发人员可以更加高效地进行数据查询、编辑、管理和分析。在本文中,我们将深入探讨SQL-Front的主要功能、特点以及如何使用它来提升MySQL操作的便捷性。 ...
在收到的“MySQL-Front-Setup.rar”压缩包中,包含了一个名为“MySQL-Front_Setup.exe”的可执行文件,这是MySQL-Front的安装程序。首先,你需要解压这个RAR文件,然后双击运行“MySQL-Front_Setup.exe”,按照安装...
这里我为大家提供2019年1月的最后一个版本。且用钱珍惜。下面是作者停止mysql-fornt的声明文稿 MySQL-Front is not longer available Hello, my name is Nils. 18 years, I developed the application „MySQL-...
新增更新: -新集成进一个PHP隧道,这样即使你得isp不允许你从自己的工作站连接数据库,你也可以连接了 -允许缓存数据库架构,加速mysql-front 运行速度 -无需数据库请求即可内部排序数字 -SQL编辑器用有自动完成...
它为数据库管理员和开发人员提供了一个直观的界面,使他们能够轻松地执行SQL查询、管理数据库对象以及进行数据导入导出等任务,而无需直接通过命令行交互。在"MySQL-Front_Setup"中,我们将探讨MySQL-Front的安装...
3. 数据迁移:在不同数据库系统间进行数据迁移时,SQL-Front可以作为桥梁,帮助用户将数据从一个系统迁移到另一个系统。 4. 教学与学习:对于学习SQL的新手,SQL-Front提供了一个良好的实践环境,通过实际操作来...
MySQL-Front是一款强大的MySQL数据库管理工具,专为MySQL开发人员设计。它提供了用户友好的图形界面,使得数据库的管理和操作更为便捷。这个压缩包“MySQL-Front_V5.4.4.153_Setup.rar”包含的是MySQL-Front的安装...
根据提供的信息,我们可以了解到“MySQL-Front v5.0 Build 1.0 官方中文版序列号”涉及的是一个用于管理和操作MySQL数据库的应用程序。接下来,我们将详细解析这一工具的功能、特点以及如何使用等内容。 ### MySQL-...
2. **SQL编辑器**:提供了一个强大的SQL编辑环境,支持编写、执行和调试SQL语句。用户可以创建复杂的查询,进行数据更新、删除和插入操作,以及管理索引和视图。 3. **数据库设计**:MySQL-Front允许用户进行数据库...
MySQL-Front是一款功能丰富的图形化MySQL数据库管理工具,专为MySQL服务器设计,提供了一个直观、易用的界面,使得数据库的管理和操作变得更加便捷。这款客户端软件适用于初学者和专业人士,可以大大提高工作效率,...
SQL-Front 5.3是该软件的一个版本,它提供了用户友好的界面,使得数据库管理变得更加直观和高效。 SQL-Front 5.3的主要特点包括: 1. **图形化用户界面**:与命令行界面相比,SQL-Front提供了更加直观的图形化界面...
总的来说,FISCO-BCOS与WeBase-Front的组合为开发者提供了一个强大的区块链开发环境。通过WeBase-Front,开发者可以更便捷地管理和监控FISCO-BCOS区块链网络,提高开发效率,推动企业级区块链应用的快速落地。在实际...
在安装过程中,你需要确保你的计算机已经安装了MySQL服务器,因为SQL-Front是一个前端客户端,用于连接并管理MySQL数据库。如果你还没有安装MySQL,可以从MySQL官方网站下载并安装适合你操作系统的版本。MySQL是流行...
- **登录信息**:在“一般”选项卡中输入一个易于识别的名称(如“localhost”),这将作为该连接的标识。 ##### 2. 配置连接参数 - **服务器地址**:在“连接”选项卡中输入MySQL服务器的IP地址或域名。 - **端口...
在查询编写和执行方面,SQL-Front拥有一个强大的SQL编辑器。它支持自动完成代码、语法高亮、错误检查等功能,使得编写SQL语句更为便捷。用户可以编写并运行各种类型的SQL语句,包括SELECT、INSERT、UPDATE、DELETE,...