一、创建项目
1.File->New->Project
2.选择Spring Initializr 默认JDK1.8即可 点击Next
3.完善项目信息,最终建的项目名为:demo,src->main->java下包名会是:com->example->demo 点击next
4.可以在此界面对maven依赖进行选择,也可以后续在pom文件中增加自己需要的maven依赖,然后点击Next
5.选择项目路径,然后点击Finish,打开新的窗口
做完这一步之后就完成了新建Springboot项目的流程就完成了。
6.这就是刚创建好的项目目录结构
7.点击右侧的Maven,点击设置按钮(扳手🔧图标)进行Maven仓库路径的设置
8.(1)手动选择本地Maven路径(2)勾选配置文件后边Override选项,然后修改为本地Maven的配置文件,它会根据配置文件直接找到本地仓库位置
9.pom文件配置,这里是SSM框架所用到的POM文件
10.pom文件配置完成之后如果没有出现导包提示,可以点击左上角重新导包按钮,或者点击下载按钮,选择下载所有源文件和文档
Import Changes :导入我们新添加的依赖
Enable Auto-Import:设置后后更改 pom 文件后自动下载依赖包(推荐)
如果想要取消自动导入依赖
打开setting→maven→importing:取消选择Import Maven projects automatically
11.在.yml配置文件中进行相关配置
server:
port: 9101 #设置端口号
spring:
datasource:
name: test #数据库名
url: jdbc:mysql://localhost:3306/test #url
username: sa #用户名
password: 123456 #密码
driver-class-name: com.mysql.jdbc.Driver #数据库链接驱动
mybatis:
mapper-locations: classpath:mapper/*.xml #配置映射文件
type-aliases-package: com.example.demo.pojo #配置实体类
#打印可执行sql语句
logging:
level:
com.ava.demo.mapper: debug #com.ava.demo.mapper替换成你自己的数据访问接口类的包名
至于为什么要用.yml文件不用.properties文件不懂的可以跳转以下链接👇
12.Springboot项目大概分为四层
1)Bean层:也称Model层,模型层、实体层、entity层,是用于存放pojo对象,也就是数据库表的映射实体类,一张表对应一个实体类。
package com.example.demo.pojo;
public class User {
private int id;
private String name;
private String password;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
2)Dao层:包括XxxMapper.java(数据库访问接口类)和XxxMapper.xml(数据库接口实现类)在这里主要处理对数据库的CRUD操作。
package com.example.demo.mapper;
import com.example.demo.pojo.User;
public interface UserMapper {
User getInfo(String name,String password);
}
DAO层访问数据库实现文件(需在resource包下创建mapper文件夹,然后再创建一个UserMapper.xml.在application配置文件中mybatis:mapper-locations:对应的就是该文件地址),注意
<mapper>
标签的namespace
属性要填写 访问数据库接口类文件路径
<?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.example.demo.mapper.UserMapper">
<select id="getInfo" parameterType="String" resultType="com.example.demo.pojo.User">
SELECT * FROM user WHERE name = #{name} AND password = #{password}
</select>
</mapper>
3)Service层:包括XxxService.java(业务接口类)和XxxServiceImpl.java(业务接口实现类)具体的业务处理应放在service中去写,而且service不单纯是对于dao的增删改查的调用,service是业务层,所以应该更切近于具体业务功能要求,所以在这一层,一个方法所体现的是一个可以对外提供的功能,比如购物商城中的生成订单方法,这里面就不简单是增加个订单记录那么简单,我们需要查询库存,核对商品等一系列实际业务逻辑的处理。
package com.example.demo.service;
import com.example.demo.pojo.User;
public interface UserService {
User loginIn(String name,String password);
}
Service层业务实现类编写,注意要注解@Service,注入DAO:
package com.example.demo.service;
import com.example.demo.pojo.User;
import com.example.demo.mapper.UserMapper;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
//用于标注业务层组件
@Service
public class UserServiceImpl implements UserService {
//将DAO注入Service层
@Autowired
private UserMapper userMapper;
@Override
public UserBean loginIn(String name, String password) {
return userMapper.getInfo(name,password);
}
}
4)Controller层,也就是Web层,从字面上理解是控制器,所以它是负责业务调度的,所以在这一层应写一些业务的调度代码。
package com.example.demo.controller;
import com.example.demo.pojo.User;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
//@Controller:用于标注是控制层组件,需要返回页面时请用@Controller而不是@RestController
@Controller
@RequestMapping("/User")
public class LoginController {
//将Service注入Web层
@Autowired
UserService userService;
/*
* @RestController 是 @Controller 和 @ResponseBody的结合,一个类被加上@RestController 注解,数据接口中就不再需要添加@ResponseBody。更加简洁。
* @RequestMapping:是一个用来处理请求地址映射的注解,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径
* 也可用 @GetMapping、@PostMapping替代,它相当于 @RequestMapping(value=”/”,method=RequestMethod.Get、Post、Put、Delete等) 。
* @ResponseBody:返回结果不会被解析为跳转路径,而是直接写入HTTP response body中;比如异步获取json数据,加上 @responsebody后,会直接返回json数据
*/
@RequestMapping("/login")
public String show(){
return "login";
}
@RequestMapping(value = "/loginIn",method = RequestMethod.POST)
public String login(String name,String password){
User user = userService.loginIn(name,password);
if(user!=null){
return "success";
}else {
return "error";
}
}
}
依照上面四层,创建目录结构如下:
5)最后记得为启动类加入注解@MapperScan,项目启动时扫描mapper接口,否则会报错找不到mapper文件
package com.example.demo;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/*
* @ComponentScan:组件扫描。个人理解相当于,如果扫描到有 @Component @Controller @Service等这些注解的类,则把这些类注册为 bean*;
* @MapperScan:spring-boot支持mybatis组件的一个注解,通过此注解指定mybatis接口类的路径,即可完成对mybatis接口的扫描。
*/
@SpringBootApplication
@MapperScan("com.example.demo.mapper")
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
13.最后在浏览器输入地址,进行测试
localhost:9101/User/login
ok!整个SpringBoot搭建流程就完成了!
如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!
听说 👉 点赞 👈 的人运气不会太差,每一天都会元气满满哦 嘿嘿!!! ❤️ ❤️ ❤️
大家的支持就是我坚持下去的动力。点赞后不要忘了👉 关注 👈我哦!