在给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。 后来各种找资料,下了各种的...
新增更新: -新集成进一个PHP隧道,这样即使你得isp不允许你从自己的工作站连接数据库,你也可以连接了 -允许缓存数据库架构,加速mysql-front 运行速度 -无需数据库请求即可内部排序数字 -SQL编辑器用有自动完成...
SQL-Front(原mysql-front)
MySQL-Front 5.1 安装包+注册码 绝对可用
MySQL-Front v5.0 Build 1.0 官方中文版序列号
这里我为大家提供2019年1月的最后一个版本。且用钱珍惜。下面是作者停止mysql-fornt的声明文稿 MySQL-Front is not longer available Hello, my name is Nils. 18 years, I developed the application „MySQL-...
MySQL-Front_Setup最新安装版本........................
一, 安装软件,这个很简单,就是到网上把这两个软件下到就可以了,不过MYSQL-FRONT是需要钱注册的,一般可以搜索到破解的版本,MYSQL是免费提供的。 下到后安装即可。 二, 到mysql in目录下找到winmysqladmin.exe...
MySQL-Front_Setup安装包,MySQL-Front是MySQL的客户端工具。
Mysql安装教程+Mysql-Front简单安装+Mysql-Front注册码
MySQL-Front_Setup中文版支持win32和win64 附带安装教程
FISCO-BCOS及WeBase-Front中间件安装包
MySQL-Front注册码 针对于过期的MySQL-Front完成重新注册
MYSQL专用导入导出工具mysql-front
包含mysql-front和其破解代码, mysql-front是一款mysql的界面管理工具,可以非常方便的连接数据库,创建数据库和表等操作。
SQL-Front(MySQL front) v4.0.exe SQL-Front(MySQL front) v4.0.exe
SQL-Front_Setup 一个MySQL常用的图形化界面的客户端
MySQL-Front的安装包,用它把excel数据导入到了数据库中,还比较好用
mysql-front 6.1
开发工具\MySQL-Front_Setup.exe开发工具\MySQL-Front_Setup.exe开发工具\MySQL-Front_Setup.exe开发工具\MySQL-Front_Setup.exe