struts,spring,hibernate配置文件头,schema

本文详细介绍了Struts2、Spring和Hibernate的配置文件(struts.xml、applicationContext.xml和hibernate.cfg.xml)以及它们之间的整合过程。包括配置文件的XML声明、组件扫描、数据源配置、事务管理、本地会话工厂和事务通知的配置。此外,还阐述了如何通过hibernate.cfg.xml和xxx.hbm.xml文件实现持久化类与数据库表的映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一,struts.xml的dtd约束
这个很好找,在struts2-core.jar

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<!-- 这里开始写 -->
</struts>



二,spring的配置文件头

<?xml version="1.0"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">
<!-- 组件扫描 -->
<context:component-scan base-package="要扫描的包路径,多个用逗号隔开,如com.baidu.service,com.baidu.dao" />

<!-- 分散配置 -->
<context:property-placeholder location="classpath:jdbc.properties"/>

<!-- 数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driverclass}" />
<property name="jdbcUrl" value="${jdbc.url}" />
<property name="user" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />

<property name="maxPoolSize" value="${c3p0.pool.size.max}" />
<property name="minPoolSize" value="${c3p0.pool.size.min}" />
<property name="initialPoolSize" value="${c3p0.pool.size.ini}" />
<property name="acquireIncrement" value="${c3p0.pool.size.increment}" />
</bean>

<!-- 本地会话工厂bean,spring整合hibernate的核心入口 -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 注入数据源 -->
<property name="dataSource" ref="dataSource" />
<!-- 指定hibernate配置文件 -->
<property name="configLocation" value="classpath:hibernate.cfg.xml" />
<!-- 指定映射文件目录 -->
<property name="mappingDirectoryLocations">
<list>
<value>classpath:com/baidu/domain</value>
</list>
</property>
</bean>

<!-- 事务管理器,在service层面上实现事务管理,而且达到平台无关性 -->
<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>

<!-- 配置事务通知 -->
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
<tx:method name="save*" propagation="REQUIRED" isolation="DEFAULT" />
<tx:method name="update*" propagation="REQUIRED" isolation="DEFAULT" />
<tx:method name="delete*" propagation="REQUIRED" isolation="DEFAULT" />
<tx:method name="batch*" propagation="REQUIRED" isolation="DEFAULT" />
<tx:method name="new*" propagation="REQUIRED" isolation="DEFAULT" />

<tx:method name="get*" propagation="REQUIRED" isolation="DEFAULT" read-only="true"/>
<tx:method name="load*" propagation="REQUIRED" isolation="DEFAULT" read-only="true"/>
<tx:method name="find*" propagation="REQUIRED" isolation="DEFAULT" read-only="true"/>

<tx:method name="*" propagation="REQUIRED" isolation="DEFAULT" />
</tx:attributes>
</tx:advice>

<!-- aop事务配置 -->
<aop:config>
<aop:advisor advice-ref="txAdvice" pointcut="execution(* *..*Service.*(..))"/>
</aop:config>
</beans>



三,hibernate
1, hibernate.cfg.xml
xml声明很好找,打开hibernate3.jar的org.hibernate包下最后第二个文件hibernate-configuration-3.0.dtd,第3行到第5行即是

<?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">
<hibernate-configuration>
<session-factory>
<!-- 连接数据库的基本配置信息 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/数据库名?useUnicode=true&characterEncoding=utf8</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<!-- 方言,使用hibernate的方言用来通知操作的数据库是mysql数据库 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!--
自动将配置文件.hbm.xml的配置信息关联数据库表
* create:当表不存在的时候会创建表,当表存在的时候也会先删除表再创建表,然后再往表中添加数据(此时不能保存历史数据)
* none:将数据会追加到当前的数据库的表中(此时会保留历史数据),但是没有创建表的功能
* update:当表不存在的时候会创建表,如果存在直接向表中追加数据(此时会保留历史数据)
-->
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- 是否显示sql语句 默认false-->
<property name="hibernate.show_sql">true</property>
<!-- 是否对sql语句进行格式化 false-->
<property name="hibernate.format_sql">false</property>
</session-factory>
</hibernate-configuration>



2,xxx.hbm.xml
xml声明很好找,打开hibernate3.jar的org.hibernate包下最后一个文件hibernate-mapping-3.0.dtd,第3行到第5行即是

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!--
class:映射持久化类javabean与表的映射
* name:持久化类javabean的名称,(全路径)
* table:持久化类javabean对应的数据库的表名
-->
<class name="xx.xx.Customer" table="customer">
<!--
id:用来映射主键ID
* name:持久化javabean的属性名称
* type:表示hibernate的数据类型,用来关联java的数据类型和数据库的数据类型
* column:持久化类javabean的属性对应的数据库字段的名称
* generator:表示主键生成策略
-->
<id name="id" type="integer">
<column name="id"></column>
<generator class="increment"></generator>
</id>
<!--
property:映射持久化类javabean的属性与数据库表中的字段
* name:持久化类javabean的属性的名称
* column:持久化类javabean的属性对应的数据库字段的名称
* type:表示hibernate的数据类型,用来关联java的数据类型和数据库的数据类型
-->
<property name="name" column="name" type="string"></property>
<property name="age" column="age" type="integer"></property>
<property name="des" column="des" type="string"></property>
</class>
</hibernate-mapping>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值