IDEA + Maven + SpringBoot + Mybatis + Thymeleaf + Swagger实现一个web项目

本文主要是介绍IDEA + Maven + SpringBoot + Mybatis + Thymeleaf + Swagger实现一个web项目,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Web项目的成长过程

  • 前言
  • Project创建
  • 初始项目结构说明
  • 初始项目配置
    • 个人习惯配置
      • Maven配置
    • 数据库连接驱动JDBC的配置
    • Tomcat配置
    • Mybatis数据库映射配置
      • 配置Mybatis Generator自动生成代码
    • Thymeleaf配置
    • 解决跨域问题
    • 使用区分不同开发环境下的配置文件

前言

Project创建

创建项目,从New Project开始,图文教程优于文案教程,所以创建过程已图文为主
项目创建图文步骤一:当https://start.spring.io无法连接时也可以使用custom的https://start.aliyun.com项目创建图文步骤一:项目的创建方式
项目创建图文步骤二
项目创建图文步骤二项目创建图文步骤三项目创建图文步骤三:项目的依赖配置
项目创建图文步骤四项目创建图文步骤四:项目的本地配置

初始项目结构说明

初始项目结构介绍图
到此,以上内容为整个项目个创建过程。
接下来就是启动项目验证,本地的启动方式有两种,如下图
项目启动图文

启动方式一:项目创建时自动配置好的启动类,也可通过配置Edit Configurations进行配置启动类为SpringbootApiApplication
启动方式二:值得注意的是SpringbootApiApplication.java中有main方法,所以可直接在SpringbootApiApplication类中右键任何位置进行run

初始项目配置

到此,项目虽然创建起来了,但只是创建过程中添加了部分基础组件,IDEA却无法在项目中进行自动生成配置,比如没有配置访问时的项目名、没有配置端口号、没有配置数据库等等,这些都是需要手动配置的,那么以下则为个人总结的初始项目需要配置的内容

个人习惯配置

对于SpringBoot项目的配置,有两种文件格式的配置方式,均可使用,所以遵循个人喜好即可
1、在application.properties中进行配置(默认生成的配置文件)
2、在application.yml中进行配置(层级更简洁,个人偏向)

Maven配置

下图仅为个人习惯配置,因为我个人本地有自己的Maven库,所以指定使用我自己的
项目个人配置内容图文一:本地Maven仓库的指定

数据库连接驱动JDBC的配置

spring:datasource:url: jdbc:mysql://localhost:3306/itsdf07_db?useUnicode=true&characterEncoding=utf-8&useSSL=falseusername: rootpassword:driver-class-name: com.mysql.jdbc.Driver

以上为个人平时的默认配置,useUnicode=true&characterEncoding=utf-8&useSSL=false这些为JDBC所携带的配置参数,请根据需要进行修改即可
如不配置上述JDBC的驱动内容,则无法启动项目,且出现异常信息如下

Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
2020-03-12 10:00:02.943 ERROR 7796 --- [           main] o.s.b.d.LoggingFailureAnalysisReporter   : ***************************
APPLICATION FAILED TO START
***************************Description:Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.Reason: Failed to determine a suitable driver classAction:Consider the following:If you want an embedded database (H2, HSQL or Derby), please put it on the classpath.If you have database settings to be loaded from a particular profile you may need to activate it (no profiles are currently active).Disconnected from the target VM, address: '127.0.0.1:61130', transport: 'socket'Process finished with exit code 1

异常原因其实很清楚,我们创建项目过程,只添加了组件,并没有配置组件的原因。到此,项目便可正常启动了,启动日志如下

2020-03-12 10:04:00.469  INFO 4196 --- [           main] com.itsdf07.SpringbootApiApplication     : Starting SpringbootApiApplication on DESKTOP-JQDVDVV with PID 4196 (D:\Workspaces\api\springboot-api\target\classes started by itsdf07 in D:\Workspaces\api\springboot-api)
2020-03-12 10:04:00.482  INFO 4196 --- [           main] com.itsdf07.SpringbootApiApplication     : No active profile set, falling back to default profiles: default
2020-03-12 10:04:01.774  WARN 4196 --- [           main] o.m.s.mapper.ClassPathMapperScanner      : No MyBatis mapper was found in '[com.itsdf07]' package. Please check your configuration.
2020-03-12 10:04:02.318  INFO 4196 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8080 (http)
2020-03-12 10:04:02.328  INFO 4196 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2020-03-12 10:04:02.329  INFO 4196 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.31]
2020-03-12 10:04:02.422  INFO 4196 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2020-03-12 10:04:02.422  INFO 4196 --- [           main] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 1808 ms
2020-03-12 10:04:02.661  INFO 4196 --- [           main] o.s.s.concurrent.ThreadPoolTaskExecutor  : Initializing ExecutorService 'applicationTaskExecutor'
2020-03-12 10:04:02.801  WARN 4196 --- [           main] ion$DefaultTemplateResolverConfiguration : Cannot find template location: classpath:/templates/ (please add some templates or check your Thymeleaf configuration)
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
2020-03-12 10:04:03.088  INFO 4196 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8080 (http) with context path ''
2020-03-12 10:04:03.093  INFO 4196 --- [           main] com.itsdf07.SpringbootApiApplication     : Started SpringbootApiApplication in 3.603 seconds (JVM running for 5.773)

