Spring框架的7大功能
核心容器(Spring core)
核心容器提供spring框架的基本功能。
Spring以bean的方式组织和管理Java应用中的各个组件及其关系。
Spring使用BeanFactory来产生和管理Bean,它是工厂模式的实现。
BeanFactory使用控制反转(IoC)模式将应用的配置和依赖性规范与实际的应用程序代码分开。
BeanFactory使用依赖注入的方式提供给组件依赖。
Spring面向切面编程(Spring AOP)
通过配置管理特性,Spring AOP 模块直接将面向方面的编程功能集成到了 Spring框架中。
所以,可以很容易地使 Spring框架管理的任何对象支持 AOP。
Spring AOP 模块为基于 Spring 的应用程序中的对象提供了事务管理服务。
通过使用 Spring AOP,不用依赖 EJB 组件,就可以将声明性事务管理集成到应用程序中。
Spring ORM模块
Spring 与所有的主要的ORM映射框架都集成的很好,包括hibernate、JDO实现、TopLink和IBatis SQL Map等。
Spring为所有的这些框架提供了模板之类的辅助类,达成了一致的编程风格。
Spring DAO模块
DAO模式主要目的是将持久层相关问题与一般的的业务规则和工作流隔离开来。
Spring 中的DAO提供一致的方式访问数据库,不管采用何种持久化技术,Spring都提供一直的编程模型。
Spring还对不同的持久层技术提供一致的DAO方式的异常层次结构。
Spring Web模块
Web上下文模块建立在应用程序上下文模块之上,为基于Web的应用程序提供了上下文。
Web层使用Web层框架,可选的,可以是Spring自己的MVC框架,
或者提供的Web框架,如Struts、Webwork、tapestry和jsf。
Spring Web模块
Web上下文模块建立在应用程序上下文模块之上,为基于Web的应用程序提供了上下文。
Web层使用Web层框架,可选的,可以是Spring自己的MVC框架,或者提供的Web框架,
如Struts、Webwork、tapestry和jsf。
Spring MVC框架(Spring WebMVC)
MVC框架是一个全功能的构建Web应用程序的MVC实现。
通过策略接口,MVC框架变成为高度可配置的。
Spring的MVC框架提供清晰的角色划分:控制器、验证器、命令对象、表单对象和模型对象、分发器、处理器映射和视图解析器。Spring支持多种视图技术。
Spring框架中的三大核心思想是什么
== DI(依赖注入),IOC(控制反转),AOP(面向切面编程)==
IOC的概念以及在Spring容器中如何进行IOC的操作。
IOC:Inversion of Control,控制反转。
在Java开发中,IOC意味着将你设计好的类交给系统去控这里写代码片制,而不是在你的类内部控制,这称为控制反转,就是被调用类的实例由原先的调用类控制创建、销毁现在转变成由Spring的容器管理
AOP的概念以及使用AOP机制有什么好处
Java编程中实现AOP有几种方式 AOP的概念是Aspected Oriented Programming 面身向方面编程。
- 好处:AOP将程序分解成各个方面或者说关注点。这使得可以模块化,相当横向上分切了。它可以解决OOP和过程化方法不能够很好解决的横切(crosscut)问题,如:事务、安全、日志等横切关注
实现AOP有几种方式:
- Spring 1.2版本中通过ProxyFactoryBean来实现aop,即通过动态代理来实现的,Aspect必须继承MethodBeforeAdvice,MethodAfterAdvice等
- Spring 2.0 AOP需要改的是FBI 这个类,而且它也不需要再实现某些接口
- 使用标注(@AspectJ)实现AOP
Spring框架中的事务处理有几种。
请分别阐述两者的区别 spring提供的事务管理可以分为两类:
编程式的和声明式的。
编程式
编程式的,比较灵活,但是代码量大,存在重复的代码比较多;
声明式
声明式的比编程式的更灵活.编程式事务的总接口是什么?使用编程式事务需要用到哪几个Spring事务的核心类对象 总接口PlatformTransactionManager接口,
核心类:
TransactionDefinition
Spring的声明式事务能不能为普通的类产生代理接口,能不能在代码中使用Try/Catch能捕获异常,如果不可以,请说明原因 不能。Spring的声明式事务为实现类产生代理。不能在代码中使用Try/Catch,因为代码中捕获了异常,Spring容器捕获不了异常。
使用TransactionProxyFactoryBean为Bean产生事务物理时,需要哪几个属性值的设置:
<bean name=”baseTransactionProxy”
class=”org.springframework.transaction.interceptor.TransactionProxyFactoryBean”>
<!– ⑴ 为事务代理bean注入事务管理器–>
<property name=”transactionManager” ref=”transactionManager”>
</property>
<!– ⑵ 设置事务属性–>
<property name=”transactionAttributes”>
<props>
<!– ⑶ 所有方法采用required的事务策略 ->
<prop key=”*”>PROPAGATION_REQUIRED</prop>
</props>
</property>
<!– ⑷ 为事务代理bean设置目标bean –>
<property name=”target” ref=”userDao”>
</property>
</bean>
<!– ⑸ 目标bean –>
<bean name=”userDao” class=”com.dao.userDao”>
<property name=”dataSource” ref=”dataSource” /></property>
</bean>
在Spring框架中获取连接池有几种方式。
当JNDI与DBCP同时存在时,会不会出现问题,如果不能同时存在的话,请说明原因 四种方式,如下:
1:DBCP数据源
DBCP类包位于 /lib/jakarta-commons/commons-dbcp.jar,DBCP是一个依赖Jakarta commons-pool对象池机制的数据库连接池,所以在类路径下还必须包括/lib/jakarta-commons/commons-pool.jar。下面是使用DBCP配置Oracle数据源的配置片断:
<bean id=”dataSource”
class=”org.apache.commons.dbcp.BasicDataSource” destroy-method=”close”>
<property name=”driverClassName” value=” oracle.jdbc.driver.OracleDriver ” />
<property name=”url” value=”jdbc:oracle:thin:@localhost:1521:orcl ” />
<property name=”username” value=”root” />
<property name=”password” value=”1234″ />
</bean>
2:C3P0数据源
C3P0是一个开放源代码的JDBC数据源实现项目,它在lib目录中与Hibernate一起发布,实现了JDBC3和JDBC2扩展规范说明的Connection 和Statement 池。C3P0类包位于/lib/c3p0/c3p0-0.9.0.4.jar。下面是使用C3P0配置一个Oracle数据源:
<bean id=”dataSource” class=”com.mchange.v2.c3p0.ComboPooledDataSource” destroy-method=”close”>
<property name=”driverClassName” value=” oracle.jdbc.driver.OracleDriver ” />
<property name=”url” value=”jdbc:oracle:thin:@localhost:1521:orcl ” />
<property name=”username” value=”root” />
<property name=”password” value=”1234″ />
</bean>
3. Spring的数据源实现类(DriverManagerDataSource)
Spring本身也提供了一个简单的数据源实现类DriverManagerDataSource ,它位于org.springframework.jdbc.datasource包中。这个类实现了javax.sql.DataSource接口,但它并没有提供池化连接的机制,每次调用getConnection()获取新连接时,只是简单地创建一个新的连接。因此,这个数据源类比较适合在单元测试或简单的独立应用中使用,因为它不需要额外的依赖类。
<bean id=”dataSource” class=”org.springframework.jdbc.datasource.DriverManagerDataSource” destroy-method=”close”>
<property name=”driverClassName” value=” oracle.jdbc.driver.OracleDriver ” />
<property name=”url” value=”jdbc:oracle:thin:@localhost:1521:orcl ” />
<property name=”username” value=”root” />
<property name=”password” value=”1234″ />
</bean>
4.获取JNDI数据源
如果应用配置在高性能的应用服务器(如WebLogic或Websphere等)上,我们可能更希望使用应用服务器本身提供的数据源。应用服务器的数据源使用JNDI开放调用者使用,Spring为此专门提供引用JNDI资源的JndiObjectFactoryBean类。下面是一个简单的配置:
<bean id=”dataSource”
class=”org.springframework.jndi.JndiObjectFactoryBean”>
<property name=”jndiName” value=”java:comp/env/jdbc/oracle”/>
</bean>
通过jndiName指定引用的JNDI数据源名称。
在使用Spring的JDBCTemplate操作数据时,必须要往模板中注入哪些对象,同时模板要不要手动关闭数据库连接 注入DataSource数据源对象
不要手动关闭数据库连接,JdbcTemplate会帮我们关闭数据库连接
JdbcTemplate的QueryForList方法得到List集合,请问List集合中每一个对象为什么数据类型,在JSP页面使用EL表达式如何取值。 每一个对象为java.util.Map类型的数据,EL表达式里用取值