如何搭建漂亮的 SpringBoot 脚手架?

d6106b4bdfc6abb456d70b2db0f32fcb.jpeg来源:juejin.cn/post/7360947498943578139

👉 欢迎加入小哈的星球,你将获得: 专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论

  • 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于 Spring Cloud Alibaba + Spring Boot 3.x + JDK 17..., 点击查看项目介绍

  • 《从零手撸:前后端分离博客项目(全栈开发)》 2期已完结,演示链接:http://116.62.199.48/;

截止目前,累计输出 51w+ 字,讲解图 2330+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,Spring Cloud Alibaba 等等,戳我加入学习,解锁全部项目,已有1900+小伙伴加入

57a9c651599b4b0ba3f99cb6a8fac4da.gif

1. 项目初始化

如果你问研发同学,在开发过程中最讨厌、最痛苦的事情是什么?大部分同学会告诉环境,环境,还是环境。

我带你走一趟你就知道环境搭建是多么头疼的事情了。

在开发一个新项目之前,先下载IDE,光是IDE这个事情,可能就折腾半天。为啥要折腾这么久呢,下载倒是非常快,可现在的IDE基本上都收费,所以网上就出现了各种破解软件,有每30天需要激活一次的,有各种lisence的,总之这些方法在你尝试了很多次之后,基本无一奏效,jetBrains是靠这个挣钱的,如果大家都破解了,人家怎么生存?找各种方法破解,最终都是浪费时间。

为啥大家喜欢用盗版呀,不是喜欢,有免费的会用收费的吗?这是一种心理。说起用盗版这个成因可能就比较复杂了,大部分程序员是随着免费环境成长起来的,一说到收费,第一反应是很难适应的,还记得Mp3吗?刚开始的时候大家都免费下载MP3,但后来因为版权问题开始收费了,下载量跌了50%。

可能还有另外一个原因,作为程序员还不能找一个破解的方法?虽然你道高一尺,但我魔高一丈。

除此之外,大家觉得收费并不便宜,所以望而却步了。

虽然有诸多限制,但IDE必须还得用啊,官方提供了社区版,很多同学用着社区版,还有一部分同学继续走着破解之路。接下来咱们先看看如何用IDE创建springboot项目,然后一路next就行了

2d995eef3df190b17d673ce71dc131c8.jpeg

图片

这就是刚创建好的项目,新鲜出炉,有启动类、配置文件、测试启动类。

c97799c55ac5ab0df9d3dd1aa45e3bc5.jpeg

图片

2. 版本管理

咱们的项目就这么轻松的创建成功了,是不是可以上手开发了,先别着急。先给你看个东西。

这是springCloud和springboot版本之间的对应关系:

  • https://spring.io/projects/spring-cloud

c350a6772eb97a94a11b9da502b99ecf.jpeg

图片

这是springboot和kafka的版本对应关系:

  • https://spring.io/projects/spring-kafka

81d2ae196577d5d471694c4354bddefa.jpeg

图片

很复杂吧,瞬间就想骂娘了?

我先给你讲个最近发生的故事,让你平复一下心情。我最近就在spring-kakfa版本上面栽了跟头

事情是这样的:我们生产环境用的kafka-server是0.11版本的,但我们的客户端用的是3.0.4版本,我的springboot用的是2.7.x版本,从上边表中看到springboot的版本和kafka-client的版本是适配的,但kafka-client的版本和server的版本是不适配的

这是当时的报错信息

?,?:Exception thrown when sending a message with key='null' and payload='byte[205]' to topic notify org.apache.kafka.common.errors.UnsupportedVersionException: Attempting to use idempotence with a broker which does not support the required message format (v2). The broker must be version * 0.11* or later.

你可能会问这是非常容易发现的问题呀,也很容易测试出来呀,对,问题很容易复现

关键就是生产环境的版本和测试环境的server版本不一样,不一样,不一样,真是没想到啊,所以就栽了跟头。