经常带着疑问以及有看log习惯的人总能发现一写细节问题,如在启动过程的日志中,出现了JDBC的驱动警告提示Loading class com.mysql.jdbc.Driver’. This is deprecated. The new driver class is com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary
其实这个因为是JDBC连接Mysql不同版本时使用的驱动不匹配
com.mysql.jdbc.Driver 是 mysql-connector-java 5中的
com.mysql.cj.jdbc.Driver 是 mysql-connector-java 6中的
而项目在创建过程中添加组件时,均是默认最新版本,所有可在下图中查看当前项目中使用的Mysql版本就明白了
查看当前项目使用的mysql组件版本
解决方案就是驱动与Mysql版本对应即可,而修改方式有如下两种
1、Mysql6(含6)以上使用JDBC的com.mysql.cj.jdbc.Driver驱动
2、Mysql6以下使用JDBC的com.mysql.jdbc.Driver驱动
poc.xml中指定Mysql组件的版本配置如下

<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><!--<scope>runtime</scope>--><version>5.1.47</version><!--指定版本号-->
</dependency>

Tomcat配置

由于SpringBoot的打包特性是jar包,且使用默认集成的Tomcat服务器进行部署,而我们的项目部署之后访问规范中是根据项目名称以及接口名称进行访问,且要保证端口不与其他项目冲突,那么我这边也遵循其优点,进行配置自己项目名称以及端口号

server:port: 17081 #项目端口号servlet:context-path: /itsdf07 #访问的项目名

备注:SpringBoot项目同样也可以打成war包,并且使用自行配置的Tomcat服务器进行部署,但是本文不做这方面的说明!

Mybatis数据库映射配置

mybatis:mapper-locations: classpath:mapper/*.xml  #注意:一定要对应mapper映射xml文件的所在路径type-aliases-package: com.aso.store.entity  # 注意:对应实体类的路径configuration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl  # 配置控制台打印sql查询语句并附带查询结果数据

配置Mybatis Generator自动生成代码

pom.xml中增加mybatis generator 自动生成代码插件

<!-- mybatis generator 自动生成代码插件 --><plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.1</version><configuration><configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile><overwrite>true</overwrite><verbose>true</verbose></configuration></plugin>

resources中增加mybatis generator配置文件
增加generatorConfig.xml
配置mybatis generator文件的启动方式
配置mybatis generator的启动方式
在这里插入图片描述
启动方式
验证自动生成结果
验证自动生成结果

Thymeleaf配置

#  ###ThymeLeaf配置
thymeleaf:##配置模板引擎:是让controller层到templates文件夹寻找xx.html(src/main/resources/templates)prefix: classpath:/templates/ #配置前缀,可以不配置,因为静态页面存放的默认位置就是该templatessuffix: .html #配置后缀,也是可以不用配置,也是默认htmlcache: false #启用模板缓存。encoding: UTF-8 #模板编码content-type: text/html; charse=utf-8 #Content-Type值check-template: true #在呈现模板之前检查模板是否存在。check-template-location: true #检查模板位置是否存在。enabled: true #启用MVC Thymeleaf视图分辨率。excluded-view-names: #应该从解决方案中排除的视图名称的逗号分隔列表。mode: HTML5 #应用于模板的模板模式。另请参见StandardTemplateModeHandlers。template-resolver-order: #链中模板解析器的顺序。view-names: #可以解析的视图名称的逗号分隔列表。

Thymeleaf模板引擎的配置,如果只是简单的页面跳转,则可以不用配置,因为静态页面的默认存放路径就是在classpath:/templates/路径下

解决跨域问题

出于安全原因,浏览器禁止Ajax调用驻留在当前原点之外的资源

使用区分不同开发环境下的配置文件

在一个规范的项目运作中,从项目的研发到最后的上线生成过程中,应该要经过四种项目环境
1、本地开发环境,即dev版本
2、测试环境,即test版本
3、预生产环境,即pre版本
4、生产环境,即prod,且一般只有运维可以操作
在以上4中环境中,如果只用一个配置文件来达到四种环境下的不同配置,那么真的是一件不小的苦力活,而且还无法保证其改动的百分百正确性,那么java的面向对象封装思想就又体现出了其优势:即把共性的部分提取出来,不同环境的差异配置到不同环境的配置文件中,然后通过spring.profiles.active进行切换,切换规则为根据application-*.yml命名中*的内容进行配置
不同开发环境下的配置文件
从上图,可以看出,原本在application.yml中配置的端口号以及JDBC连接数据库的驱动配置已经看不见了,那么如果项目最起码的不配置JDBC连接数据库的驱动配置,项目肯定是启动不了的,那么配置到哪里去了呢?这里已开发环境和预生产环境的配置文件作为例子进行截图对比
在这里插入图片描述

在这里插入图片描述

这篇关于IDEA + Maven + SpringBoot + Mybatis + Thymeleaf + Swagger实现一个web项目的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/954644

相关文章

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一