SSM框架入門教程

SSM入門教程

SSM(Spring+SpringMVC+Mybatis)屬於開源的輕量級框架,其中,Spring的主要功能事封裝實體類,在配置文件裏設置相應屬性便可使用。而Mybatis則完成了JDBC的封裝,通過配置文件來關聯SQL語句映射。SpringMVC主要爲前端控制器、處理器映射器、處理器適配器以及視圖解析器等等組成,SSM框架目前應用範圍相當廣泛,適用於大中型項目的開發,極大提升了程序開發效率,運用此框架節約了開發成本,而且學習起來相對容易。
1、基本概念
1.1、Spring
SSM(Spring+SpringMVC+Mybatis)屬於開源的輕量級框架,其中,Spring的主要功能事封裝實體類,在配置文件裏設置相應屬性便可使用。而Mybatis則完成了JDBC的封裝,通過配置文件來關聯SQL語句映射。SpringMVC主要爲前端控制器、處理器映射器、處理器適配器以及視圖解析器等等組成,SSM框架目前應用範圍相當廣泛,適用於大中型項目的開發,極大提升了程序開發效率,運用此框架節約了開發成本,而且學習起來相對容易。

1.2、SpringMVC

    Spring MVC屬於SpringFrameWork的後續產品,已經融合在Spring Web Flow裏面.Spring MVC分離了控制器、模型對象、分派器以及處理程序對象的角色,這種分離讓它們更容易進行定製。

1.3、MyBatis

MyBatis本是apache的一個開源項目iBatis , 2010 年這個項目由 apache software foundation遷移到了google code,並改名爲MyBatis.MyBatis是一個基於Java的持久化框架iBATIS提供的持久層框架,包括SQL Maps和Data Access Objects (DAO) MyBatis消除了幾乎所有的JDBC代碼和參數的手工設置以及結果集的檢索.MyBatis 使用簡單的XML或註解用於配置和原始映射,將接口和Java的POJOs(Plain Old Java Objects,普通的Java對象)映射成數據庫中的記錄

2、開發環境搭建
如果需要,參看之前的博文: http://blog.csdn.net/zhshulin/article/details/30779873

3、Maven Web項目創建
如果需要,參看之前的博文: http://blog.csdn.net/zhshulin/article/details/37921705

4、SSM整合

    下面主要介紹三大框架的整合,至於環境的搭建以及項目的創建,參看上面的博文。這次整合我分了 2 個配置文件 ,分別是 spring-mybatis.xml ,包含 spring 和 mybatis 的配置文件,還有個是 spring-mvc 的配置文件,此外有 2 個資源文件 : jdbc.propertis 和 log4j.properties 。完整目錄結構如下:

使用框架都是較新的版本 :

Spring 4.0.2 RELEASE

Spring MVC 4.0.2 RELEASE

MyBatis 3.2.6

4.1、Maven引入需要的JAR包
爲了方便後面說的時候不需要引入JAR包,我這裏 直接給出所有需要的JAR包,這都是基本的JAR包 ,每個包的是幹什麼的都有註釋,就不再多說了。

pom.xml

4.2、Spring與MyBatis的整合
所有需要的 JAR 包都引入以後,首先進行 Spring 與 MyBatis 的整合,然後再進行 JUnit 測試,先看一個項目結構圖:

4.2.1、建立JDBC屬性文件
jdbc.properties (文件編碼修改爲 utf-8 )

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://10.221.10.111:8080/db_zsl
username=demao
password=demao
#定義初始連接數
initialSize=0
#定義最大連接數
maxActive=20
#定義最大空閒
maxIdle=20
#定義最小空閒
minIdle=1
#定義最長等待時間
maxWait=60000
4.2.2、建立spring-mybatis.xml配置文件
這個文件就是用來完成spring和mybatis的整合的。這裏面也沒多少行配置,主要的就是 自動掃描,自動注入,配置數據庫 。註釋也很詳細,大家看看就明白了。

spring-mybatis.xml

<?xml version="1.0" encoding="UTF-8"?>



<context:component-scan base-package=“com.cn.hnust” />



<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
	destroy-method="close">
	<property name="driverClassName" value="${driver}" />
	<property name="url" value="${url}" />
	<property name="username" value="${username}" />
	<property name="password" value="${password}" />
	<!-- 初始化連接大小 -->
	<property name="initialSize" value="${initialSize}"></property>
	<!-- 連接池最大數量 -->
	<property name="maxActive" value="${maxActive}"></property>
	<!-- 連接池最大空閒 -->
	<property name="maxIdle" value="${maxIdle}"></property>
	<!-- 連接池最小空閒 -->
	<property name="minIdle" value="${minIdle}"></property>
	<!-- 獲取連接最大等待時間 -->
	<property name="maxWait" value="${maxWait}"></property>
