工具:idea
服务器:tomcat
数据库:mysql
准备:Maven仓库(idea自带有,但是下载依赖很慢,这里我用自己下载的Maven仓库)
时间:40分钟左右

第一步:创建Maven项目

我这里配置的是自己的Maven仓库,没有用idea默认的


** 注意右下角,点击右边的按钮下载所需文件(在idea下载完成前最好先别动任何东西,不然可能会出现各种奇葩的状况)**
完成时:


到这里我们就完成了一个web项目的创建,接下来就可以构建ssm框架了

首先来看一下项目骨架

这是整个项目的结构图

注意
这里有三个文件夹需要进行特殊设置,在创建完成后马上进行设置
第一个:main目录下的java文件夹:(右键文件夹进行设置)

第二个:main目录下的resources文件夹

第三个是test目录下的java文件夹(注意区分两个java文件夹)

接下来就是贴代码时间了

首先是pom.xml

<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>com.ssm</groupId><artifactId>ssm</artifactId><packaging>war</packaging><version>1.0-SNAPSHOT</version><name>ChatRobot Maven Webapp</name><url>http://maven.apache.org</url><properties><!-- 设置项目编码编码 --><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><!-- spring版本号 --><spring.version>4.3.5.RELEASE</spring.version><!-- mybatis版本号 --><mybatis.version>3.4.1</mybatis.version></properties><dependencies><!-- java ee --><dependency><groupId>javax</groupId><artifactId>javaee-api</artifactId><version>7.0</version></dependency><!-- 单元测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><!-- 实现slf4j接口并整合 --><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.2</version></dependency><!-- JSON --><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.8.7</version></dependency><!-- 数据库 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.11</version><scope>runtime</scope></dependency><!-- 数据库连接池 --><dependency><groupId>com.mchange</groupId><artifactId>c3p0</artifactId><version>0.9.5.2</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.3.1</version></dependency><!-- Spring --><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-beans</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</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-tx</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-webmvc</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring.version}</version></dependency></dependencies><build><finalName>ChatRobot</finalName><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><!-- 设置JDK版本 --><source>1.8</source><target>1.8</target></configuration></plugin></plugins></build></project>

UserController.java

package com.ssm.controller;import com.fasterxml.jackson.databind.ObjectMapper;
import com.ssm.model.User;
import com.ssm.service.UserServiceImpl;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;@Controller
@RequestMapping("/user")
public class UserController {@Resourceprivate UserServiceImpl userService;@RequestMapping(value="showUser.do",method = RequestMethod.POST)public void selectUser(HttpServletRequest request, HttpServletResponse response) throws IOException {request.setCharacterEncoding("UTF-8");response.setCharacterEncoding("UTF-8");long userId = Long.parseLong(request.getParameter("id"));User user = this.userService.selectUser(userId);ObjectMapper mapper = new ObjectMapper();response.getWriter().write(mapper.writeValueAsString(user));response.getWriter().close();}}

IUserDao接口

package com.ssm.dao;import com.ssm.model.User;public interface IUserDao {User selectUser(long id);
}

User.java

package com.ssm.model;public class User {private long id;private String email;private String password;private String username;public long getId() {return id;}public void setId(int id) {this.id = id;}public String getEmail() {return email;}public void setEmail(String email) {this.email = email;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}}

UserServiceImpl.java

package com.ssm.service;import com.ssm.dao.IUserDao;
import com.ssm.model.User;
import org.springframework.stereotype.Service;import javax.annotation.Resource;@Service("userService")
public class UserServiceImpl {@Resourceprivate IUserDao userDao;public User selectUser(long userId) {return this.userDao.selectUser(userId);}public int insert(User user) {return 0;}}

UserDao.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"><!-- 设置为IUserDao接口方法提供sql语句配置 -->
<mapper namespace="com.ssm.dao.IUserDao"><select id="selectUser" resultType="User" parameterType="long">SELECT * FROM user WHERE id = #{id}</select></mapper>

接下来是配置文件
jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
#数据库地址
jdbc.url=jdbc:mysql://localhost:3306/mytest?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC
#用户名
jdbc.username=root
#密码
jdbc.password=123456
#最大连接数
c3p0.maxPoolSize=30
#最小连接数
c3p0.minPoolSize=10
#关闭连接后不自动commit
c3p0.autoCommitOnClose=false
#获取连接超时时间
c3p0.checkoutTimeout=10000
#当获取连接失败重试次数
c3p0.acquireRetryAttempts=2

logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true"><appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><root level="debug"><appender-ref ref="STDOUT"/></root>
</configuration>

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:context="http://www.springframework.org/schema/context"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd"><!-- 扫描web相关的bean --><context:component-scan base-package="com.ssm.controller"/><!-- 开启SpringMVC注解模式 --><mvc:annotation-driven/><!-- 静态资源默认servlet配置 --><mvc:default-servlet-handler/><!-- 配置jsp 显示ViewResolver --><bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/><property name="prefix" value="/WEB-INF/views/"/><property name="suffix" value=".jsp"/></bean></beans>

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:context="http://www.springframework.org/schema/context"xmlns:tx="http://www.springframework.org/schema/tx"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx.xsd"><!-- 扫描service包下所有使用注解的类型 --><context:component-scan base-package="com.ssm.service"/><!-- 配置数据库相关参数properties的属性:${url} --><context:property-placeholder location="classpath:jdbc.properties"/><!-- 数据库连接池 --><bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"><property name="driverClass" value="${jdbc.driver}"/><property name="jdbcUrl" value="${jdbc.url}"/><property name="user" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/><property name="maxPoolSize" value="${c3p0.maxPoolSize}"/><property name="minPoolSize" value="${c3p0.minPoolSize}"/><property name="autoCommitOnClose" value="${c3p0.autoCommitOnClose}"/><property name="checkoutTimeout" value="${c3p0.checkoutTimeout}"/><property name="acquireRetryAttempts" value="${c3p0.acquireRetryAttempts}"/></bean><!-- 配置SqlSessionFactory对象 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><!-- 注入数据库连接池 --><property name="dataSource" ref="dataSource"/><!-- 扫描model包 使用别名 --><property name="typeAliasesPackage" value="com.ssm.model"/><!-- 扫描sql配置文件:mapper需要的xml文件 --><property name="mapperLocations" value="classpath:mapper/*.xml"/></bean><!-- 配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- 注入sqlSessionFactory --><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/><!-- 给出需要扫描Dao接口包 --><property name="basePackage" value="com.ssm.dao"/></bean><!-- 配置事务管理器 --><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><!-- 注入数据库连接池 --><property name="dataSource" ref="dataSource"/></bean><!-- 配置基于注解的声明式事务 --><tx:annotation-driven transaction-manager="transactionManager"/></beans>

然后是web文件
web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"version="3.1"><welcome-file-list><welcome-file>index.html</welcome-file></welcome-file-list><display-name>ChatRobot</display-name><description>ChatRobot_Alpha_0.0.1</description><!-- 编码过滤器 --><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></filter><filter-mapping><filter-name>encodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping><!-- 配置DispatcherServlet --><servlet><servlet-name>SpringMVC</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><!-- 配置springMVC需要加载的配置文件--><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring-*.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 形式 --><!--/*.do是对所有以.do结尾的请求做处理,/*是对所有请求做处理--><url-pattern>/</url-pattern></servlet-mapping></web-app>

index.html

