spring 的IOC是反射注入,用来管理对象的创建与销毁。一般使用都是在启动的web服务器的时候就创建了对象,可以选择自动装配对象管理,将对象引用实现与引用分开。采用的xml配置方式。及大减少了各个类的代码。

spring IOC实际配置

<beans default-autowire="byName">
<bean id="userDao" class="org.springside.modules.security.dao.UserDao" />
<bean id="deptDao" class="org.springside.modules.security.dao.DeptDao" />
<bean id="roleDao" class="org.springside.modules.security.dao.RoleDao" />
<bean id="resourceDao" class="org.springside.modules.security.dao.ResourceDao" />
<bean id="permissionDao" class="org.springside.modules.security.dao.PermissionDao" />
</beans>

属性注入    default-autowire="byName" 这个显示自动装配

public class RoleDao extends BaseHibernateDao {
private UserDao userDao; public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}

spring是管理容器,负责创建创建对象,创建对象如果没有spring容器,创建的时候就是能用的时候就直接到类里面创建,如果有了spring容器,那么创建对象就是spring的事情了,这样有什么好处呢,就是能够解耦,这应该就是控制吧,就好比 (剧本 角色 饰演者)剧本需要角色,角色的实际对象是饰演者,剧本就会创建饰演者满足角色,这样就是以剧本引入角色。

public class MoAttack {
public void drama()
{
//打演员扮演剧本角色
Role role= new performer(); //剧本角色剧情展开
role.responseAsk("墨者革离!");
}
}

这样就是以剧本引入角色没有spring管理的。这样有什么问题呢,真正的饰演者也写到了剧本里面,

实际情况下应该是由导演来指定应该让谁演的。导演其实应该就是spring管理容器,这样能够将角色与饰演者分开,这就是解耦。
构造函数注入

public class MoAttack {
private Role role;
//①注入具体角色扮演者
public MoAttack(Role role){
this.role= role;
}
public void cityGateAsk(){
role.responseAsk("墨者革离!");
}
}

剧本这样呢就不关心到底是扮演这个角色,只需要你传入进来真正的饰演者就可以了。有谁来传入呢,由导演来指定谁扮演
注:借鉴

public class Director {
public void direct(){
//①指定角色的扮演者 德华
Role role= new LiuDeHua(); //②注入具体扮演者到剧本中
MoAttack moAttack = new MoAttack(geli);
moAttack.cityGateAsk();
}
}

spring 基础配置

web.xml文件

firstListener就是用来加载applicationContext.xml的监听器

spring 解决hibernate关闭及延迟的问题OpenSessionInViewFilter是将一次完成的请求与对应的线程绑定,他允许在事物提交之后加载显示所需要的对象。

<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath:context/applicationContext.xml
</param-value>
</context-param>
<context-param>
<param-name>firstListener</param-name>
<param-value>org.springframework.web.context.ContextLoaderListener</param-value>
</context-param>
<filter>
<filter-name>hibernateFilter</filter-name>
<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
</filter>

classpath:context/applicationContext.xml

sessionFactory(依赖  dataSource  mappingDirectoryLocations    hibernateProperties   )  与下面代码对应

<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="mappingDirectoryLocations">
<list>
<value>classpath:domain/hbm/</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
<prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
<prop key="hibernate.cache.provider_class">${hibernate.cache.provider_class}</prop>
<prop key="hibernate.connection.SetBigStringTryClob">${hibernate.connection.SetBigStringTryClob}</prop>
</props>
</property>
</bean>

*****************************************************************************************

dataSource   org.apache.commons.dbcp.BasicDataSource                       (依赖driverClassName  url  username  password  )与下面对应

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName">
<value>${jdbc.driverClassName1}</value>
</property>
<property name="url">
<value>${jdbc.url1}</value>
</property>
<property name="username">
<value>${jdbc.username1}</value>
</property>
<property name="password">
<value>${jdbc.password1}</value>
</property>
</bean>

(driverClassName  url  username  password)   (依赖根目录下jdbc.properties 配置)注:项目工程一般都直接配置在tomcat  context.xml 或者server.xml里面

 <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:jdbc.properties</value>
</list>
</property>
</bean>

jdbc.properties配置文件,是通过inputStream流将配置属性读入加载

jndi.default_name=
hibernate.connection.SetBigStringTryClob=true
hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider
hibernate.cache.use_query_cache=false
hibernate.dialect=org.hibernate.dialect.Oracle9Dialect hibernate.format_sql=false
hibernate.hbm2ddl.auto=
hibernate.show_sql=false jdbc.driverClassName=oracle.jdbc.OracleDriver
jdbc.url=
jdbc.username=
jdbc.password= jdbc.driverClassName1=oracle.jdbc.OracleDriver
jdbc.url1=
jdbc.username1=
jdbc.password1=

************************************************************************************************

----------------------------------------------------------------------------------------

mappingDirectoryLocations   hibernate映射的目录

 <property name="mappingDirectoryLocations">
<list>
<value>classpath:domain/hbm/</value>
<value>classpath:modules/</value>
</list>
</property>

-----------------------------------------------------------------------------------

hibernateProperties

