以前的SSM会因为版本问题特别烦恼,现在既然学了springboot那就重新配置
关于STS插件是专门创建sprinngboot项目你只需要知道你需要什么功能就可以了,更多的详细内容请百度
我的是Eclipse,关于安装STS插件的步骤和版本问题网上有好多教程,这就不多说了,可以自行百度
我这直接列出pom.xml
4.0.0
org.springframework.boot
spring-boot-starter-parent
2.1.6.RELEASE
com.springboot
SpringBoot1
0.0.1-SNAPSHOT
SpringBoot1
Demo project for Spring Boot
1.8
13.0.11
3.1.1
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-devtools
runtime
true
org.mybatis.spring.boot
mybatis-spring-boot-starter
2.1.0
mysql
mysql-connector-java
org.apache.tomcat.embed
tomcat-embed-jasper
javax.servlet
jstl
org.springframework.boot
spring-boot-maven-plugin
可能因为Eclipse版本的问题或者你直接STS和Eclipse一起安装的,在刚开始创建选需要的依赖时有所不同
我创建项目时选依赖的环境根本没有Web这个大的选项
只能选它的子级,所以要知道自己选什么依赖,详细一点没坏处
一般springboot整合SSM的项目差不多这样的,繁琐些的就是在这3个部分添加代码和配置,
springboot舍弃了web.xml
用SpringBoot整合的SSM和普通的SSM的区别主要在1、2部分
你看这个可能有点迷糊,可能有一些乱,我这个Eclipse是这么摆放包的,网上的很多和我不一样,以后可能会换个版本的Eclipse
看Navigator更形象化些(在这里包改口成文件夹)
com.ssm下有controller、mapper、pojo等文件夹,而SpringBoot1Application.java
和它们是平级,这个类是你创建好这个项目它自己生成的,是启动类,不用自己再提交到Tomcat再运行,用内置的服器来测试
在原来SSM中的Mapper中的xml应该是在mapper文件夹下,现在mapper.xml移动到resources下的mapper文件夹下,这是由于SpringBoot的机制决定的,如果不放在那可能会报错
这里说一下,要不你会奇怪这怎么没有mapper里的那个xml呢?
里面都是一些配置文件,以前的SSM有很多的配置文件,现在SpringBoot简化了,把那些配置文件都放在了一个 application.** 里,为什么是**呢?因为有两种配置格式,一种是application.yml
和另外一种application.properties
,这两种方式都可以,我这的是 .yml,它的位置位于 resources 下
在resources 还有static等文件夹,里面存放着的是静态资源,比如图片什么的,下一篇博客单独列出来了SpringBoot访问静态资源(图片,html,js,jquery等)
不是不说吗,为什么又写了呢?
因为可能因为各种各样的原因,第三部分不存在。需要自己去创建
这只做了一个示例,其他的还需自己去填充
这个类是不用自己去建的,它自己生成
package com.ssm;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class SpringBoot1Application {
public static void main(String[] args) {
SpringApplication.run(SpringBoot1Application.class, args);
}
}
上面这个类如果和Controller,mapper等不在同一级目录下或者Controller,mapper等不是这个类的子类,就需要自己在@SpringBootApplication
再写注解把controller,mapper等包扫描
package com.ssm.controller;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import com.ssm.pojo.User;
import com.ssm.service.UserService;
/**
* @author 作者
* @data 2019年8月1日
*/
@Controller
public class UserController {
@Autowired
private UserService userService;
@RequestMapping("findAll")
public String findAll(Model model) throws Exception {
List list = userService.getAllUser();
model.addAttribute("list",list);
return "index";
}
}
关于@Controller
肯定都熟悉,上面不解释也都知道什么意思
这主要说一下有时候返回的不是网址地址,而是json,这样如果只是某个方法返回json,你就直接在方法上加上@ResponseBody
,这个套路也是老套路了,说一个新的注解,在类上加@RestController
,它相当于@Controller
和@ResponseBody
两个,说明这个controller 返回的都是json,别忘了把bean 实现序列化接口
package com.ssm.mapper;
import java.util.List;
import org.apache.ibatis.annotations.Mapper;
import com.ssm.pojo.User;
/**
* @author 作者
* @data 2019年7月31日
*/
@Mapper
public interface UserMapper {
List getAllUser() throws Exception;
}
这就加了个@Mapper
注解,为了启动类在启动时把它扫描上
package com.ssm.pojo;
import java.io.Serializable;
/**
* @author 作者
* @data 2019年7月31日
*/
public class User implements Serializable{
private static final long serialVersionUID = 1L;
private String id;
private String name;
private Integer age;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
}
}
package com.ssm.service;
import java.util.List;
import com.ssm.pojo.User;
/**
* @author 作者
* @data 2019年7月31日
*/
public interface UserService {
List getAllUser() throws Exception;
}
package com.ssm.service.impl;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.ssm.mapper.UserMapper;
import com.ssm.pojo.User;
import com.ssm.service.UserService;
/**
* @author 作者
* @data 2019年7月31日
*/
@Service("userService")
@Transactional
public class UserServiceImpl implements UserService{
@Autowired
UserMapper userMapper;
@Override
public List getAllUser() throws Exception {
List list = userMapper.getAllUser();
return list;
}
}
#服务器配置
server:
port: 8090
#spring配置
spring:
#数据源配置(默认数据源为HikariDataSource)
datasource:
#配置mysql数据库
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
username: root
password:
#配置JSP视图,相当于SSM中controller的xml的视图管理器
mvc:
view:
prefix: /WEB-INF/jsp/
suffix: .jsp
#配置mybatis框架
mybatis:
#定义Mapper接口映射文件位置
mapper-locations: classpath:mapper/*.xml
#定义实体类位置
type-aliases-package: com.ssm.pojo
#控制台打印sql语句
logging:
level:
com.ming.ssm.mapper: debug
这看上面就知道,格式有特别注意的,这排列格式用的是空格,不是tab键,冒号后有空格,再填约束,关于yml的要求可以自行百度
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
客户管理页面
客户ID
客户姓名
客户年龄
${c.id}
${c.name}
${c.age}
正好在这说明一下怎么通过 .properties转换成 .yml
以server.servlet.context-path=/demo
为例,这句话在 .properties 中代表的是项目名书写
那在 .yml中怎么表示呢?
server:
servlet:
context-path: /demo
关于更多的语法请访问yml配置文件语法