手记

我的学习记录——ssm整合1

ssm框架整合
dao层:spring和mybatis整合,由spring来管理mapper接口
service层:spring管理接口和对象
web层:springMVC调用service层接口

1.spring和mabatis整合
(1)创建SqlMapConfig.xml配置文件
(2)创建applicationContext-dao.xml配置文件

    <!-- 加载数据库配置文件 -->
    <context:property-placeholder location="classpath:db.properties"/>

    <!-- 采用c3p0连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${jdbc.driver}"></property>
        <property name="jdbcUrl" value="${jdbc.url}"></property>
        <property name="user" value="${jdbc.username}"></property>
        <property name="password" value="${jdbc.password}"></property>
    </bean>

    <!-- 创建sqlSessionFactory -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"></property>
        <!-- 配置mybatis核心配置文件地址 -->
        <property name="configLocation" value="classpath:mybatis/SqlMapConfig.xml"></property>
    </bean>

    <!-- 开启mapper扫描,在此处开启扫描mapper,在SqlMapConfig.xml中就不用配置mapper -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.melon.mapper"></property>
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
    </bean>

(3)编写dao层接口和mapper

public interface UserMapper {
    public void register(User user) throws Exception;

    public List<User> searchUser(User user) throws Exception;
}

<mapper namespace="com.melon.mapper.UserMapper">  

    <sql id="searchUser">
        <if test="id != null">
            id = #{id}
        </if>
        <if test="username != null">
            and username = #{username}
        </if>
        <if test="address != null">
            and address = #{address}
        </if>
    </sql>

    <insert id="register" parameterType="user">
        insert into userlist (username,password,address) values (#{username},#{password},#{address})
    </insert>

    <select id="searchUser" parameterType="user" resultType="user">
        select * from userlist
        <where>
            <include refid="searchUser"></include>
        </where>
    </select>

</mapper>

2.spring与service层整合,service层调用mapper接口方法,创建applicationContext-service.xml文件,创建service对象
3.创建事务管理器,创建applicationContext-transaction.xml文件

    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>

    <!-- 开启注解事务管理器 -->
    <tx:annotation-driven transaction-manager="transactionManager"/>

4.在web层使用springMVC
(1)创建springmvc.xml文件

<!-- 自动加载注解处理器映射器和处理器适配器 -->
<mvc:annotation-driven></mvc:annotation-driven>

<!-- 开启注解扫描 -->
<context:component-scan base-package="com.melon.controller"></context:component-scan>

<!-- 视图管理器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <!-- 设置返回页面的前缀和后缀 -->
    <property name="prefix" value="/WEB-INF/jsp/"></property>
    <property name="suffix" value=".jsp"></property>
</bean>
(2)在web.xml中配置前端控制器
  <servlet>
    <servlet-name>springMVC</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:spring/springmvc.xml</param-value>
    </init-param>
  </servlet>
  <servlet-mapping>
    <servlet-name>springMVC</servlet-name>
    <url-pattern>*.action</url-pattern>
  </servlet-mapping>

5.编写Controller

//@Controller注解表明这是一个Controller
@Controller
//此注解表示这个Controller的根路径,若要访问Register需要在前面加上/userService
@RequestMapping("/userService")
public class UserServiceHandler {

    @Autowired
    private UserService userService;

    //RequestMapping配置此控制器的访问路径
    @RequestMapping("/register")
    public String Register() throws Exception {
        User user = new User();
        user.setUsername("simon");
        user.setPassword("123");
        user.setAddress("龙江");

        userService.register(user);
        return "index";
    }

    @RequestMapping("/searchUser")
    public ModelAndView searchUser() throws Exception {
        User user = new User();
        user.setId(2);

        List<User> userList = userService.searchUser(user);
        ModelAndView modelAndView = new ModelAndView();
        modelAndView.addObject("userList", userList);
        modelAndView.setViewName("userList");
        return modelAndView;
    }
}

6.在web.xml中加载所有spring配置文件

  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>/WEB-INF/classes/spring/applicationContext-*.xml</param-value>
  </context-param>
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
2人推荐
随时随地看视频
慕课网APP