我们知道grails框架提供了DSL风格的控制器和高度简化的domain,框架几乎帮我们做了所有的事情,我们仅仅集中精力到业务上。
框架做了以下的工作
1,整个MVC流程的运转(这个大家很熟,多数MVC框架都提供)
2,DSL风格的控制器(动态增强)
3,增强的domain
查看了grails的代码,知道grails是通过springmvc来实现grails框架的,不同的地方,在得到control以后,grails利用groovy语言的动态能力对control进行了增强。
GORM的增强时比较有意思的。
grails通过加载sessionfactorybean的时候(ConfigurableLocalSessionfactorybean),会依次生成sessionfacoty和domainclass,并且利用spring的beanaware能力,在GORMEnhancingBeanPostProcessor的postProcessAfterInitialization方法中,
DomainClassGrailsPlugin.enhanceDomainClasses(application,applicationContext)HibernatePluginSupport.enhanceSessionFactory(sf,application,applicationContext)
static enhanceDomainClasses(GrailsApplication application,ApplicationContext ctx) { for(GrailsDomainClass dc in application.domainClasses) { def domainClass = dc MetaClass MetaClass = domainClass.MetaClass MetaClass.IDent = {-> delegate[domainClass.IDentifIEr.name] } MetaClass.constructor = {-> if(ctx.containsBean(domainClass.fullname)) { ctx.getBean(domainClass.fullname) } else { BeanUtils.instantiateClass(domainClass.clazz) } } MetaClass.static.create = {-> ctx.getBean(domainClass.getFullname()) } addValIDationMethods(application,domainClass,ctx) addRelationshipManagementMethods(domainClass) } }
另外,HibernatePluginSupport是作为插件加载的,但是现在很多代码写死在grails里的,因此GORM现在和hibernate是强耦合的(我看了,代码写的一团浆糊,解耦的话估计工作量不小)
grails的插件运行机制是DefaultGrailsPlugin载入所有插件,//调用plugin的doWithSpring方法,加载plugin到spring的ApplicationContext
def doWithSpring = { ..... }
Closure c = (Closure)this.plugin.getProperty(DO_WITH_SPRING); BeanBuilder bb = new BeanBuilder(getParentCtx(),springConfig,application.getClassLoader()); Binding b = new Binding(); b.setvariable("application",application); b.setvariable("manager",getManager()); b.setvariable("plugin",this); b.setvariable("parentCtx",getParentCtx()); b.setvariable("resolver",getResolver()); bb.setBinding(b); c.setDelegate(bb); bb.invokeMethod("beans",new Object[]{c});
doWithSpring是委托执行,委托beanbuilder执行闭包
private BeanBuilder invokeBeanDefiningClosure(Closure callable) { callable.setDelegate(this); // callable.setResolveStrategy(Closure.DELEGATE_FirsT); callable.call(); finalizeDeferredPropertIEs(); return this; }
doWithApplicationContext是直接执行,参数是applicationContext
public voID doWithApplicationContext(ApplicationContext applicationContext) { if(this.pluginBean.isReadableProperty(DO_WITH_APPliCATION_CONTEXT)) { Closure c = (Closure)this.plugin.getProperty(DO_WITH_APPliCATION_CONTEXT); c.setDelegate(this); c.call(new Object[]{applicationContext}); }总结
以上是内存溢出为你收集整理的GRAILS框架运行机制探全部内容,希望文章能够帮你解决GRAILS框架运行机制探所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)