</bean>

<!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
	<property name="dataSource" ref="dataSource" />
	<!-- 自動掃描mapping.xml文件 -->
	<property name="mapperLocations" value="classpath:com/cn/hnust/mapping/*.xml"></property>
</bean>

<!-- DAO接口所在包名,Spring會自動查找其下的類 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
	<property name="basePackage" value="com.cn.hnust.dao" />
	<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>

<!-- (事務管理)transaction manager, use JtaTransactionManager for global tx -->
<bean id="transactionManager"
	class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
	<property name="dataSource" ref="dataSource" />
</bean>
4.2.3、Log4j的配置 爲了方便調試,一般都會使用日誌來輸出信息, Log4j是 Apache 的一個開放源代碼項目,通過使用Log4j,我們可以控制 日誌 信息輸送的目的地是 控制檯 、文件、 GUI 組件,甚至是套接口服務器、 NT 的事件記錄器、 UNIX Syslog 守護進程 等;我們也可以控制每一條日誌的輸出格式;通過定義每一條日誌信息的級別,我們能夠更加細緻地控制日誌的生成過程。
  Log4j 的配置很簡單,而且也是 通用的 ,下面 給出一個基本的配置 ,換到其他項目中也無需做多大的調整, 如果想做調整 或者想了解 Log4j 的各種配置,參看我 轉載的一篇博文 ,很詳細:

http://blog.csdn.net/zhshulin/article/details/37937365

下面給出配置文件目錄:

log4j.properties

#定義LOG輸出級別
log4j.rootLogger=INFO,Console,File
#定義日誌輸出目的地爲控制檯
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.Target=System.out
#可以靈活地指定日誌輸出格式,下面一行是指定具體的格式
log4j.appender.Console.layout = org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n

#文件大小到達指定尺寸的時候產生一個新的文件
log4j.appender.File = org.apache.log4j.RollingFileAppender
#指定輸出目錄
log4j.appender.File.File = logs/ssm.log
#定義文件最大大小
log4j.appender.File.MaxFileSize = 10MB

輸出所以日誌,如果換成DEBUG表示輸出DEBUG以上級別日誌

log4j.appender.File.Threshold = ALL
log4j.appender.File.layout = org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH:mm:ss}][%c]%m%n
4.2.4、JUnit測試
經過以上步驟(到4.2.2,log4j不配也沒影響),我們 已經完成了Spring和mybatis的整合,這樣我們就可以編寫一段測試代碼來試試是否成功了。

4.2.4.1、創建測試用表

既然我們需要測試,那麼我們就需要建立在數據庫中建立一個測試表,這個表建的很簡單, SQL 語句爲:

DROP TABLE IF EXISTS user_t;

