SpringBoot项目搭建服务模块-server

本文介绍如何创建并集成一个包含MyBatis组件的公共模块,实现数据访问层的复用。具体步骤包括定义实体类、接口、服务层及配置等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

新建公共模块-server

将system的domain、mapper、service还有resources下的mapper都拷贝过来,并修改一下报错的地方。
在这里插入图片描述

package com.dog.server.domain;

public class Test {

    private String id;

    private String name;

    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;
    }
}

package com.dog.server.mapper;

import com.dog.server.domain.Test;

import java.util.List;

public interface TestMapper {

    public List<Test> list();
}

package com.dog.server.service;

import com.dog.server.domain.Test;
import com.dog.server.mapper.TestMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class TestService {

    @Autowired(required = false)
    private TestMapper testMapper;

    public List<Test> list() {
        return testMapper.list();
    }
}

<?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.dog.server.mapper.TestMapper" >

    <select id="list" resultType="com.dog.server.domain.Test">
        select `id`, `name` from `test`
    </select>

</mapper>

server模块加入依赖

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- 集成mybatis -->
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>

    <!-- 热部署DevTools -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
    </dependency>

</dependencies>

server模块的依赖和原来system的依赖基本一样,只是比system模块少了这个依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

system集成server模块

总项目的pom文件加入server依赖

<dependency>
	<groupId>com.lucky</groupId>
	<artifactId>server</artifactId>
	<version>0.0.1-SNAPSHOT</version>
</dependency>

system模块里的pom加入server依赖(去版本的)

<dependency>
    <groupId>com.lucky</groupId>
    <artifactId>server</artifactId>
</dependency>

修改system启动类

package com.dog.system;

import org.mybatis.spring.annotation.MapperScan;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.core.env.Environment;

@SpringBootApplication
@EnableEurekaClient
@ComponentScan("com.dog")
@MapperScan("com.dog.server.mapper")
public class SystemApplication {

	private static final Logger LOG = LoggerFactory.getLogger(SystemApplication.class);

	public static void main(String[] args) {
		SpringApplication app = new SpringApplication(SystemApplication.class);
		Environment env = app.run(args).getEnvironment();
		LOG.info("启动成功!!");
		LOG.info("System地址: \thttp://127.0.0.1:{}", env.getProperty("server.port"));
	}

}

这里的@ComponentScan("com.dog")一定不要写成@Component("com.dog")
不然会报这个错
在这里插入图片描述
在这里插入图片描述
然后搜了一下这两个注解的区别
在这里插入图片描述
——————————————————————
修改system里的controller

package com.dog.system.controller;

import com.dog.server.domain.Test;
import com.dog.server.service.TestService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
public class TestController {

    @Autowired(required = false)
    private TestService testService;

    @RequestMapping("/test")
    public List<Test> test() {
        return testService.list();
    }
}

这里的@Autowired(required = false)可以写成@Resource,有的版本的idea会在加了@Resource的地方,出现红色波浪线,但不影响运行。
在这里插入图片描述

将通用的配置移动到server

system的配置文件只留这些
在这里插入图片描述
其余的复制到server的recourses下的config文件夹里
在这里插入图片描述

# 增加数据库连接
spring.datasource.url=jdbc:mysql://localhost:3306/icourse?characterEncoding=UTF8&autoReconnect=true
spring.datasource.username=icourse
spring.datasource.password=icourse
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

mybatis.mapper-locations=classpath:/mapper/*.xml

logging.level.com.dog.system.mapper=trace

system的启动类也放在一个config文件夹里
在这里插入图片描述
这样就OK了。

### 创建和配置新的Spring Boot项目 #### 初始化工程结构及添加必要依赖 通过使用Spring Initializr可以快速创建并初始化一个Spring Boot项目。在IDEA工具中点击New Project,进入创建项目的界面后选择Spring Initializr选项,在此界面上按照提示填写必要的信息[^3]。 对于构建工具的选择,可以选择Maven或Gradle;对于语言,默认支持Java、Kotlin等编程语言。接着指定Spring Boot版本号,通常建议采用最新稳定版以获得最新的特性和安全更新。之后便是勾选所需的起步依赖(Starters),比如Web开发相关的`Spring Web`,数据库交互方面的`Spring Data JPA`加上特定类型的数据库驱动如`MySQL Driver`等,这些都取决于具体的应用场景需求[^1]。 完成上述设置后,点击下一步直至生成项目文件夹结构。此时已经得到了基础的Spring Boot应用程序框架,其中包含了pom.xml(如果是Maven的话)用于管理外部库和其他资源的信息描述文档。 ```xml <dependencies> <!-- Spring Boot Starter Web --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- Other dependencies as needed --> </dependencies> ``` 为了确保程序能够正常工作,还需要适当调整application.properties或者application.yml中的参数来适配环境变量或是第三方组件连接字符串等内容。例如: ```yaml server.port=8081 spring.datasource.url=jdbc:mysql://localhost:3306/testdb?useSSL=false&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=password ``` 最后一步就是编写业务逻辑代码了,这涉及到定义控制器类接收HTTP请求,并调用服务层处理数据访问操作等功能模块的设计与实现。当一切准备就绪以后,可以通过命令行执行mvn spring-boot:run 或者直接运行主函数启动整个应用实例[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值