ssm搭建

雖然現在也做過一些項目,但是自己從頭搭起來的框架幾乎沒有,所以這兩天自己搭了一下ssm的框架,下面寫一下框架的搭建過程。並且給出增刪改查四條線來方便大家熟悉代碼。

環境準備

maven3.2.3 
eclipse luna Service Release(4.4.1) 
jdk 1.7 
tomcat7.0.40 
我們需要的工具就是這些,版本影響其實不太大。

配置

一般來說,tomcat ,jdk ,maven一起配置就可以。windows->preferences->Server配置tomcat,順便配置jdk,如圖 
這裏寫圖片描述 
這裏寫圖片描述 
到此步,tomcat配置完成 
下面配置maven,選擇菜單windows->preferences->Maven->User Settings,具體看自己的配置文件,將配置文件和maven文件夾都設置好,如圖 
這裏寫圖片描述

新建maven項目

File->New->Maven Project 新建一個maven項目 
這裏寫圖片描述 
選擇文件夾 
這裏寫圖片描述 
選擇webapp,如果剛到這個頁面不現實下面這些,把catalog選項換成Internal 
這裏寫圖片描述 
給項目起個名字 
這裏寫圖片描述

最後,還有個index.jsp報錯,我們需要引入Java EE的jar包即可。在pom.xml中引入:

    <!-- 導入java ee jar 包 -->  
    <dependency>  
        <groupId>javax</groupId>  
        <artifactId>javaee-api</artifactId>  
        <version>7.0</version>  
    </dependency>  

到現在爲止, 
一個maven項目就搭建完成了。

引入jar包

我們需要引入的jar包包括以下幾種 
spring核心包 
mybatis核心包 
spring-mybatis整合包 
MySQL連接包 
jstl標籤類 
日誌包 
json解析包 
下面是pom文件的內容

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <groupId>org.storm.ssm</groupId>
        <artifactId>maven-ssm</artifactId>
        <packaging>war</packaging>
        <version>0.0.1-SNAPSHOT</version>
        <name>maven-ssm Maven Webapp</name>
        <url>http://maven.apache.org</url>

        <properties>
            <!-- spring版本號 -->
            <spring.version>4.0.2.RELEASE</spring.version>
            <!-- mybatis版本號 -->
            <mybatis.version>3.2.6</mybatis.version>
            <!-- log4j日誌文件管理包版本 -->
            <slf4j.version>1.7.7</slf4j.version>
            <log4j.version>1.2.17</log4j.version>
        </properties>


        <dependencies>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>3.8.1</version>
                <scope>test</scope>
            </dependency>


            <!-- spring核心包 -->
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-core</artifactId>
                <version>${spring.version}</version>
            </dependency>

            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-oxm</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-tx</artifactId>
                <version>${spring.version}</version>
            </dependency>

            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-jdbc</artifactId>
                <version>${spring.version}</version>
            </dependency>

            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-webmvc</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-aop</artifactId>
                <version>${spring.version}</version>
            </dependency>

            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context-support</artifactId>
                <version>${spring.version}</version>
            </dependency>

            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-test</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <!-- mybatis核心包 -->
            <dependency>
                <groupId>org.mybatis</groupId>
                <artifactId>mybatis</artifactId>
                <version>${mybatis.version}</version>
            </dependency>
            <!-- mybatis/spring包 -->
            <dependency>
                <groupId>org.mybatis</groupId>
                <artifactId>mybatis-spring</artifactId>
                <version>1.2.2</version>
            </dependency>
            <!-- 導入java ee jar 包 -->
            <dependency>
                <groupId>javax</groupId>
                <artifactId>javaee-api</artifactId>
                <version>7.0</version>
            </dependency>
            <!-- 導入Mysql數據庫鏈接jar包 -->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>5.1.30</version>
            </dependency>
            <!-- 導入dbcp的jar包,用來在applicationContext.xml中配置數據庫 -->
            <dependency>
                <groupId>commons-dbcp</groupId>
                <artifactId>commons-dbcp</artifactId>
                <version>1.2.2</version>
            </dependency>
            <!-- JSTL標籤類 -->
            <dependency>
                <groupId>jstl</groupId>
                <artifactId>jstl</artifactId>
                <version>1.2</version>
            </dependency>
            <!-- 日誌文件管理包 -->
            <!-- log start -->
            <dependency>
                <groupId>log4j</groupId>
                <artifactId>log4j</artifactId>
                <version>${log4j.version}</version>
            </dependency>


            <!-- 格式化對象,方便輸出日誌 -->
            <dependency>
                <groupId>com.alibaba</groupId>
                <artifactId>fastjson</artifactId>
                <version>1.1.41</version>
            </dependency>


            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
                <version>${slf4j.version}</version>
            </dependency>

            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
                <version>${slf4j.version}</version>
            </dependency>
            <!-- log end -->
            <!-- 映入JSON -->
            <dependency>
                <groupId>org.codehaus.jackson</groupId>
                <artifactId>jackson-mapper-asl</artifactId>
                <version>1.9.13</version>
            </dependency>
            <!-- 上傳組件包 -->
            <dependency>
                <groupId>commons-fileupload</groupId>
                <artifactId>commons-fileupload</artifactId>
                <version>1.3.1</version>
            </dependency>
            <dependency>
                <groupId>commons-io</groupId>
                <artifactId>commons-io</artifactId>
                <version>2.4</version>
            </dependency>
            <dependency>
                <groupId>commons-codec</groupId>
                <artifactId>commons-codec</artifactId>
                <version>1.9</version>
            </dependency>


        </dependencies>
        <build>
            <finalName>maven-ssm</finalName>
        </build>
    </project>