<!DOCTYPE html>
<html>
<head><meta charset="UTF-8"><title>test</title>
</head>
<script>function selectUser() {var xmlhttp = new XMLHttpRequest();xmlhttp.onreadystatechange = function () {if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {document.getElementById("test").innerHTML = xmlhttp.responseText;}}xmlhttp.open("POST", "user/showUser.do", true);xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");xmlhttp.send("id=1");}
</script>
<body>
<p id="test">Hello World!</p>
<button type="button" onclick="selectUser()">onclick test</button>
</body>
</html>

还有一个UserDao的测试类
IUserDaoTest.java

package com.ssm.daoTest;import com.ssm.dao.IUserDao;
import com.ssm.model.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;// 加载spring配置文件
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration({"classpath:spring-mybatis.xml"})
public class IUserDaoTest {@Autowiredprivate IUserDao dao;@Testpublic void testSelectUser() throws Exception {long id = 1;User user = dao.selectUser(id);System.out.println(user.getUsername());}}

数据库设计:

注意数据库名和表格名
建表后往表中插入一条id为1的数据,用以后面的测试

如果你做到了这里,那么恭喜你,你的ssm框架已经搭建完成,接下来就是测试和部署到tomcat上的事情了

接下来我们先测试mybatis框架是否搭建成功

结果:

结论:

mybatis框架搭建成功

然后是部署到tomcat上测试ssm框架是否搭建成功
先将项目部署到tomcat服务器






运行项目


结果:


结论:ssm框架搭建完成!

结语:这里粗略说一下ssm框架工作的流程,首先,前端将访问的url传递给后台,后台接受url后进行解析,然后决定前往某个controller,这个controller决定前往某个service,service决定前往某个dao,dao决定前往某个mapper.xml进行数据持久化,处理后的数据又会反方向传回前端,从而完成一次动作。以上都是个人的粗略理解,大家也可以发表自己的见解。

配置文件:
1.jdbc.properties:这里面是连接数据库的一些参数设置,比如用户名,密码
2.spring-mvc.xml:springMvc框架的配置文件
3.spring-mybatis.xml:整合spring框架与mybatis框架的配置文件

idea快速搭建ssm框架相关推荐

  1. 手把手教你快速搭建SSM框架

    文章目录 前言 一.创建一个工程 二.补充结构 1.引入Jar包 2.完善层级结构 三.创建层:dao.service和controller 1.创建对应表的实体类,需要set.get.toStrin ...

  2. 快速搭建SSM项目【最全教程】~令狐小哥版

    快速搭建SSM项目[最全教程]~令狐小哥版 文章目录 快速搭建SSM项目[最全教程]~令狐小哥版 一.创建项目 二.集成spring依赖 三.创建applicationContext.xml文件 四. ...

  3. 使用maven搭建ssm框架的javaweb项目

    目前主流的javaweb项目,常会用到ssm(Spring+Spring MVC+Mybatis)框架来搭建项目的主体框架,本篇介绍搭建SSM框架的maven项目的实施流程.记之共享! 一.SSM框架 ...

  4. 新手搭ssm要多久_如何快速学习ssm 框架?

    要快速学习SSM框架,你需要一套学习曲线平滑的教程 1. 很快可以看到效果 SSM框架这种教程的,在百度或者git上一搜一大把,不过很遗憾,大部分你照着上面的流程做,是做不出来的,要么缺少包,要么配置 ...

  5. eclipse + maven搭建SSM框架

    eclipse + maven搭建SSM框架 0.系统环境 1)Windows 10 企业版 2)JDK 1.8.0_131 3)Eclipse Java EE IDE for Web Develop ...

  6. Spring框架学习笔记09:基于XML配置方式搭建SSM框架实现用户登录

    文章目录 一.采用MVC架构 二.用户登录运行效果 三.基于XML配置方式搭建SSM框架实现用户登录 (一)创建数据库与表 - simonshop (t_user) 1.创建数据库 - simonsh ...

  7. 神经风格转移:Anaconda快速搭建DL框架学梵高(Van Gogh)绘画Ubuntu16.04 CPUGPU版

    神经风格转移:Anaconda快速搭建DL框架学梵高(Van Gogh)绘画 Ubuntu16.04 CPU&GPU版 最近开始学ML和DL的知识,开始新的方向,像吴恩达说的,看的再多,不跑几 ...

  8. MyEclipse使用Maven创建web项目+搭建SSM框架教程

    MyEclipse使用Maven创建web项目+搭建SSM框架教程 博文中的代码:链接:http://pan.baidu.com/s/1o8tqIMI 密码:m3si 安装maven和配置 1.下载m ...

  9. 使用idea搭建SSM框架,并成功运行。

    1.搭建环境 1. 前4步跟搭建Spring项目环境是一样的,请参考本人博客的Spring框架学习01. 2.在pom.xml中引入相关依赖 相关测试依赖 <dependency>< ...

最新文章

  1. 印度小哥“神剑”:PDF提取表格so easy!
  2. 图片的裁剪、旋转、平移、模糊
  3. 《Humans vs Computers》作者访谈录
  4. Java Eclipse和MyEclipse快捷键
  5. Groovy 设计模式 -- 借贷
  6. 这套前端可视化框架,让数据栩栩如生!
  7. 金立手机又推新品!翻盖手机A326发布 意图复刻经典
  8. linux内核类型lagency,使用u盘安装linux(manjaro)时Grub报错
  9. 全球与中国电子探针市场现状及未来发展趋势2022-2028
  10. python嵩天ppt_嵩天python课程笔记1
  11. 怎么把程序内部坐标转为屏幕坐标_各位老大,如何把屏幕坐标转换成游戏的坐标...
  12. ZZNUOJ_C语言1083:数值统计(多实例测试)(完整代码)
  13. ip和ifconfig命令添加及删除虚拟IP
  14. 单片机电流检测电路图大全(四款模拟电路设计原理图详解) - 信号处理电子电路图
  15. php 浏览器打开excel文件夹里,php网页显示excel表格数据-phpexcel 读取excel里的数据并在页面显示出来...
  16. 练习:排序数组中查找元素的第一个和最后一个位置
  17. 柳传志内部邮件曝光:联想筹备1年等待大反攻
  18. 面试回答,JVM内存模型/内存空间:运行时数据区
  19. arcgis风向_arcgis制作风或水流速流向图
  20. 解读阿里云成功运营生态体系的两个关键密码:开放与双向赋能

热门文章

  1. java实现简单的LUR算法
  2. Java中继承和实现的区别【单继承,多实现】
  3. 微信生态的渗透与价值
  4. 初级信息处理技术员access教程_初级信息处理技术员如何备考?
  5. Appium爬虫小案例
  6. shell常用语法之if [ $? -ne 0 ]
  7. h5 底部按钮兼容 iPhone X(解决底部横杠遮挡问题)
  8. 百度云for mac破解方法--获取无限svip
  9. clearcase下的一些常用命令
  10. 伍伦贡大学计算机科学,计算机技术(科学)专业