SSHの統合
8017 ワード
SSHとは、Struts 1/Struts 2,Spring,Hibernateの3つの技術の統合です.
この3つの技術の整合方法は様々です.私の知っている限りでは、次のような統合方式があります.
1.SpringとStrutsの統合.
ここには二つの主要な整合方法があります.一つは彼らがそれぞれ役割を果たし、一つは上の方です.二つはStrutsのアクションをSpringに任せます.
2.Springとヒップホップの統合
二つの種類に分けられます.一つはHibernate.cfg.xmlファイルです.彼の構成は以下の通りです.
Application Contect.xml中
彼らの第二の統合方式はApple Contaction Contect.xmlにSession Factoryを配置し、データソースを配置し、hibernation.cg.xmlファイルを省略しました.
設定は以下の通りです
Application Contect.xmlにおいて.
主な構成は以下の通りです
この3つの技術の整合方法は様々です.私の知っている限りでは、次のような統合方式があります.
1.SpringとStrutsの統合.
ここには二つの主要な整合方法があります.一つは彼らがそれぞれ役割を果たし、一つは上の方です.二つはStrutsのアクションをSpringに任せます.
2.Springとヒップホップの統合
二つの種類に分けられます.一つはHibernate.cfg.xmlファイルです.彼の構成は以下の通りです.
Application Contect.xml中
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>classpath:hibernate.cfg.xml</value>
</property>
</bean>
Hbernature.cfg.xmlには通常通り配置されています.次のとおりです
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<property name="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<property name="connection.url">
jdbc:jtds:sqlserver://localhost:1433;databasename=tt;
</property>
<property name="connection.username">sa</property>
<property name="connection.password">sa</property>
<property name="connection.driver_class">
net.sourceforge.jtds.jdbc.Driver
</property>
<property name="myeclipse.connection.profile">
sqlserver2000
</property>
<property name="show_sql">true</property>
<property name="format_sql">false</property>
<property name="connection.autocommit">true</property>
<property name="hbm2ddl.auto">update</property>
<mapping resource="com/baidu/ssh/bean/TtBean.hbm.xml" />
</session-factory>
</hibernate-configuration>
oracle、Mysql、DB 2などです.彼らの第二の統合方式はApple Contaction Contect.xmlにSession Factoryを配置し、データソースを配置し、hibernation.cg.xmlファイルを省略しました.
設定は以下の通りです
Application Contect.xmlにおいて.
<!-- -->
<bean id="datasource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>net.sourceforge.jtds.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:jtds:sqlserver://localhost:1433;databasename=tt</value>
</property>
<property name="username" value="sa"></property>
<property name="password" value="sa"></property>
<!-- -->
<!-- -->
<property name="maxPoolSize" value="40"></property>
<property name="minPoolSize" value="1"></property>
<property name="initialPoolSize" value="1"></property>
<property name="maxIdleTime" value="20"></property>
<property name="checkoutTimeout" value="1800"></property>
<property name="acquireIncrement" value="2"></property>
<property name="maxStatements" value="500"></property>
</bean>
!-- hibernate SessionFactory -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="datasource"></property>
<property name="mappingResources">
<list>
<value>com/baidu/ssh/bean/TtBean.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">false</prop>
<prop key="hibernate.connection.autocommit">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
</bean>
この3つの技術の統合は、Session FactoryがSpringによって管理され、Strutsが自主的に管理しています.主な構成は以下の通りです
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<!-- -->
<bean id="datasource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>net.sourceforge.jtds.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:jtds:sqlserver://localhost:1433;databasename=tt</value>
</property>
<property name="username" value="sa"></property>
<property name="password" value="sa"></property>
</bean>
<bean id="datasource2" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>net.sourceforge.jtds.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:jtds:sqlserver://localhost:1433;databasename=tt</value>
</property>
<property name="username" value="sa"></property>
<property name="password" value="sa"></property>
</bean>
<!-- hibernate Factory -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="datasource"></property>
<property name="mappingResources">
<list>
<value>com/baidu/ssh/bean/TtBean.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">false</prop>
<prop key="hibernate.connection.autocommit">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
</props>
</property>
</bean>
<bean id="ttDaoImplHb" class="com.baidu.ssh.dao.hb.TtDaoImplHb">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="datasource2"></property>
</bean>
<bean id="ttDaoImplJdbc" class="com.baidu.ssh.dao.jdbc.TtDaoImplJdbc">
<property name="template" ref="jdbcTemplate"></property>
</bean>