有一款神器不是叫Maven吗,这个不就是解决版本之间的依赖关系吗?

在说maven之前,先简单说一下springboot的自动配置,在springboot出来之前,大家依赖关系都是通过手动添加,springboot的autoconfiuration功能解决了包之间依赖关系,至少让研发的开发效率提升了50%,但有些场景下依赖的冲突还是未能解决。

  • https://maven.apache.org/index.html

Apache Maven is a software project management and comprehension tool

我们最常用的maven命令是build,package,在构建上真的是一把利器,maven确实提升了研发的效率。

3. 废话不多说,直接看脚手架

87eba2c8d8c7795e379e29a94664b455.jpeg

图片

接下来我们来看看都有哪些核心类,我把代码贴到下方。

46f1b00693ffe8c2e8d23662fef6b08e.jpeg

图片

全局异常处理

@RestControllerAdvice
@ResponseBody
@Slf4j
public class GlobalExceptionHandler {

    @ExceptionHandler(value = {MethodArgumentNotValidException.class})
    public ResponseResult<String> handleValidException(MethodArgumentNotValidException ex, HttpServletResponse httpServletResponse) {
        log.error("[GlobalExceptionHandler][handleValidException] 参数校验exception", ex);
        return wrapperBindingResult(ex.getBindingResult(), httpServletResponse);
    }


    private ResponseResult<String> wrapperBindingResult(BindingResult bindingResult, HttpServletResponse httpServletResponse) {
        StringBuilder errorMsg = new StringBuilder();
        for (ObjectError error : bindingResult.getAllErrors()) {
            if (error instanceof FieldError) {
                errorMsg.append(((FieldError) error).getField()).append(": ");
            }
            errorMsg.append(error.getDefaultMessage() == null ? "" : error.getDefaultMessage());

        }
        httpServletResponse.setStatus(HttpStatus.BAD_REQUEST.value());
        return ResponseResult.failed(ResultCode.FAILED.getCode(),null);
    }

日志处理

@Aspect
@Slf4j
@Component
public class WebLogAspect {

    @Pointcut("@within(org.springframework.stereotype.Controller) || @within(org.springframework.web.bind.annotation.RestController)")
    public void cutController() {
    }

    @Before("cutController()")
    public void doBefore(JoinPoint point) {
        //获取拦截方法的参数
        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
        String url = request.getRequestURL().toString();
        List<Object> list = Lists.newArrayList();
        for (Object object : point.getArgs()) {
            if (object instanceof MultipartFile || object instanceof HttpServletRequest || object instanceof HttpServletResponse || object instanceof BindingResult) {
                continue;
            }
            list.add(object);
        }
        log.info("请求 uri:[{}],params:[{}]", url, StringUtils.join(list, ","));
    }

    /**
     * 返回通知:
     * 1. 在目标方法正常结束之后执行
     * 1. 在返回通知中补充请求日志信息,如返回时间,方法耗时,返回值,并且保存日志信息
     *
     * @param response
     * @throws Throwable
     */
    @AfterReturning(returning = "response", pointcut = "cutController()")
    public void doAfterReturning(Object response) {
        if (response != null) {
            log.info("请求返回result:[{}]", JSONUtil.toJsonStr(response));
        }
    }
}

跨域类

@Configuration
public class GlobalCorsConfig {
    /**
     * 允许跨域调用的过滤器
     */
    @Bean
    public CorsFilter corsFilter() {
        CorsConfiguration config = new CorsConfiguration();
        //允许所有域名进行跨域调用
        config.setAllowedOrigins(Lists.newArrayList("*"));
        //允许跨越发送cookie
        config.setAllowCredentials(true);
        //放行全部原始头信息
        config.addAllowedHeader("*");
        //允许所有请求方法跨域调用
        config.addAllowedMethod("*");
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        source.registerCorsConfiguration("/**", config);
        return new CorsFilter(source);
    }
}
@Configuration
@EnableOpenApi
public class SwaggerConfig {
    @Bean
    public Docket docket() {
        return new Docket(DocumentationType.OAS_30)
                .apiInfo(apiInfo()).enable(true)
                .select()
                //apis: 添加swagger接口提取范围
                .apis(RequestHandlerSelectors.basePackage("com.vines.controller"))
                //.apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
                .paths(PathSelectors.any())
                .build();
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("项目描述")
                .description("基础服务项目描述")
                .contact(new Contact("作者", "作者URL", "作者Email"))
                .version("1.0")
                .build();
    }
}

响应体

@Data
public class  ResponseResult<T> {
    private int code;
    private String message;
    private T data;

