Spring4+Springmvc+Hibernate4

Spring4+Springmvc+Hibernate4 开发

一.所需的jar包

<!-- 导入java ee jar 包 -->  
    <dependency>  
        <groupId>javax</groupId>  
        <artifactId>javaee-api</artifactId>  
        <version>7.0</version>  
    </dependency> 
    <!-- log4j -->
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency> 
    <dependency>
    <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>1.5.6</version>
    </dependency>

    <!-- junit -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.11</version>
    </dependency>

    <!-- ****** Spring ****** -->
    <!-- Core Container Spring 核心包 -->
    <!-- spring-context -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- spring-context-support -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context-support</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- spring-expression 支持el表达式-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-expression</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- spring-core -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- spring-beans -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-beans</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- AOP  -->
    <!-- spring-aop -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aop</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- spring-aspects -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aspects</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- Integration -->
    <!-- spring-orm 整合框架资源-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-orm</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- spring-tx 支持所有特殊的接口和pojo 类的编程和事物管理声明-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!--  Web -->
    <!-- spring-web -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- ****** Spring ****** -->

    <!-- ****** Springmvc****** -->
    <!-- spring-webmvc -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- ****** Springmvc****** -->


    <!-- ****** Hibinate ******-->
    <!-- hibernate-core -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-core</artifactId>
        <version>4.3.11.Final</version>
    </dependency>
    <!-- hibernate-ehcache -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-ehcache</artifactId>
        <version>4.3.11.Final</version>
    </dependency>
    <!-- hibernate-commons-annotations -->
    <dependency>
        <groupId>org.hibernate.common</groupId>
        <artifactId>hibernate-commons-annotations</artifactId>
        <version>4.0.5.Final</version>
    </dependency>
    <!-- ****** Hibinate ******-->

    <!-- ****** commons ******-->
    <!-- commons-io 简化文件读写,复制输入输出流等等相关。-->
    <dependency>
        <groupId>commons-io</groupId>
        <artifactId>commons-io</artifactId>
        <version>2.4</version>
    </dependency>
    <!-- commons-fileupload 与io结合只用的文件上传及上传相关功能。-->
    <dependency>
        <groupId>commons-fileupload</groupId>
        <artifactId>commons-fileupload</artifactId>
        <version>1.3.1</version>
    </dependency>
    <!-- commons-codec 处理常用的编码方法的工具类包,例如DES、SHA1、MD5、Base64等等,用于加密算法等。-->
    <dependency>
        <groupId>commons-codec</groupId>
        <artifactId>commons-codec</artifactId>
        <version>1.10</version>
    </dependency>
    <!-- ****** commons ******-->

    <!-- ******Data Access****** -->
    <!-- mysql-connector-java -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.38</version>
    </dependency>

    <!-- spring-jdbc -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>4.2.6.RELEASE</version>
    </dependency>
    <!-- c3p0 -->
    <dependency>
        <groupId>c3p0</groupId>
        <artifactId>c3p0</artifactId>
        <version>0.9.1.2</version>
    </dependency>
    <!-- ******Data Access****** -->

