现在心情很差,头脑很乱,会写得有点语无伦次。
我的需求很简单:
如:有个实体名叫Product,我需要:提供一个网站后台管理,卖家管理,顾客管理,分别对这个实体crud操作。命名方式我是想这样:com.lugua.admin.ProductController,com.lugua.seller.ProductController,com.lugua.customer.ProductController
先用我最熟悉的grails。grails的文档没明确说控制器不能同名,但实际上在grails中用以上的命名,编译是不会出错,当grails按照约定找控制器的时候,就只会去找其中一个,具体找哪个我还没有研究,总之只会去找一个,那这样问题就大了。我不想用AdminProductController,SellerProductController,CustomerProductController这么丑恶的名字来命名控制器。我把grails的UrlMapping文档来回看了很多遍,尝试各种7股8怪的映射方式,无所不用其极,还是没能解决控制器查找重名的问题。于是我想看看通过grails源码能不能找到可以切入的地方。
grails的整个view层就是一个springmvc应用,刚开始确实找到切入点。grails处理控制器的方式大概是:
它会为每个*Controller.groovy控制器注册一个描述的类,这个类用来描述该控制器的uri,与action的对应关系,action与返回的view的对应关系,于是想到在控制器中自己加个static namespace='/admin',在容器启动的时候,通过反射将namespace值追加到uri与view的前面,这样或许可以解决问题。但由于这些对应关系对是用private Map的形式声明的,这么强行写入,可能会破坏数据,事实证明,这么一改,牵一动百。这么一改,牵连到grails处理请求的过滤器,缓存,热部署等等的连锁反应,总之就是不大改,行不通。我可没功夫改这么多了。难怪,我到grails社区论坛上,看到有人提到这问题的时候,社区的反应是,这功能不加是因为想保持grails的简单。我想不是简单吧,是怕牵一动百吧,NND,玩不下去了。
不过这次追逐过程,倒是对grails的请求处理过程有了更深的理解,也增加了但心,因为就我眼看到的源码,有约8个地方用到了反射,对uri的解析映射到控制器action的映射的处理稍显复杂,很是但心性能啊。
不知道play!是不是一路货色,如果能解决这问题,我就用play!开发下一项目。play!最近的呼声很高,不会让我失望吧,我想。
之前没玩过play!,得看个把小时的文档。慢慢发现,它某些地方比grails还省事。并且controller都是静态方法,既然这样,就可能通过com.lugua.admin.Product.show的方式直接引用,应该可以解决我的分包问题。事实上,它确实解决了。定义一个controllers.lugua.admin.Product,通过url/admin/product/show,它就会去找views下面的/admin/product/show页面,一阵兴奋。。。。。
别急,郁闷开始了,当我在项目中引入security这个module的时候,出现问题了。它的权限模块控制器也都是静态方法,并且提供的方式是@Secure之类的注解方式,还有个什么Secure.connected()返回一个登录用户的用户名,当我要修改它的登录逻辑时,当我写个Admin放到controller.lugua.admin包下,用这模块时,连编译都不通过了。因为Secure是Security的内部类,并且不是public的,而是包级的访问声明,也就是default的方式,Security是打包在controllers下,即package controllers,现在明白我要说什么了吧,也就是我的Admin没法引用到这个Secure!!!!!!搞到这里,我发扬不抛弃,不放弃的精神,又折腾了两个小时,最后结果,over,不玩了,没解决问题。也不敢玩了,谁知道再玩下去,还会有什么郁闷的事情呢。
下一站,rails3!,这个呼声更高。rails之前更加没接触过,但是因为之前有grails的基础,还算可以搞一下她。折腾着下个ruby1.9.2,下个rails3,在windows搞好rails开发环境后,开始搞,其中装sqlit3被搞得半死,一开始死活报错,明明gem install sqlit3-ruby装了,并且也提示装好了,起动应用就是报错,老是弄不起来。后来查了半天,是要自己下个sqlit3.ddl丢到ruby_home\bin下面去。看着文档,看到了routes这一块,它里面有个 namespace :admin do products end的示例,这不就是我要的吗???!!赶紧尝试,结果是,bo shift。又是一个表面看起来很美,很华丽的东西。它确实可以分包,但是有限制的。如果是按照以上的路由声明,那么控制器里面的实例变量,也需要如:@admin_product这样的方式,并且对应的model也需要诸如:class Admin::Product的方式声明,否则页面的标签要引用这些变量的时候就会报错。
如果是控制器是如Admin::ProductController这样声明我还忍了,但是model也要求这样,我就没法接受了。Product不属于任何一个命名空间,这么声明意思就是model属于Admin的。
奇丑无比。
不玩了不玩了不玩了,叫你分包叫你分包叫你分包。为了搞这东西,不吃不喝十几小时,中间为了理清思维,还花钱去按了摩洗了脚,杯具。
full-stack。。。。。。,以后别跟我提full-stack这词。。。
回头想,ssh开发效率虽然慢一点,但就是有它强的地方,不会阴碍你架构项目的方式,不会。。。
写这文章不是想误导群众,我是敢肯定grails是不支持的,其它两个框架刚刚接触几小时,反正我是弄不出来了。。。。 写得比较乱,洗洗睡了。
在同一个项目里3个同名类这思路本来就很扭曲,撞墙也就不奇怪了######
框架只是技术的实现,有的时候真的不是实现的问题,而是设计的问题。别跟自己过不去。
######呵呵,楼主每种框架都只是浅尝辄止,怎么能够体会到框架的精髓呢。3楼说的不错,框架只是不同技术的实现,让你省去实现的方式。而你太去追究细节,每种框架都不能百分百满足你的要求,最好你自己写框架。
######不知道楼上几位是用什么框架来开发,你们没有这样的需求吗?
######特别是这种类Rails的框架,一些约定俗成的规定多少会有点限制。既然用了,那就能遵循它的习惯了。
######不死心,又试了下play,发现。
play!还有个问题,控制器所有必须继承controller,具体用代码说明。
class Admin extends Controller{}
class Users extends Admin{}
以上代码,Users继承了Admin,Admin继承了Controller,那么Users也应该是一个Controller,play应该可以找到。但事实证明是,play死活找不到,没法在routes里面配置映射。一定要这样:
class User extends Controller{},play才认。这个问题就大了,具体会有什么大问题不说了。
有没有对play比较熟悉的,力推play框架的来说说这个问题,我确实对这框架浅尝辄止,因为,我想要做些变化,就受到很大的阻碍,没法不“辄止”。
######从以上看来,grails给我的限制是最小的,最起码controller都是实例方法,可以拥有面向对象的一切好处,性能差点就差点,还是玩我的grails吧。
######不死心,又试了下play,发现。
play!还有个问题,控制器所有必须继承controller,具体用代码说明。
class Admin extends Controller{}
class Users extends Admin{}
以上代码,Users继承了Admin,Admin继承了Controller,那么Users也应该是一个Controller,play应该可以找到。但事实证明是,play死活找不到,没法在routes里面配置映射。一定要这样:
class User extends Controller{},play才认。这个问题就大了,具体会有什么大问题不说了。
有没有对play比较熟悉的,力推play框架的来说说这个问题,我确实对这框架浅尝辄止,因为,我想要做些变化,就受到很大的阻碍,没法不“辄止”。
Play! 是即时编译的,因此可能有点傻,但是思路的确超强。
######试试tapestry5.2.4啊,也许可以满足你的需求
######关于 rails 3 那部分 , 你的 表达是错的!!!
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。