首页 > 学院 > 开发设计 > 正文

SSH实例(2)

2019-11-15 00:22:58
字体:
来源:转载
供稿:网友
SSH实例(2)

在WebContent/WEB-INF/下新建两个文件:applicationContext.xml和web.xml。

web.xml:

<?xml version="1.0" encoding="UTF-8"?><web-app version="2.5"     xmlns="http://java.sun.com/xml/ns/javaee"     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">   <filter>  <filter-name>struts2</filter-name>  <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> </filter>  <filter-mapping>  <filter-name>struts2</filter-name>  <url-pattern>/*</url-pattern> </filter-mapping>  <listener>  <listener-class>org.sPRingframework.web.context.ContextLoaderListener</listener-class> </listener>   <welcome-file-list>      <welcome-file>index.jsp</welcome-file> </welcome-file-list>   </web-app>

web.xml指定了filter和listener。

applicationContext.xml:

<?xml version="1.0" encoding="UTF-8"?><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-3.0.xsd">    <!-- 配置sessionFactory -->     <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">        <property name="dataSource" >            <ref local="dataSource"/>        </property>        <!-- 配置Hibernate的属性 -->        <property name="hibernateProperties">            <props>                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>                <prop key="hibernate.show_sql">true</prop>            </props>        </property>        <!-- 指定Hibernate映射文件的路径 -->        <property name="mappingResources">            <list>                <value>com/school/entity/Clas.hbm.xml</value>            </list>        </property>     </bean>     <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">        <property name="driverClassName">            <value>com.mysql.jdbc.Driver</value>        </property>        <property name="url">            <value>jdbc:mysql://localhost:3306/myssh            </value>        </property>        <property name="username">            <value>root</value>        </property>        <property name="passWord">            <value>root</value>        </property>    </bean>    <bean id="clasDAO"         class="com.school.dao.ClasDAOImpl"         abstract="false" lazy-init="default" autowire="default">         <property name="sessionFactory">             <ref bean="sessionFactory" />         </property>     </bean>        <bean id="clasService" class="com.school.service.ClasServiceImpl">         <property name="clasDAO" ref="clasDAO"></property>    </bean>     <bean id="clasQueryAction" class="com.school.action.ClasQueryAction">         <property name="clasService" ref="clasService"></property>     </bean>    <bean id="clasAction" class="com.school.action.ClasAction">         <property name="clasService" ref="clasService"></property>     </bean> </beans>

applicationContext.xml定义了多个bean,其中dataSource定义了连接数据库的url、用户名、密码等属性。sessionFactory配置了Hibernate的属性以及映射文件的路径,映射的com/school/entity/Clas.hbm.xml文件如下:

<?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 name="com.school.entity.Clas" table="clas">        <id name="id" type="java.lang.Integer">            <column name="ID" precision="22" scale="0" />            <generator class="identity" />        </id>        <property name="name" type="java.lang.String">            <column name="NAME"  length="50" not-null="true">                <comment>课程名称</comment>            </column>        </property>        <property name="comment" type="java.lang.String">            <column name="COMMENT" length="500" not-null="false">                <comment>课程介绍</comment>            </column>        </property>    </class></hibernate-mapping>

该文件对应MySQL数据库中的clas表,表的结构如下:

对应的Clas文件如下:

package com.school.entity;public class Clas {        // 课程id    private int id;    // 课程名称    private String name;    // 课程介绍    private String comment;        // 默认构造方法    public Clas() {    }        // 包含全部属性的构造方法    public Clas(int id, String name, String comment) {        super();        this.id = id;        this.name = name;        this.comment = comment;    }        public int getId() {        return id;    }    public void setId(int id) {        this.id = id;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public String getComment() {        return comment;    }    public void setComment(String comment) {        this.comment = comment;    }}

在applicationContext.xml中,各个bean之间存在引用关系:

clasDAO对应的类为com.school.dao.ClasDAOImpl,以sessionFactory作为参数;

clasService对应的类为com.school.service.ClasServiceImpl,以clasDAO作为参数;

clasQueryAction对应的类为com.school.action.ClasQueryAction,以clasService作为参数;

clasAction对应的类为com.school.action.ClasAction,以clasService作为参数。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表