二.xml配置
1.web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns="http://java.sun.com/xml/ns/javaee" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
        http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0">

    <!-- ******Spring****** -->
    <!-- 说明 
    1.在启动Web项目时,容器(比如Tomcat)会读web.xml配置文件中的两个节点<listener>和<contex-param>。
    2.接着容器会创建一个ServletContext(上下文),应用范围内即整个WEB项目都能使用这个上下文。
    3.接着容器会将读取到<context-param>转化为键值对,并交给ServletContext。
    4.容器创建<listener></listener>中的类实例,即创建监听(备注:listener定义的类可以是自定义的类但必须需要继承ServletContextListener)。
    5.在监听的类中会有一个contextInitialized(ServletContextEvent event)初始化方法,在这个方法中可以通过
      event.getServletContext().getInitParameter("contextConfigLocation")来得到context-param 设定的值。
         在这个类中还必须有一个contextDestroyed(ServletContextEvent event) 销毁方法.
         用于关闭应用前释放资源,比如说数据库连接的关闭。
    6.得到这个context-param的值之后,你就可以做一些操作了.注意,这个时候你的WEB项目还没有完全启动完成.
         这个动作会比所有的Servlet都要早。
    -->
    <!-- 
    由上面的初始化过程可知容器对于web.xml的加载过程是context-param >> listener  >> fileter  >> servlet
    使用: 
    1.页面中
      ${initParam.contextConfigLocation}
    2.Servlet中
      String paramValue=getServletContext().getInitParameter("contextConfigLocation")
     -->

    <!-- 初始化上下文参数 这里的contextConfigLocation名字 不能改,否则会默认到WEB-INFO 下面去找--> 
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext.xml</param-value>
    </context-param>

    <!-- 加载spring 监听 -->
    <!-- 方式一 -->
    <listener>
        <listener-class>
            org.springframework.web.context.ContextLoaderListener
        </listener-class>
    </listener>
    <!-- 方式二 -->
    <!-- 
    <servlet>    
        <servlet-name>context</servlet-name>    
        <servlet-class>    
           //自定义servlet 继承  org.springframework.web.context.ContextLoaderListener.class
        </servlet-class>    
        <load-on-startup>1</load-on-startup>    
    </servlet>   
     -->
    <!-- ******Spring****** -->

    <!-- ******SpringMVC****** -->
    <!-- 配置spring mvc的相关内容,此处的servlet-name任意,但必须有<your servlet-name>-servlet.xml与之对应 -->
    <servlet>
        <servlet-name>spingmvc</servlet-name>
        <!-- DispatcherServlet主要用作职责调度工作,本身主要用于控制流程,主要职责如下:
             1、文件上传解析,如果请求类型是multipart将通过MultipartResolver进行文件上传解析;
             2、通过HandlerMapping,将请求映射到处理器(返回一个HandlerExecutionChain,它包括一个处理器、多个HandlerInterceptor拦截器);
             3、通过HandlerAdapter支持多种类型的处理器(HandlerExecutionChain中的处理器);
             4、通过ViewResolver解析逻辑视图名到具体视图实现;
             5、本地化解析;
             6、渲染具体的视图等;
             7、如果执行过程中遇到异常将交给HandlerExceptionResolver来解析。
                                从以上我们可以看出DispatcherServlet主要负责流程的控制(而且在流程中的每个关键点都是很容易扩展的) -->
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!-- Spring Web MVC框架将加载“classpath:dispatcherservlet-config.xml”来进行初始化上下文
                          而不是“/WEB-INF/[servlet名字]-servlet.xml(这是是默认)”。 -->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:dispatcherservlet-config.xml</param-value>
        </init-param>
        <!-- 标记容器是否在启动的时候就加载这个servlet。
              当值为0或者大于0时,表示容器在应用启动时就加载这个servlet;
                                当是一个负数时或者没有指定时,则指示容器在该servlet被选择时才加载。
                                正数的值越小,启动该servlet的优先级越高。-->
        <load-on-startup>2</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>spingmvc</servlet-name>
        <url-pattern>*.do</url-pattern>
    </servlet-mapping>
    <!-- ContextLoaderListener初始化的上下文加载的Bean是对于整个应用程序共享的,不管是使用什么表现层技术,
                一般如DAO层、Service层Bean;
         DispatcherServlet初始化的上下文加载的Bean是只对Spring Web MVC有效的Bean,
                      如Controller、HandlerMapping、HandlerAdapter等等,该初始化上下文应该只加载Web相关组件。 -->
    <!-- ******SpringMVC****** -->

    <!-- ******FILTER****** -->
    <!-- 配置过滤器,同时把所有的请求都转为utf-8编码 --> 
    <filter>
        <filter-name>characterencodingfilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>characterencodingfilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping> 
    <!-- ******FILTER****** -->

    <!-- ******welcome****** -->
    <!--   配置项目主页 -->
    <!--  
    <session-config>  
        <session-timeout>30</session-timeout>  
    </session-config>  
    -->  
    <welcome-file-list>  
        <welcome-file>login.do</welcome-file>  
    </welcome-file-list>
    <!-- ******welcome****** -->
</web-app>      

