程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> SpringMVC+Spring+Mybatis整合

SpringMVC+Spring+Mybatis整合

編輯:關於C++

創建web工程

用eclipse或idea創建一個web工程,在這裡演示使用idea,項目命名為ssm

建立工程目錄框架

根據習慣,簡歷包目錄,分別為

config
在其中創建兩個子包mybatis和spring,分別用來放置spring、mybatis配置文件 mapper
用來放置mybatis的mapper接口和mapper.xml service
service層的javabean controller
controller的javabean pojo
簡單的POJO類

這裡寫圖片描述

在WEB-INF下建立兩個目錄<喎?/kf/ware/vc/" target="_blank" class="keylink">vcD4NCmxpYjxiciAvPg0KamFysPzEv8K8IHZpZXdzPGJyIC8+DQpqc3DK0828xL/CvA0KPHA+PGltZyBhbHQ9"這裡寫圖片描述" src="/uploadfile/Collfiles/20150703/20150703083640485.png" title="\" />

導入jar包

一共需要如下jar包

spring所有包 mybatis spring-mybatis整合包 aspectj jstl log4j c3p0 mysql

這裡寫圖片描述

百度雲下載 鏈接:http://pan.baidu.com/s/1dDB8cxV 密碼:3cqp

添加mybatis配置文件

在config.mybatis下創建mybatis.xml配置文件,SSM整合和mybatis在不需要二級緩存等配置時,mybatis配置文件只需要一個框架,不需要書寫具體內容,框架如下







添加spring和springmvc配置文件

springmvc

在config.spring下創建springmvc.xml文件,用來配置springmvc





       
       

       
       

       
       
              
              
              
       


applicationContext-dao.xml

在config.spring下創建applicationContext-dao.xml文件,用來配置DAO層的內容,在這裡連接數據庫的數據源使用C3P0,所以在這之前先在config中添加db.properties來指定數據庫連接信息

jdbc.driver = com.mysql.jdbc.Driver
jdbc.url = jdbc:mysql://127.0.0.1:3306/mybatis?characterEncoding=UTF-8
jdbc.username = root
jdbc.password = root

applicationContext-dao.xml內容:




       
       

       
       
              
              
              
              
              
              
              
       

       
       
              
              
              
              
       

       
       
              
              
       
applicationContext-service.xml

在config.spring中添加applicationContext-service.xml,用來把service層的javabean注入到IOC容器中





       
       
applicationContext-transtion.xml

在config.spring中添加applicationContext-transtion.xml,用來配置AOP事務




       
              
       

       
              
                     
                     
                     
                     
              
       

       
              
       

添加log4j配置文件

為了方便mybatis的調試,使用log4j作為日志輸出,在src根目錄中添加log4j.properties

log4j.rootLogger=DEBUG,Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
log4j.logger.org.apache=INFO

修改web.xml文件

web.xml需要實現三個功能

配置spring文件


    contextConfigLocation
    classpath:cn/elinzhou/OrderSpringMVC/config/spring/applicationContext-*.xml



    org.springframework.web.context.ContextLoaderListener
配置springmvc中的前端控制器


    dispatcher
    org.springframework.web.servlet.DispatcherServlet
    
        contextConfigLocation
        
        classpath:cn/elinzhou/OrderSpringMVC/config/spring/springmvc.xml
    
    1


    dispatcher
    /
解決post亂碼問題


    CharacterEncodingFilter
    org.springframework.web.filter.CharacterEncodingFilter
    
        encoding
        utf-8
    


    CharacterEncodingFilter
    /*

創建pojo類

這裡使用一張用戶表做示例,表結構如下

DROP TABLE IF EXISTS `user`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `user` (
  `id` int(11) NOT NULL auto_increment,
  `username` varchar(32) NOT NULL COMMENT '用戶名稱',
  `sex` char(1) default NULL COMMENT '性別',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=31 DEFAULT CHARSET=utf8;

根據表結構建立POJO類

package cn.elinzhou.OrderSpringMVC.pojo;

import java.util.Date;

public class User {
    private Integer id;

    private String username;

    private String sex;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username == null ? null : username.trim();
    }
    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex == null ? null : sex.trim();
    }
}

創建mapper接口和mapper.xml

mapper.java

package com.elin4it.ssm.mapper;

import com.elin4it.ssm.pojo.User;
import java.util.List;

public interface UserMapper {
    //查詢用戶列表
    List findUser() throws Exception;
}

mapper.xml




  

創建service接口和實現

創建一個service接口,添加一個方法,用來查詢所用用戶
UserService.java

package com.elin4it.ssm.service;

import com.elin4it.ssm.pojo.User;

import java.util.List;

/**
 * Created by elin on 15-7-1.
 */
public interface UserService {
    List findUser()throws Exception;
}

添加UserService的實現類UserServiceImpl.java

package com.elin4it.ssm.service;

import com.elin4it.ssm.mapper.UserMapper;
import com.elin4it.ssm.pojo.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * Description: UserServiceImpl
 * Author: Elin Zhou
 * Create: 2015-07-01 20:59
 */
@Service
public class UserServiceImpl implements UserService {

    //自動注入mapper接口
    @Autowired
    private UserMapper userMapper;


    @Override
    public List findUser() throws Exception {
        //調用mapper接口中的方法,獲取用戶列表
        List users = userMapper.findUser();
        return users;
    }
}

創建controller

創建後端控制器,前端控制器根據用戶請求映射到後端控制器中的方法,並且返回視圖和數據來渲染視圖

package com.elin4it.ssm.controller;

import com.elin4it.ssm.pojo.User;
import com.elin4it.ssm.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

import java.util.List;
import java.util.Map;

/**
 * Description: UserController
 * Author: Elin Zhou
 * Create: 2015-07-01 19:30
 */
@Controller
@RequestMapping(/user)
public class UserController {
    //自動注入service   
    @Autowired
    private UserService userService;

    @RequestMapping(/findUser)
    public String findUser(Map map) throws Exception{
    //調用service中的查詢用戶列表方法來獲取用戶列表
        List users = userService.findUser();
        //把用戶列表放到形參傳入的map中,相當於執行request.addAttribute()方法
        map.put(users,users);

        return user/userList;
    }
}

創建對應的jsp頁面

在WEB-INF的views文件夾中添加user文件加,用來存放用戶相關的視圖,在添加一個userList.jsp文件

<%@ taglib prefix=c uri=http://java.sun.com/jsp/jstl/core %>
<%--
  Created by IntelliJ IDEA.
  User: elin
  Date: 15-7-1
  Time: 下午8:53
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType=text/html;charset=UTF-8 language=java %>

userList

id username sex ${i.id} ${i.username} ${i.sex}

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved