SSM框架,顧名思義,就是Spring+SpringMVC+mybatis。css
經過Spring來將各層進行整合,html
經過spring來管理持久層(mybatis),java
經過spring來管理handler。web
總之,spring是將各層進行整合。spring
廢話不說了,來搭建吧。sql
共十個步驟,有點囉嗦,可是我以爲挺仔細的。不足之處,指正。數據庫
第一步,創建一個動態的web項目。
第二步,創建各個包,並導入各類jar包,我是從網上下載的。以下圖:

第三步,創建model類吧。我這邊創建一個很簡單的類,先不進行配置,配置有點頭暈。
創建user類,自建get和set方法,並構造方法:apache
1 package com.jk.model;
2
3 public class Student{
private Integer stuId;
private String stuName;
private String stuAge;
private String stuBir;
7 }
第四步,容我先配置一下mybatis的xml文件。
建一個StudentMapper.xml和StudentMapper.java 接口文件 。spring-mvc
先作一個select * from tb_student;tomcat
由於數據庫是這個樣子滴,以下圖:

配置代碼以下:
package com.jk.mapper;
import java.util.List;
import com.jk.model.Student;
public interface StudentMapper {
public List<Student> findAllUser();
}
xml文件以下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jk.mapper.StudentMapper">
<!-- 解決表名與字段不匹配 -->
<resultMap type="com.jk.model.Student" id="stuResultMap">
<id property="stuId" column="stuid"/>
<result property="stuName" column="stuname"/>
<result property="stuAge" column="stuage"/>
<result property="stuBir" column="stubir"/>
</resultMap>
<!-- -->
<select id="findStudentList" resultMap="stuResultMap" >
select * from t_student;
</select>
</mapper>
mybatis,算是完成一半了,後面的會繼續,不會停的。
須要考慮到service了。這就有了第五步了。
第五步,配置service。
首先,要看到咱們以前建的兩個包,一個是com.jk.service和com.service.impl。
在com.service中,要創建一個UserService類。代碼以下:
package com.jk.service;
import java.util.List;
import com.jk.model.Student;
public interface StuService {
public List<Student> findStuList();
}
另外一個,須要用到這個接口,implements它吧。
UserServiceImpl.java代碼以下:
package com.service.impl;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.mapper.StudentMapper;
import com.model.Student;
@Service
public class StuServiceImp implements StuService{
@Autowired
private StudentMapper studentMapper;
@Override
public List<Student> findStuList() {
List<Student> list=studentMapper.findStudentList();
System.err.println(list);
return list;
}
}
@後面的註解必定要加的,否則,會出錯的。第六步:開始寫controller吧controller,從單詞上就能看到,控制。寫一個UserController類吧。
package com.jk.contorller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("stu")
public class StuContorller {
@Autowired
private StuService stuService;
@RequestMapping("toStuShow")
public String toStuShow(){
stuService.findStuList();
return "stu/stu-show";
}
}
去看他們之間的類,去了解他們之間的關係。我以爲了解很重要。
第七步,開始配置xml文件吧,把文件放在config中。
而後就是去寫spring配置了:spring-common.xml和spring-mvc.xml依次以下。其實代碼都是我百度的,而後本身修改一下,謝謝分享。
<?xml version="1.0" encoding="UTF-8"?>
<?xml version="1.0" encoding="UTF-8"?>
xsi:schemaLocation="
<!-- 註解掃描包 -->
<context:component-scan base-package="com.jk" />
<!-- 開啓註解 -->
<mvc:annotation-driven />
<!-- 配置數據源屬性文件-->
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:jdbc.properties</value>
</list>
</property>
</bean>
<!-- 配置數據源 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</bean>
<!-- mybatis的SqlSession的工廠: SqlSessionFactoryBean dataSource:引用數據源
MyBatis定義數據源,贊成加載配置 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="mapperLocations" value="classpath:com/jk/mapper/*.xml"></property>
</bean>
<!-- mybatis自動掃描加載Sql映射文件/接口 : MapperScannerConfigurer sqlSessionFactory
basePackage:指定sql映射文件/接口所在的包(自動掃描)
-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.jk.mapper" />
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
</bean>
<!--
4. 事務管理 : DataSourceTransactionManager dataSource:引用上面定義的數據源
-->
<bean id="txManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 5. 使用聲明式事務
transaction-manager:引用上面定義的事務管理器
-->
<tx:annotation-driven transaction-manager="txManager" />
</beans>
View Code
<?xml version="1.0" encoding="UTF-8"?>
<!-- 註解掃描包 -->
<context:component-scan base-package="com.jk" />
<!-- 開啓註解 -->
<mvc:annotation-driven />
<!--
配置靜態資源,直接映射到對應的文件夾,不被DispatcherServlet處理,3.04新增功能,須要從新設置spring-mvc-3.0.xsd
<mvc:resources mapping="/img/**" location="/img/" />
<mvc:resources mapping="/js/**" location="/js/" />
<mvc:resources mapping="/css/**" location="/css/" />
<mvc:resources mapping="/html/**" location="/html/" />
-->
<!-- 定義跳轉的文件的先後綴 ,視圖模式配置-->
<bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 這裏的配置個人理解是自動給後面action的方法return的字符串加上前綴和後綴,變成一個 可用的url地址 -->
<property name="prefix" value="/WEB-INF/view/" />
<property name="suffix" value=".jsp" />
</bean>
</beans>
View Code
第八步,就是web.xml文件了。網上一大堆,隨便下,我也是從網上拷貝的。而後,在麼有錯誤的狀況下,隨着性子改。
<?xml version="1.0" encoding="UTF-8"?>
<!-- 加載Spring容器配置-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 設置Spring容器加載全部的配置文件的路徑 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-*.xml</param-value>
</context-param>
<!-- 配置SpringMVC核心控制器 -->
<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>
</servlet>
<!--爲DispatcherServlet創建映射 -->
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<!-- 此處能夠能夠配置成*.do -->
<url-pattern>/</url-pattern>
</servlet-mapping>
<!-- 防止Spring內存溢出監聽器 -->
<listener>
<listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
</listener>
<!-- 解決工程編碼過濾器 -->
<filter>
<filter-name>encodingFilter</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>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
View Code
第九步,寫一個jsp文件吧,由於才controller中,return的是allUser。就寫一個allUser文件吧。
1 <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
2 <%
3 String path = request.getContextPath();
4 String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
5 %>
6 <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
7 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
8 <html>
9 <head>
10 <base href="<%=basePath%>">
11
12 <title>ssm</title>
13
14 <meta http-equiv="pragma" content="no-cache">
15 <meta http-equiv="cache-control" content="no-cache">
16 <meta http-equiv="expires" content="0">
17 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
18 <meta http-equiv="description" content="This is my page">
19 <!--
20 <link rel="stylesheet" type="text/css" href="styles.css">
21 -->
22
23 </head>
24
25 <body>
26 <table border="1">
27 <tbody>
28 <tr>
29 <th>姓名</th>
30 <th>年齡</th>
31 </tr>
32 <c:if test="${!empty listUser }">
33 <c:forEach items="${listUser}" var="list">
34 <tr>
35 <td>${list.username }</td>
36 <td>${list.age }</td>
37
38 </tr>
39 </c:forEach>
40 </c:if>
41 </tbody>
42 </table>
43 </body>
44 </html>
View Code
第十步,執行吧,開啓tomcat服務器,輸入:
http://localhost:8080/SSM/user/findAllUser
獲得的以下圖:
