使用eclipse开发工具手把手教你搭建一个spring boot项目(spring boot+maven+mybatis+mysql)

一、第一步创建maven项目

file>>>>maven project>>>Filter输入web

1、

2、

/3、

3、新建的项目结构为:

 

4、切换为maven目录(去除勾选的选项)

 

调整后的目录结构

 

5、配置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.neon</groupId>
  <artifactId>apple</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>apple Maven Webapp</name>
  <url>http://maven.apache.org</url>
 
  <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
  </parent>

  <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <mybatis-spring-boot-starter.version>1.1.1</mybatis-spring-boot-starter.version>
        <druid.version>1.0.29</druid.version>
        <fastjson.version>1.2.32</fastjson.version>
    </properties>
    
 <dependencies>
         <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        
         <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
            <exclusions>
                <!-- json库统一使用fastjson -->
                <exclusion>
                    <groupId>com.fasterxml.jackson.core</groupId>
                    <artifactId>jackson-databind</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>${mybatis-spring-boot-starter.version}</version>
        </dependency>
        
        <!-- json处理工具 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>${fastjson.version}</version>
        </dependency>
        
        <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.45</version>
        </dependency>

        <!-- druid数据库连接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>${druid.version}</version>
        </dependency>
        <!-- 数据库连接驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        
    </dependencies>
  <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            
            <!-- 引入java编译器插件 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <compilerVersion>1.8</compilerVersion>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
            
            <!-- 资源文件拷贝插件 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-resources-plugin</artifactId>
                <configuration>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>
 

6、resources目录下增加application.yml配置文件

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/mytest?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true
    username: root
    password: root
mybatis:
  config-location: classpath:mybatis-config.xml
  mapper-locations: classpath:mybatis/*Mapper.xml

 

7、mybatis-config.xml配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>
    <settings>
        <!-- 获取数据库自增id -->
        <setting name="useGeneratedKeys" value="true"/>

        <!-- 支持别名 -->
        <setting name="useColumnLabel" value="true" />

        <!-- 支持驼峰命名转换,例如表字段create_time 对应实体类的createTime属性 -->
        <setting name="mapUnderscoreToCamelCase" value="true" />
    </settings>
</configuration>

8、src/main/java目录创建如下目录

 

9、AppleApplication.java服务启动类

package com.neon.apple;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@MapperScan("com.neon.apple.dao")
public class AppleApplication {
    
    public static void main(String[] args) {
        SpringApplication.run(AppleApplication.class, args);
    }

}
 

 

10、user实体类

package com.neon.apple.model;

public class User {
    
    private String userId;
    private String userName;
    private String password;
    
    public String getUserId() {
        return userId;
    }
    public void setUserId(String userId) {
        this.userId = userId;
    }
    public String getUserName() {
        return userName;
    }
    public void setUserName(String userName) {
        this.userName = userName;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }   

}
 

 

11、dao接口

package com.neon.apple.dao;

import java.util.List;

import com.neon.apple.model.User;

public interface IUserDao {

    List<User> getAll();
    User find(String userId);
    int insert(User user);
    int delete(String userId);
    int update(User user);
}
 

12、service接口

package com.neon.apple.service;

import java.util.List;

import com.neon.apple.model.User;

public interface IUserService {

    List<User> getAll();
    int insert(User user);
    int delete(String userId);
    int update(User user);
    User find(String userId);

}
 

13、service实现层

package com.neon.apple.service.impl;

import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;

import com.neon.apple.dao.IUserDao;
import com.neon.apple.model.User;
import com.neon.apple.service.IUserService;

@Service
public class UserServiceImpl implements IUserService {

    private static final Logger LOGGER = LoggerFactory.getLogger(UserServiceImpl.class);

    @Autowired
    private IUserDao userDao;

    @Override
    public List<User> getAll() {
        return userDao.getAll();
    }

    @Override
    public int insert(User user) {
        return userDao.insert(user);
    }

    @Override
    public int delete(String userId) {
        return userDao.delete(userId);
    }

    @Override
    public int update(User user) {
        User userOutVo=null;
        if(user!=null && !StringUtils.isEmpty(user.getUserId())) {
            userOutVo=userDao.find(user.getUserId());
            if(userOutVo!=null) {
                LOGGER.info("用户名:"+user.getUserName());
                userOutVo.setUserName(user.getUserName());
                userOutVo.setPassword(user.getPassword());
            }
        }
        return userDao.update(userOutVo);
    }

    @Override
    public User find(String userId) {
        return userDao.find(userId);
    }

    

}
 

 

14、控制层UserController

package com.neon.apple.controller;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

import com.neon.apple.model.User;
import com.neon.apple.service.IUserService;

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

    @Autowired
    IUserService userService;
    
    @RequestMapping("/")
    String home() {
        return "Hello World!";
    }

    @RequestMapping(value={"/getUserList"}, method=RequestMethod.POST)
    public List<User> getUserList(){
        System.out.println("查询用户信息。。。。。。。。。");
        return userService.getAll();
    }

    @RequestMapping(value={"/addUser"}, method=RequestMethod.POST)
    @ResponseBody
    public void addUser(@RequestBody User user){
        System.out.println("开始新增。。。。。。。。。。。。。。");
        userService.insert(user);
    }

    @RequestMapping(value={"/updateUser"}, method=RequestMethod.POST)
    @ResponseBody
    public void updateUser(@RequestBody User user){
        System.out.println("开始修改信息。。。。。。。。");
        userService.update(user);
    }

    @RequestMapping(value={"/deleteUser"}, method=RequestMethod.POST)
    @ResponseBody
    public void deleteUser(@RequestParam String id){
        System.out.println("开始删除信息。。。。。。。。");
        userService.delete(id);
    }
}

 

15、在src/main/resources下新建目录mybatis,创建UserMapper.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.neon.apple.dao.IUserDao">
    <select id="getAll" resultType="com.neon.apple.model.User">
       select user_id,user_name,password 
         from tb_user order by user_id desc
    </select>

    <select id="find" resultType="com.neon.apple.model.User">
        select user_id,user_name,password  from tb_user where user_id = #{userId}
    </select>

    <insert id="insert" useGeneratedKeys="true" keyProperty="userId" keyColumn="user_id" parameterType="com.neon.apple.model.User">
        insert into tb_user(user_id,user_name,password) values(#{userId},#{userName},#{password})
    </insert>

    <update id="update" parameterType="com.neon.apple.model.User">
       update tb_user
       <set>
           <if test="userName != null">user_name=#{userName},</if>
           <if test="password != null">password=#{password},</if>
       </set>
        where user_id=#{userId}
    </update>

    <delete id="delete">
        delete from tb_user where user_id=#{userId}
    </delete>
</mapper>
 

至此,基本的crud操作基本完成。现在进行验证

二、

1、找到AppleApplication.java文件右键Run as  >>>>Java Application启动

(控制台无报错信息即说明框架整合成功)

 

2、用Postman测试一下接口

 

添加用户接口测试成功

 

 

 

查询数据接口测试成功

 

附可直接运行源码下载地址:https://download.csdn.net/download/llt1991com/11271866

  • 6
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值