整合spring-mybatis

jdbc.properties

這個文件配置連接數據庫的參數賦值等。

    driver=com.mysql.jdbc.Driver
    url=jdbc:mysql://localhost/ssmtest
    username=root
    password=123456
    #定義初始連接數  
    initialSize=0  
    #定義最大連接數  
    maxActive=20  
    #定義最大空閒  
    maxIdle=20  
    #定義最小空閒  
    minIdle=1  
    #定義最長等待時間  
    maxWait=60000

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 

spring-mybatis.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"  
        xmlns:context="http://www.springframework.org/schema/context"  
        xmlns:mvc="http://www.springframework.org/schema/mvc"  
        xsi:schemaLocation="http://www.springframework.org/schema/beans    
                            http://www.springframework.org/schema/beans/spring-beans-3.1.xsd    
                            http://www.springframework.org/schema/context    
                            http://www.springframework.org/schema/context/spring-context-3.1.xsd    
                            http://www.springframework.org/schema/mvc    
                            http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">  
      <!-- 自動掃描 -->  
        <context:component-scan base-package="com.cn.ssm" /> 
         <!-- 引入配置文件 -->  
        <bean id="propertyConfigurer"  
            class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
            <property name="location" value="classpath:jdbc.properties" />  
        </bean>  

        <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/ssm/mapping/*.xml"></property>  
        </bean>  

        <!-- DAO接口所在包名,Spring會自動查找其下的類 -->  
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
            <property name="basePackage" value="com.cn.ssm.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>  


        </beans>

到此爲止,spring和mybatis的整合就完成了,下面做springmvc的整合。

整合springmvc

spring-mvc.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"  
        xmlns:context="http://www.springframework.org/schema/context"  
        xmlns:mvc="http://www.springframework.org/schema/mvc"  
        xsi:schemaLocation="http://www.springframework.org/schema/beans    
                            http://www.springframework.org/schema/beans/spring-beans-3.1.xsd    
                            http://www.springframework.org/schema/context    
                            http://www.springframework.org/schema/context/spring-context-3.1.xsd    
                            http://www.springframework.org/schema/mvc    
                            http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">  
        <!-- 自動掃描該包,使SpringMVC認爲包下用了@controller註解的類是控制器 -->  
        <context:component-scan base-package="com.cn.ssm.controller" />  

        <!--避免IE執行AJAX時,返回JSON出現下載文件 -->  
        <bean id="mappingJacksonHttpMessageConverter"  
            class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">  
            <property name="supportedMediaTypes">  
                <list>  
                    <value>text/html;charset=UTF-8</value>  
                </list>  
            </property>  
        </bean>  
        <!-- 啓動SpringMVC的註解功能,完成請求和註解POJO的映射 -->  
        <bean  
            class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">  
            <property name="messageConverters">  
                <list>  
                    <ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON轉換器 -->  
                </list>  
            </property>  
        </bean>  
        <!-- 定義跳轉的文件的前後綴 ,視圖模式配置-->  
        <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
            <!-- 這裏的配置我的理解是自動給後面action的方法return的字符串加上前綴和後綴,變成一個 可用的url地址 -->  
            <property name="prefix" value="/WEB-INF/jsp/" />  
            <property name="suffix" value=".jsp" />  
        </bean>  

        <!-- 配置文件上傳,如果沒有使用文件上傳可以不用配置,當然如果不配,那麼配置文件中也不必引入上傳組件包 -->  
        <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>   

    </beans>  

以上配置文件的路徑如圖: 
這裏寫圖片描述

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">  
    <display-name>Archetype Created Web Application</display-name>  
    <!-- Spring和mybatis的配置文件 -->  
    <context-param>  
        <param-name>contextConfigLocation</param-name>  
        <param-value>classpath:spring-mybatis.xml</param-value>  
    </context-param>  
    <!-- 編碼過濾器 -->  
    <filter>  
        <filter-name>encodingFilter</filter-name>  
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
        <async-supported>true</async-supported>  
        <init-param>  
            <param-name>encoding</param-name>  
            <param-value>UTF-8</param-value>  
        </init-param>  
    </filter>  
    <filter-mapping>  
        <filter-name>encodingFilter</filter-name>  
        <url-pattern>/*</url-pattern>  
    </filter-mapping>  
    <!-- Spring監聽器 -->  
    <listener>  
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
    </listener>  
    <!-- 防止Spring內存溢出監聽器 -->  
    <listener>  
        <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>  
    </listener>  

    <!-- 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>  

    <servlet-mapping>  

      <servlet-name>default</servlet-name>  

      <url-pattern>*.jpg</url-pattern>  

</servlet-mapping>  

<servlet-mapping>  

      <servlet-name>default</servlet-name>  

      <url-pattern>*.js</url-pattern>  

</servlet-mapping>  

<servlet-mapping>  

      <servlet-name>default</servlet-name>  

      <url-pattern>*.css</url-pattern>  

</servlet-mapping>  
<servlet-mapping>  

      <servlet-name>default</servlet-name>  

      <url-pattern>*.gif</url-pattern>  

</servlet-mapping>  

    <welcome-file-list>  
        <welcome-file>/index.jsp</welcome-file>  
    </welcome-file-list>  

</web-app> 

需要注意的是,spring-mybatis和spring-mvc這兩個配置文件裏面涉及到路徑的要改成自己的實際路徑,不然會報錯。

測試

框架搭建完成,然後我們連接數據庫測試一下,下面是數據庫創建語句

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=125556 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of user_t
-- ----------------------------
INSERT INTO `user_t` VALUES ('12', '123', '123', '14');
INSERT INTO `user_t` VALUES ('123', 'test', '123', '13');
INSERT INTO `user_t` VALUES ('11111', 'zahgnsan', '123', '23');
INSERT INTO `user_t` VALUES ('123456', 'username', '12id', '34');
INSERT INTO `user_t` VALUES ('125555', '123', '123', '14');

建表成功以後,我們使用mybatis的插件來生成接口和mapper的代碼,可以參考這個博客: 
http://blog.csdn.net/zhshulin/article/details/23912615 
生成之後將文件拷貝到我們的目錄下,如圖: 
這裏寫圖片描述

然後我們從前臺到後臺寫一條線,先寫一個查詢。敲之前記得先把maven更新一下。

IUserService.java

package com.cn.ssm.service;

import com.cn.ssm.pojo.User;

public interface IUserService {

    public User getUserById(int userId);

}

UserServiceImpl.java

package com.cn.ssm.service.impl;
import javax.annotation.Resource;
import javax.transaction.Transactional;
import org.springframework.stereotype.Service;
import com.cn.ssm.dao.UserMapper;
import com.cn.ssm.pojo.User;
import com.cn.ssm.service.IUserService;

@Service
@Transactional
public class UserServiceImpl implements IUserService {

    @Resource
    public UserMapper userMapper;

    public User getUserById(int userId) {
        // TODO Auto-generated method stub

        return this.userMapper.selectByPrimaryKey(userId);
    }

}

UserController.java

package com.cn.ssm.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.ssm.pojo.User;
import com.cn.ssm.service.IUserService;

@Controller
@RequestMapping("/user")
public class UserController {

    @Resource
    private IUserService userService;

    @RequestMapping("userShow")
    public String toIndex(HttpServletRequest request,Model model){
        int userId = Integer.parseInt(request.getParameter("id"));

        User user = userService.getUserById(userId);

        model.addAttribute("user", user);

        return "showUser";
    }

}

showUser.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>  
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
<html>  
  <head>  
    <title>測試</title>  
  </head>  

  <body>  
    ${user.userName}  
  </body>  
</html> 

顯示

啓動tomcat,然後在瀏覽器的地址欄輸入http://localhost:8080/ssm/user/userShow?id=12 
將ssm改成你的項目名稱。 
顯示如圖: 
這裏寫圖片描述

搭建這個框架,我基本上是參照這個博客來做的,因爲覺得應該總結一下自己這兩天的成功,所以寫了這篇博客,不過大部分代碼和原博客一樣,所以大家可以去看看原博客,寫的超級好。附鏈接:http://blog.csdn.net/zhshulin/article/details/37956105/ 
謝謝。

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