2.dispatcherservlet-config.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:aop="http://www.springframework.org/schema/aop" 
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/aop 
    http://www.springframework.org/schema/aop/spring-aop-4.0.xsd 
    http://www.springframework.org/schema/beans 
    http://www.springframework.org/schema/beans/spring-beans-4.0.xsd 
    http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/context/spring-context-4.0.xsd 
    http://www.springframework.org/schema/mvc 
    http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd 
    http://www.springframework.org/schema/tx 
    http://www.springframework.org/schema/tx/spring-tx-4.0.xsd">

    <!-- 扫描controller -->
    <context:component-scan base-package="com.ssh.controller"/>
    <!-- 告知Spring,我们启用注解驱动。然后Spring会自动为我们注册上几个Bean到工厂中,来处理我们的请求。
         1.RequestMappingHandlerMapping 
         2.BeanNameUrlHandlerMapping
         3.RequestMappingHandlerAdapter
         4.HttpRequestHandlerAdapter
         S.impleControllerHandlerAdapter
         6.ExceptionHandlerExceptionResolver 
         7.ResponseStatusExceptionResolver 
         8.DefaultHandlerExceptionResolver
     --> 
    <mvc:annotation-driven/>

    <!-- 对模型视图名称的解析,即在模型视图名称添加前后缀 -->  
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/view/" />
        <property name="suffix" value=".jsp" />
    </bean>
    <!-- 定义不被SpringMVC拦截的静态资源(html, js, css等文件) 资源文件 -->
    <mvc:resources location="/css/" mapping="/css/**"/>
    <mvc:resources location="/js/" mapping="/js/**"/>
    <mvc:resources location="/images/" mapping="/images/**"/>
    <mvc:resources location="/fonts/" mapping="/fonts/**"/>
    <!-- 配置拦截器 -->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/test/*" />
            <bean class="com.ssh.interceptor.MyLoginInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>
</beans>

3.applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:aop="http://www.springframework.org/schema/aop" 
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/tx   
    http://www.springframework.org/schema/tx/spring-tx-4.0.xsd   
    http://www.springframework.org/schema/context   
    http://www.springframework.org/schema/context/spring-context-4.0.xsd
    http://www.springframework.org/schema/aop        
    http://www.springframework.org/schema/aop/spring-aop-4.0.xsd" >

    <!-- 引入jdbc配置文件 -->  
    <context:property-placeholder location="classpath:jdbc.properties" /> 

    <!-- c3p0连接池 -->
    <bean id="dataSource"  
        class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">  
        <property name="driverClass" value="${jdbc.driverClass}"></property>  
        <property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>  
        <property name="user" value="${jdbc.user}"></property>  
        <property name="password" value="${jdbc.password}"></property>  
        <property name="minPoolSize" value="${jdbc.minPoolSize}"></property>
        <property name="maxPoolSize" value="${jdbc.maxPoolSize}"></property>
        <property name="initialPoolSize" value="${jdbc.initialPoolSize}"></property>
        <property name="maxIdleTime" value="${jdbc.maxIdleTime}"></property>
        <property name="acquireIncrement" value="${jdbc.acquireIncrement}"></property>
    </bean>  
    <!-- 配置数据源  
    <bean id="dataSource"  
        class="org.springframework.jdbc.datasource.DriverManagerDataSource">  
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />  
        <property name="url" value="jdbc:mysql://127.0.0.1/mqtttest" />  
        <property name="username" value="root" />  
        <property name="password" value="123456" />  
    </bean> 
    --> 
    <!--  配置hibernate SessionFactory-->  
    <bean id="sessionFactory"  
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <!-- 注入连接池对象 -->  
        <property name="dataSource" ref="dataSource" /> 
        <!-- 注入hibernate框架参数 --> 
        <property name="hibernateProperties">  
            <props>  
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>  
                <prop key="hibernate.hbm2ddl.auto">update</prop>  
                <prop key="hibernate.show_sql">true</prop>  
                <prop key="hiberante.format_sql">true</prop>

        </property>
        <!--两种方式映射 注解和xml 配置-->
        <!-- 注入映射描述文件 (注解方式)
        <property name="configLocations">  
            <list>  
                <value>  
                   classpath*:hibernate/hibernate.cfg.xml  
                </value>  
            </list>  
        </property>
         --> 
        <!-- xml 配置  -->
        <property name="mappingLocations" value="classpath:com/ssh/bean/*.hbm.xml">
        </property> 

    </bean>  

    <!-- 事务管理器 -->  
    <bean id="transactionManager"  
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">  
        <property name="sessionFactory" ref="sessionFactory"></property>  
    </bean>  

    <!-- 事务代理类 -->  
    <bean id="transactionBese"  
        class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"  
        lazy-init="true" abstract="true">  
        <property name="transactionManager" ref="transactionManager"></property>  
        <property name="transactionAttributes">  
            <props>  
                <prop key="add*">PROPAGATION_REQUIRED,-Exception</prop>  
                <prop key="update*">PROPAGATION_REQUIRED,-Exception</prop>  
                <prop key="insert*">PROPAGATION_REQUIRED,-Exception</prop>  
                <prop key="modify*">PROPAGATION_REQUIRED,-Exception</prop>  
                <prop key="delete*">PROPAGATION_REQUIRED,-Exception</prop>  
                <prop key="del*">PROPAGATION_REQUIRED,-Exception</prop>  
                <prop key="get*">PROPAGATION_NEVER</prop>  
            </props>  
        </property>  
    </bean>  

    <!-- 导入相关配置 -->
    <import resource="classpath:applicationContext-dao.xml"/>

</beans>

4.applicationContext-dao.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:aop="http://www.springframework.org/schema/aop" 
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/tx   
    http://www.springframework.org/schema/tx/spring-tx-4.0.xsd   
    http://www.springframework.org/schema/context   
    http://www.springframework.org/schema/context/spring-context-4.0.xsd
    http://www.springframework.org/schema/aop        
    http://www.springframework.org/schema/aop/spring-aop-4.0.xsd" >

    <context:component-scan base-package="com.ssh.dao.impl"></context:component-scan>
    <!-- hibernateTemplate 方式 注入hibernateTemplate 
    <bean id="hibernateTemplate" class="org.springframework.orm.hibernate4.HibernateTemplate"> 
        <property name="sessionFactory">
            <ref bean="sessionFactory"/>
        </property>
    </bean>
    -->
    <!-- 注入dao 
    <bean id="userdao" class="com.ssh.dao.impl.UserDaoImpl">
        <property name="hibernateTemplate">
            <ref bean="hibernateTemplate"/>
        </property>
    </bean>
    -->
    <bean id="userdao" class="com.ssh.dao.impl.UserDaoImpl"></bean>

</beans>

5.jdbc.properties

jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.jdbcUrl=jdbc:mysql://localhost:3306/mqtttest?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
jdbc.user=root
jdbc.password=123456
#最小连接数
jdbc.minPoolSize=5
#定义最大连接数  
jdbc.maxActive=20 
#定义最大空闲  
jdbc.maxIdle=20  
#连接池中保留的最大连接数。Default: 15
jdbc.maxPoolSize=30
#初始化时获取的连接数,取值应在minPoolSize与maxPoolSize之间。Default: 3
jdbc.initialPoolSize=10
#最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0
jdbc.maxIdleTime=0
#当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 
jdbc.acquireIncrement=5
jdbc.initialSize=0  
#定义最小空闲  
jdbc.minIdle=1  
#定义最长等待时间  
jdbc.maxWait=60000 

6.hibernate.cfg.xml(注解方式)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>  
    <session-factory>  
        <!-- 引入需要映射的类 -->  
        <mapping class="com.ssh.bean.User"/>  
    </session-factory>  
</hibernate-configuration> 

7.user.hbm.xml(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.ssh.bean.User" table="base_user">
        <id name="id" type="int">
            <generator class="native"></generator>
        </id>
        <property name="username" type="string">
            <column name="username" not-null="true" length="255" > </column>
        </property>
        <property name="password" type="string">
            <column name="password" not-null="true" length="255" > </column>
        </property>
    </class>
</hibernate-mapping>

三.java 代码
User.java

package com.ssh.bean;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="base_user")
public class User {
    private int id;
    private String username;
    private String password;

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }
    @Column(name="username")
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    @Column(name="password")
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
}

UserDaoImpl.java

package com.ssh.dao.impl;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;


import com.ssh.bean.User;
import com.ssh.dao.UserDao;

public class UserDaoImpl implements UserDao{

    @Autowired
    private SessionFactory sessionFactory;  
//  private HibernateTemplate hibernateTemplate;

//  public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {
//      this.hibernateTemplate = hibernateTemplate;
//  }
    /**
     * hibernate4不支持getCurrentSession()。
     * @return
     */