CREATE TABLE user_t (
id int(11) NOT NULL AUTO_INCREMENT,
user_name varchar(40) NOT NULL,
password varchar(255) NOT NULL,
age int(4) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

/*Data for the table user_t */

insert into user_t(id,user_name,password,age) values (1,‘測試’,‘sfasgfaf’,24);
4.2.4.2、利用MyBatis Generator自動創建代碼

參考博文: http://blog.csdn.net/zhshulin/article/details/23912615

   這個可根據表自動創建實體類、 MyBatis 映射文件以及 DAO 接口,當然,我 習慣將生成的接口名改爲 IUserDao ,而不是直接用它生成的 UserMapper 。如果不想麻煩就 可以不改 。完成後將文件複製到工程中。如圖:

4.2.4.3、建立Service接口和實現類

目錄結構:

下面給出具體的內容:

IUserService.jave

package com.cn.hnust.service;

import com.cn.hnust.pojo.User;

public interface IUserService {
public User getUserById(int userId);
}
UserServiceImpl.java

package com.cn.hnust.service.impl;

import javax.annotation.Resource;

import org.springframework.stereotype.Service;

import com.cn.hnust.dao.IUserDao;
import com.cn.hnust.pojo.User;
import com.cn.hnust.service.IUserService;

@Service(“userService”)
public class UserServiceImpl implements IUserService {
@Resource
private IUserDao userDao;
@Override
public User getUserById(int userId) {
// TODO Auto-generated method stub
return this.userDao.selectByPrimaryKey(userId);
}

}
4.2.4.4、建立測試類

   測試類 在src/test/java中建立 ,下面測試類中 註釋掉的部分是不使用 Spring 時,一般情況下的一種測試方法 ;如果使用了 Spring 那麼就可以使用註解的方式來引入配置文件和類,然後再將 service 接口對象注入,就可以進行測試了。

   如果測試成功,表示 Spring 和 Mybatis 已經整合成功了 。輸出信息使用的是 Log4j 打印到控制檯。

package org.zsl.testmybatis;

import javax.annotation.Resource;

import org.apache.log4j.Logger;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.alibaba.fastjson.JSON;
import com.cn.hnust.pojo.User;
import com.cn.hnust.service.IUserService;

@RunWith(SpringJUnit4ClassRunner.class) //表示繼承了SpringJUnit4ClassRunner類
@ContextConfiguration(locations = {“classpath:spring-mybatis.xml”})

public class TestMyBatis {
private static Logger logger = Logger.getLogger(TestMyBatis.class);
// private ApplicationContext ac = null;
@Resource
private IUserService userService = null;

// @Before
// public void before() {
// ac = new ClassPathXmlApplicationContext(“applicationContext.xml”);
// userService = (IUserService) ac.getBean(“userService”);
// }

@Test
public void test1() {
	User user = userService.getUserById(1);
	// System.out.println(user.getUserName());
	// logger.info("值:"+user.getUserName());
	logger.info(JSON.toJSONString(user));
}

}
測試結果:

至此, 完成Spring和mybatis這兩大框架的整合 ,下面在繼續進行SpringMVC的整合。

4.3、整合SpringMVC
上面已經完成了2大框架的整合,SpringMVC的配置文件單獨放,然後在web.xml中配置整合。

4.3.1、配置spring-mvc.xml
配置裏面的註釋也很詳細,在此就不說了,主要是 自動掃描控制器,視圖模式,註解的啓動 這三個。

<?xml version="1.0" encoding="UTF-8"?>



<context:component-scan base-package=“com.cn.hnust.controller” />




text/html;charset=UTF-8
















<!-- 配置文件上傳,如果沒有使用文件上傳可以不用配置,當然如果不配,那麼配置文件中也不必引入上傳組件包 -->
<bean id="multipartResolver"  
    class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  
    <!-- 默認編碼 -->
    <property name="defaultEncoding" value="utf-8" />  
    <!-- 文件大小最大值 -->
    <property name="maxUploadSize" value="10485760000" />  
    <!-- 內存中的最大值 -->
    <property name="maxInMemorySize" value="40960" />  
</bean> 
4.3.2、配置web.xml文件 這裏面對spring-mybatis.xml的引入以及配置的spring-mvc的Servlet就是爲了完成SSM整合,之前2框架整合不需要在此處進行任何配置。配置一樣有詳細註釋,不多解釋了。

web.xml

<?xml version="1.0" encoding="UTF-8"?>


Archetype Created Web Application


contextConfigLocation
classpath:spring-mybatis.xml



encodingFilter
org.springframework.web.filter.CharacterEncodingFilter
true

encoding
UTF-8



encodingFilter
/*



org.springframework.web.context.ContextLoaderListener



org.springframework.web.util.IntrospectorCleanupListener

<!-- Spring MVC servlet -->
<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-mvc.xml</param-value>
	</init-param>
	<load-on-startup>1</load-on-startup>
	<async-supported>true</async-supported>
</servlet>
<servlet-mapping>
	<servlet-name>SpringMVC</servlet-name>
	<!-- 此處可以可以配置成*.do,對應struts的後綴習慣 -->
	<url-pattern>/</url-pattern>
</servlet-mapping>
<welcome-file-list>
	<welcome-file>/index.jsp</welcome-file>
</welcome-file-list>
4.3.3、測試 至此已經完成了SSM三大框架的整合了,接下來測試一下,如果成功了,那麼恭喜你,如果失敗了,繼續調試吧, 作爲程序員就是不停的與BUG做鬥爭 !

4.3.3.1、新建jsp頁面

showUser.jsp 此頁面僅輸出一下用戶名,完成一個 完整的簡單流程 。

<%@ page language=“java” import=“java.util.*” pageEncoding=“utf-8”%>

測試 ${user.userName} 4.3.3.2、建立UserController類

UserController.java 控制器

package com.cn.hnust.controller;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

import com.cn.hnust.pojo.User;
import com.cn.hnust.service.IUserService;

@Controller
@RequestMapping("/user")
public class UserController {
@Resource
private IUserService userService;

@RequestMapping("/showUser")
public String toIndex(HttpServletRequest request,Model model){
	int userId = Integer.parseInt(request.getParameter("id"));
	User user = this.userService.getUserById(userId);
	model.addAttribute("user", user);
	return "showUser";
}

}
4.3.3.3、部署項目

輸入地址: localhost:8080/ 項目名稱 /user/showUser?id=1

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章