<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
<prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
<prop key="hibernate.cache.provider_class">${hibernate.cache.provider_class}</prop>
<prop key="hibernate.connection.SetBigStringTryClob">${hibernate.connection.SetBigStringTryClob}</prop>
</props>
</property>

${hibernate.dialect}依赖于jdbc.properties里面配置  自上而下jdbc.properties配置文件,是通过inputStream流将配置属性读入加载。

java技术 spring 配置的更多相关文章

  1. Java 横向技术 Spring框架【笔记】

    Java横向技术 spring框架[笔记] Spring 的两大特性是什么? AOP(Aspect Oriented Programming,面向切面编程)与 IOC(Inverse of Contr ...

  2. Spring配置c3p0数据源时出错报:java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector

    今天在使用Spring配置c3p0数据源时,使用的数据库是mysql,服务器是tomcat,运行时报了一个 java.lang.NoClassDefFoundError: com/mchange/v2 ...

  3. 【JAVA】Spring 数据源配置整理

            在Spring中,不但可以通过JNDI获取应用服务器的数据源,也可以直接在Spring容器中配置数据源,此外,还可以通过代码的方式创建一个数据源,以便进行无依赖的单元测试. 配置数据源 ...

  4. Spring IoC — 基于Java类的配置

    普通的POJO只要标注@Configuration注解,就可以为Spring容器提供Bean定义的信息了,每个标注了@Bean的类方法都相当于提供一个Bean的定义信息. 基于Java类的配置方法和基 ...

  5. Java框架spring 学习笔记(十八):事务管理(xml配置文件管理)

    在Java框架spring 学习笔记(十八):事务操作中,有一个问题: package cn.service; import cn.dao.OrderDao; public class OrderSe ...

  6. java 线程池(ExecutorService与Spring配置threadPoolTaskExecutor)

    一.java ExecutorService实现 创建ExecutorService变量private ExecutorService executor = null 2.执行对应任务时,首先生成线程 ...

  7. spring 配置 Java配置类装配bean

    https://www.cnblogs.com/chenbenbuyi/p/8457700.html 自动化装配的确有很大的便利性,但是却并不能适用在所有的应用场景,比如需要装配的组件类不是由自己的应 ...

  8. 【Java Web开发学习】Spring配置数据源

    Spring配置数据源 转载:https://www.cnblogs.com/yangchongxing/p/10027495.html =============================== ...

  9. 【Java】Spring之基于注释的容器配置(四)

    注释是否比配置Spring的XML更好? 基于注释的配置的引入引发了这种方法是否比XML“更好”的问题.答案是每种方法都有其优点和缺点,通常,由开发人员决定哪种策略更适合他们.由于它们的定义方式,注释 ...

随机推荐

  1. HTML 兼容性

    1. 不同浏览器对HTML标记所具有的内外边距属性具有不同的定义. 2. 因此如果想消除这种差距,应该在相应的CSS部分加入以下CSS代码: *{margin:0px;padding:0px;} 优先 ...

  2. NSXMLParser解析xml格式

    NSXMLParser解析xml格式的数据 用法如下: 首先,NSXMLParser必须继续NSXMLParserDelegate协议 @interface XMLHelper : NSObject ...

  3. libgcc_s.so.1 must be installed for pthread_cancel to work

    首先 whereis 看一下 有没有 libgcc_s.so.1 有的话 记得gcc --o xxx xxx.c -lpthread -lgcc_s

  4. *** missing separator. Stop.

    在make命令后出现这种错误提示,是提示第2行没有分隔符. 例如: 1 target:prerequisites 2 command -- 改为: 1 target:prerequisites 2   ...

  5. linux find命令

    Linux中find常见用法示例 ·find   path   -option   [   -print ]   [ -exec   -ok   command ]   {} \; find命令的参数 ...

  6. 基于 Annotation 拦截的 Spring AOP 权限验证方法

    基于 Annotation 拦截的 Spring AOP 权限验证方法 转自:http://www.ibm.com/developerworks/cn/java/j-lo-springaopfilte ...

  7. jQuery中,$('#main') 与 document.getElementById('main')是什么样的关系-转

    $('#main')[0]和document.getElementById('main')两个一模一样.解释:$('#main'):是一个jquery写法,#main是一个过滤器表示方法,表示查找一个 ...

  8. hosts立即生效的方法

     做web开发和测试的,难免需要经常修改hosts来指定某个域名访问某个特定的IP:在windows中,每次修改了C:\windows\system32\drivers\etc\hosts,都需要重启 ...

  9. 在CentOS上安装并运行SparkR

    环境配置—— 操作系统:CentOS 6.5 JDK版本:1.7.0_67 Hadoop集群版本:CDH 5.3.0 安装过程—— 1.安装R yum install -y R 2.安装curl-de ...

  10. VR全景项目外包团队— VR/AR相关领域介绍和VR全景案例

    VR/AR相关领域这里我要说的一点就是硬件.诚然,硬件的确很难搞,国内在这方面就是荒漠,所以,如果你有信心,完全可以开拓一片蓝海.注意我是说真正的硬件,那些把Google的纸盒子拿来改改就能融资千万的 ...