//  public Session getSession() {
//      return sessionFactory.getCurrentSession();
//  }
    public Session getNewSession() {
        return sessionFactory.openSession();
    }

    public void flush() {        
        getNewSession().flush();    
    }       

    public void clear() {         
        getNewSession().clear();     
    }

    @Override
    public User findUser(final String username) {
        User user = new User();
        final String hql = "from User where username = ?";
        Session session = getNewSession();
        Query query= session.createQuery(hql);
        query.setParameter(0,username);
        user = (User) query.uniqueResult();
        session.close();
//      HibernateTemplate 方式        
//      final String hql = "from User where username = ?";
//      User user = (User) hibernateTemplate.execute(new HibernateCallback<Object>() {
//          @Override
//          public Object doInHibernate(Session session) throws HibernateException {
//              // TODO Auto-generated method stub
//              Query query = session.createQuery(hql);
//              query.setParameter(0, username);
//              return query.uniqueResult();
//          }
//      });
        return user;
    }

}

两方式实现;
1.使用 HibernateTemplate ,需要写set 方法;
2.直接使用SessionFactory,注意hibernate4 不支持getCurrentSession()。

四.测试

    @Test
    public void springtest(){
        ApplicationContext context =
                new ClassPathXmlApplicationContext(new String[] {"applicationContext.xml"});
        UserDao us = (UserDao) context.getBean("userdao");
        User user = us.findUser("admin");
        System.out.println("user="+user.getPassword());
    }

结果
这里写图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值