    public static <T> ResponseResult<T> success(T data){
        ResponseResult<T> responseResult=new ResponseResult<>();
        responseResult.setCode(ResultCode.SUCCESS.getCode());
        responseResult.setMessage(ResultCode.SUCCESS.getMessage());
        responseResult.setData(data);
        return  responseResult;
    }
    public static <T> ResponseResult<T> success(){
        ResponseResult<T> responseResult=new ResponseResult<>();
        responseResult.setCode(ResultCode.SUCCESS.getCode());
        responseResult.setMessage(ResultCode.SUCCESS.getMessage());
        return  responseResult;
    }

    public static <T> ResponseResult failed(int code,String message){
        ResponseResult<T> responseResult=new ResponseResult<>();
        responseResult.setCode(code);
        responseResult.setMessage(message);
        return responseResult;
    }

    public static boolean isSucceed(ResponseResult responseResult){
        return responseResult.getCode()==ResultCode.SUCCESS.getCode();
    }
}
3.1 常用工具

除了这些基本的工具之外,我再推荐几款我们项目中常用的工具

我们项目常常依赖中间件,比如mysql,kafka,redis等,如果要单元测试,我们通常的做法是在dev环境部署一套项目中依赖的中间件,非常麻烦,而且数据还不容易隔离,所以内存版的中间件就是来解决这个问题的。

内存版Redis:

  • https://github.com/kstyrc/embedded-redis

内存版DB:

  • https://github.com/mariadb

内存版kafka,springboot提供了测试依赖,直接引入starter即可

<groupId>org.springframework.kafka</groupId>
<artifactId>spring-kafka</artifactId>

hutool:

  • https://hutool.cn/

mybatis plus:

  • https://baomidou.com/

mapStruct:

  • https://mapstruct.org/

redisson:

  • https://github.com/redisson/redisson

总结

在真实的工作中,IDE的配置工作其实不是最麻烦的和最浪费的时间的,有一件事情更加浪费时间,每次搞的我都特别的崩溃,这件事情也和环境相关,同时也和其他人相关。你们猜猜是什么事情呢?

👉 欢迎加入小哈的星球,你将获得: 专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论

  • 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于 Spring Cloud Alibaba + Spring Boot 3.x + JDK 17..., 点击查看项目介绍

