【基于spring框架的系统】基于Spring框架的WebSphere应用开发2

IBM认证复习指导 2021-07-02 网络整理 可可

【shitiku.jxxyjl.com--IBM认证复习指导】

<bean id="viewresolver" class="org.springframework.web.servlet.view.freemarker.freemarkerviewresolver"> <property> <value>><value>.ftl</value></property> </bean> <bean id="freemarkerconfig" class="org.springframework.web.servlet.view.freemarker.freemarkerconfigurer"> <property> <value>/view/</value> </property> </bean>
  如果不使用spring的mvc框架而想结合已有的一些mvc框架,spring也是支持的。spring对于常见的mvc框架都提供了支持,包括struts,webwork,tapestry和jsf等。结合使用这些框架的一个好处是可以使用一些已有的熟悉的技术,另外结合spring的aop拦截器可以相对比较容易地处理框架动作共有的事情,比如动作的日志处理等。如果选择这些mvc框架,那么在使用框架的配置文件和应用的spring配置文件都需要做相应的修改。比如使用struts的时候,struts-config.xml配置文件中的映射动作类型一般会设置成org.springframework.web.struts.delegatingactionproxy,或者设置控制器为org.springframework.web.struts.delegatingrequestprocessor。然后需要在相应应的webapplicationcontext中定义与struts action对应的bean。这样就可以充分利用spring的控制反转技术来管理struts的action了。

  另外在使用这些框架的时候要解决的一个问题是上下文的装载。比如使用struts,可以使用contextloaderplugin来装载web上下文。这个contextloaderplugin替换了原来通过dispacherservlet装载的方式。需要在struts-config.xml文件中添加如下条目:<plug-in classname="org.springframework.web.struts.contextloaderplugin"/>。这种方式可以使spring的web上下文随着struts actionservlet的初始化而装载。

  因此,如果用户已有的应用是基于某个mvc框架,或者用户熟悉某个框架,那么可以利用spring对这些框架的支持结合使用。因为我们的目的本来就是为了解决问题而不是为了使用某种技术。但是对其它用户而言,如果不是对已有的一些mvc框架比较熟悉的话,那就直接使用spring的mvc框架就可以了。

  web context设置

  对于不依赖于应用服务器的spring 上下文(context)设置,通常在应用代码中通过filesystemxmlapplicationcontext或classpathxmlapplicationcontext来获取。比如使用这样的代码来得到上下文:

applicationcontext ctx = new filesystemxmlapplicationcontext("config.xml");
  但是按照控制反转的原则,应用程序代码应该尽可能少的知道上下文的设置。因此,在基于spring的web应用中,这样的代码也可以省去。spring可以通过配置让web容器自动装载上下文配置文件。从本质上讲,web应用的servletcontext就是spring用来存放应用上下文的地方。spring中与web context装载相关的有几个类:

  1. contextloaderlistener:一般的应用服务器如was都能先装载listener,如果不是的话,那么只能使用contextloaderservlet。

  2. contextloaderservlet:需要配置<load-on-startup>使得它率先装载。真正装载context的类是contextloader,上面两个类只是两种调用contextloader的不同途径。contextloader内部实际调用的是xmlwebapplicationcontext,其缺省配置文件为/web-inf/applicationcontext.xml。

  如果使用contextloaderlistener,其在web.xml中的配置一般如下:

<listener> <listener-class> org.springframework.web.context.contextloaderlistener </listener-class> </listener>
如果使用contextloaderservlet,其在web.xml中的配置一般如下:

<servlet> <servlet-name>context</servlet-name> <servlet-class> org.springframework.web.context.contextloaderservlet </servlet-class> <load-on-startup>1</load-on-startup> </servlet>
  应用本身可能除了基于http的web渠道之外还通过别的渠道对外提供服务,因此,一个比较好的做法是把展示相关的配置与后面业务处理部分的配置分开。这样如果更改了应用的访问渠道,只需要修改对应的配置文件即可。因此,spring提供了一个webapplicationcontext的概念。在webapplicationcontext中一般包含与web访问相关的配置定义,包括各种控制动作的定义、界面展示的定义等等。webapplicationcontext一般由dispatcherservlet来初始化。在上下文层次结构上可以把它看成是applcationcontext的子上下文。在缺省的情况下,dispatcherservlet装载的配置文件名称为其servlet名称-servlet.xml,但是可以通过contextconfiglocation参数来定制。dispatcherservlet在web.xml中的定义示例如下:

<servlet> <servlet-name>dispatcher</servlet-name> <servlet-class> org.springframework.web.servlet.dispatcherservlet </servlet-class> <load-on-startup>2</load-on-startup> </servlet> <init-param> <param-name>contextconfiglocation</param-name> <param-value>/web-inf/context/webcontrollers.xml</param-value> </init-param>
  数据持久化层

  虽然使用j2ee技术的web应用可以连接多种不同的企业信息系统(eis),但是毫无疑问数据库是其中最为重要和常见的一种。正因如此,spring对数据库访问提供了非常完备的支持。数据访问对象(dao)模式是j2ee模式中非常重要的一种。它的主要目的是使得持久化层与业务逻辑层分离,从而屏蔽持久化层的具体实现。我们可以把spring的dao支持分为两大类,一是直接基于spring jdbc模板的数据访问,另一类是基于某种o/r映射框架的数据访问。这里刚好可以使用spring的控制反转特性,通过外部配置文件来定义dao接口和实际实现类之间的关系。spring框架目前支持的o/r映射框架包括hibernate、jdo、toplink、ibatis等。

  假设我们定义了一个userdao。当使用jdbc来实现这个dao的时候,定义的类可以如下所示:

public class userdaojdbc extends jdbcdaosupport implements userdao{ … }
  如果使用hibernate来实现这个dao的时候,定义的类如下:

public class userdaohibernate extends hibernatedaosupport implements userdao { … }
  spring对于其它的o/r映射机制都有相应的抽象类供应用使用,比如对于ibatis有sqlmapclientdaosupport,对于jdo有jdodaosupport等。

  下面我们看一下如何在spring的配置文件中定义上述dao与具体实现的关系。假设我们的userdao具体实现是通过hibernate,那么在applicationcontext.xml中的一个dao可以定义如下:

<bean id="userdao" class="com.fgw.dao.hibernate.userdaohibernate"> <property> <ref local="sessionfactory"/> </property> </bean>
  在这里我们实际dao接口定义是:com.fgw.dao.userdao,而具体实现类为:com.fgw.dao.hibernate.userdaohibernate。显然,对于其它dao的实现,我们只需要在配置文件中修改相应的实现类(具体实现类当然是比不可少的)和属性即可。比如对于jdbc的dao实现,属性就定义成相应的数据源。

本文来源:https://shitiku.jxxyjl.com/ibmrenzhengfuxizhidao/5999.html

Copyright @ 2011- 考试题库网 All Rights Reserved. 版权所有

免责声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。

 站长统计