  • 《从零手撸:前后端分离博客项目(全栈开发)》 2期已完结,演示链接:http://116.62.199.48/;

截止目前,累计输出 51w+ 字,讲解图 2330+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,Spring Cloud Alibaba 等等,戳我加入学习,解锁全部项目,已有1900+小伙伴加入

3a493058b2c0a066e072edcf9639bc34.gif

917bb2b7ed7f4a2421e3a2874748e42c.jpeg

 
 

f7ffce7b9f610c528decccb59b05e64b.gif

 
 
 
 
1. 我的私密学习小圈子~
2. 我用这11招,让接口性能提升了100倍
3. 线程数突增!领导说再这么写就gc掉我....
4. 裸辞后,在家全职接单一个月的感触
 
 
最近面试BAT,整理一份面试资料《Java面试BATJ通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。
获取方式:点“在看”,关注公众号并回复 Java 领取,更多内容陆续奉上。
PS:因公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。
点“在看”支持小哈呀,谢谢啦
### 回答1: 前端环境需要以下内容: 1. Node.js:用于运行npm命令。 2. npm:用于管理JavaScript库和依赖项。 3. Vue CLI:Vue.js的脚手架工具,可快速搭建Vue项目。 4. Visual Studio Code:代码编辑器,可支持Vue.js的语法高亮和自动补全等功能。 5. Git:版本控制工具,可用于管理代码。 6. Webpack:打包工具,将Vue.js的组件打包成单个JavaScript文件,以便在浏览器中加载。 7. Element UI:基于Vue.js的UI组件库,可快速构建漂亮的前端界面。 以上是基本的前端环境,您可以根据实际需要添加其他依赖项和工具。 ### 回答2: Spring Boot Vue前后端系统的前端环境需要一些基本的工具和配置。首先,你需要一个可靠的开发环境,比如安装好的操作系统、IDE(集成开发环境)和一个版本控制工具,比如Git。 其次,你需要安装Node.js和npm(Node Package Manager)。Node.js是一个基于Chrome V8引擎的JavaScript运行环境,用于执行JavaScript代码。npm是Node.js的包管理工具,用于安装、发布和管理代码包。 在安装好Node.js和npm后,你可以使用npm命令安装Vue的开发工具,如Vue CLI(命令行工具)和Vue UI(可视化工具)。Vue CLI是一个快速搭建Vue项目的脚手架工具,它提供了一些常用的项目模板和插件,可以更方便地开发和构建Vue应用程序。Vue UI是一个可视化的项目管理工具,它提供了一个图形化界面,可以更直观地管理和操作项目。 此外,你可以选择一个合适的代码编辑器,如Visual Studio Code、Sublime Text或Atom等。这些编辑器都提供了很好的代码提示和调试功能,可以提升你的开发效率。 最后,你还需要安装一些常用的前端开发工具和库,如Webpack(模块打包工具)、Babel(JavaScript编译工具)、Axios(HTTP客户端)等。通过配置这些工具和库,可以更高效地构建和管理前端项目。 综上所述,Spring Boot Vue前后端系统的前端环境需要:操作系统、IDE、Git、Node.js、npm、Vue CLI、Vue UI、代码编辑器、Webpack、Babel、Axios等工具和库。这些工具和配置的使用可以更方便地开发和调试Vue前端应用程序。 ### 回答3: 前端环境一般需要以下几个方面的内容来支持SpringBoot Vue的前后端系统: 1. 开发工具:前端开发环境需要使用一款开发工具来编写和调试代码,常见的开发工具有Visual Studio Code(VS Code)、WebStorm等。 2. 前端框架:Vue.js是一款非常流行的前端框架,它可以帮助开发者构建交互性强、性能优秀的单页面应用(SPA)。前端环境需要安装和配置Vue.js,并基于该框架进行前端开发。 3. 前端依赖管理工具:前端依赖管理工具可以帮助管理项目所依赖的第三方库和插件。常见的前端依赖管理工具有npm和yarn,它们可以用于安装、更新和移除项目所需的前端依赖。 4. 前端构建工具:构建工具可以自动化地完成前端项目的构建、压缩、打包等工作。常见的前端构建工具有Webpack、Rollup等,它们可以将多个前端资源文件(如JavaScript、CSS、图片等)进行合并和优化。 5. 前端代码管理工具:代码管理工具可以帮助开发人员更好地管理和协同开发前端代码。常见的代码管理工具有Git,它可以用于版本控制、分支管理、代码合并等操作。 除了以上主要的环境要素外,还需要根据具体需求来配置与后端交互的网络请求库、前端组件库等。最后,为了提高开发效率和代码质量,前端开发环境还可以配置代码编辑器的语法检查、代码格式化等插件工具。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值