如何通过idea搭建一个SpringBoot的Web项目(最基础版)
通过idea搭建一个SpringBoot的Web项目
文章目录
- 通过idea搭建一个SpringBoot的Web项目
- 一、打开idea,找到 create new project
- 二、创建方式
- 三、配置项目依赖
- 四、新建项目模块
- 五、总结
一、打开idea,找到 create new project
- 方式1

- 方式2

二、创建方式
- 新建项目
选中 Spring Initializr -> Project Sdk -> Next

- 配置项目
第一步点击next之后,如下图,最重要的是type,需要选择Maven,要based project的,不要创建pom.xml的,然后jdk这个可以调整可以不调整,主要看你自己有什么jdk包,还有就是调整包名(package)之类的,看个人需要,这些后续都能调整。最后再点击Next。

3. 项目依赖配置
第二步点击Next之后,到这一步骤,可以直接选择Next,后续需要什么依赖再通过pom文件进行导入即可

4. 项目路径配置
最后配置项目的路径即可,点击Next

三、配置项目依赖
新建项目的pom.xml文件如下:
<?xml version="1.0" encoding="UTF-8"?>
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.6.5</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.jzs</groupId><artifactId>log</artifactId><version>0.0.1-SNAPSHOT</version><name>log-demo1</name><description>single demo about log</description><properties><java.version>8</java.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-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>
- 跟项目配置步骤的对应关系如下图所示,属于可以修改的部分

- pom文件中目前只有两个依赖,一个是提供web项目服务支持的,一个是单元测试相关的,如下两图。


四、新建项目模块
- 项目中还可以分模块,项目模块其实就是一个新项目,只是有一个父子项目的关系。新增项目大体如下:选中项目->右键->New->Module,然后其他的就跟新建项目一样

- 可以在标签中添加子模块,可以在标签中指定父项目,指定父项目之后可以继承父项目中配置的依赖。
- 父项目pom文件
<?xml version="1.0" encoding="UTF-8"?>
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.6.5</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.jz</groupId><artifactId>all-demo</artifactId><version>0.0.1-SNAPSHOT</version><name>all-demo</name><description>Demo project for Spring Boot</description><modules><module>module1</module><module>module2</module></modules><properties><java.version>8</java.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-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>
- 子项目pom文件
<?xml version="1.0" encoding="UTF-8"?>
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.jz</groupId><artifactId>all-demo</artifactId><version>0.0.1-SNAPSHOT</version></parent><groupId>com.jz</groupId><artifactId>all-demo</artifactId><version>0.0.1-SNAPSHOT</version><name>all-demo-module1</name><description>Demo project for Spring Boot</description><properties><java.version>8</java.version></properties><dependencies></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>
五、总结
以上就是通过idea创建一个Java的简易项目框架,像分布式项目等也只是基于以上的流程,然后在依赖配置中增加所需的依赖和相关的配置而已,本质上是一样的创建方式。
相关文章:
如何通过idea搭建一个SpringBoot的Web项目(最基础版)
通过idea搭建一个SpringBoot的Web项目 文章目录 通过idea搭建一个SpringBoot的Web项目一、打开idea,找到 create new project二、创建方式三、配置项目依赖四、新建项目模块五、总结 一、打开idea,找到 create new project 方式1 方式2 二、创建方式 新…...
Python和FastAPI语义分析和文本图像
要点 使用FastAPI开发RESTful API,创建端点,自定义响应,结构化多路由。Pydantic数据验证库数据建模,创建依赖项注入。开发数据库和对象关系映射,SQLAlchemy,Tortoise ORM,MongoDB。建立权限和安…...
centos系统ssh7.4升级9.6
编译安装 OpenSSL 下载 OpenSSL 源代码: wget https://www.openssl.org/source/openssl-1.1.1w.tar.gz这个命令从 OpenSSL 的官方网站下载指定版本(1.1.1w)的源代码压缩包。 解压源代码: tar zxvf openssl-1.1.1w.tar.gz使用 tar…...
excel所有知识点
1要加双引号 工作表(.xlsx) 单击右键→插入,删除,移动、重命名、复制、设置标签颜色,选定全部工作表 工作表的移动:两个表打开→右键→移动(如果右键是灰色的,可能是保护工作表了)…...
显卡基础知识及元器件原理分析
显卡应该算是是目前最为火热的研发方向了,其中的明星公司当属英伟达。 当地时间8月23日,英伟达发布截至7月30日的2024财年第二财季财报,营收和利润成倍增长,均超市场预期。 财报显示,第二财季英伟达营收为135.07 亿美…...
Spark Rebalance hint的倾斜的处理(OptimizeSkewInRebalancePartitions)
背景 本文基于Spark 3.5.0 目前公司在做小文件合并的时候用到了 Spark Rebalance 这个算子,这个算子的主要作用是在AQE阶段的最后写文件的阶段进行小文件的合并,使得最后落盘的文件不会太大也不会太小,从而达到小文件合并的作用,…...
Vue 3中实现基于角色的权限认证实现思路
一、基于角色的权限认证主要步骤 在Vue 3中实现基于角色的权限认证通常涉及以下几个主要步骤: 定义角色和权限:首先需要在后端服务定义不同的角色和它们对应的权限。权限可以是对特定资源的访问权限,比如读取、写入、修改等。用户认证&#…...
Visual Studio 2022进行文件差异比较
前言 Visual Studio 2022在版本17.7.4中发布在解决方案资源管理器中比较文件的功能,通过使用此功能,可以轻松地查看两个文件之间的差异,包括添加、删除和修改的代码行。可以逐行查看差异,并根据需要手动调整和编辑文件内容以进行…...
1.2 编译型语言和解释型语言的区别
编译型语言和解释型语言的区别 通过高级语言编写的源码,我们能够轻松理解,但对于计算机来说,它只认识二进制指令,源码就是天书,根本无法识别。源码要想执行,必须先转换成二进制指令。 所谓二进制指令&…...
C语言-常量
什么是常量? 答:常量是在程序执行过程中,其值不发生改变的量,常量分为直接常量和符号常量两种。 其中直接常量又可以分为整型常量、实型常量、字符型常量、字符串常量。 直接常量 1.整型常量 整型常量即整数,包括正整数,负整数和0。c语言中常量可以用八进制,十进制和十六…...
开源的OCR工具基本使用:PaddleOCR/Tesseract/CnOCR
前言 因项目需要,调研了一下目前市面上一些开源的OCR工具,支持本地部署,非调用API,主要有PaddleOCR/CnOCR/chinese_lite OCR/EasyOCR/Tesseract/chineseocr/mmocr这几款产品。 本文主要尝试了EasyOCR/CnOCR/Tesseract/PaddleOCR这…...
vue3实现输入框短信验证码功能---全网始祖
组件功能分析 1.按键删除,清空当前input,并跳转prevInput & 获取焦点,按键delete,清空当前input,并跳转nextInput & 获取焦点。按键Home/End键,焦点跳转first/最后一个input输入框。ArrowLeft/ArrowRight键点击…...
[C#]winformYOLO区域检测任意形状区域绘制射线算法实现
【简单介绍】 Winform OpenCVSharp YOLO区域检测与任意形状区域射线绘制算法实现 在现代安全监控系统中,区域检测是一项至关重要的功能。通过使用Winform结合OpenCVSharp库,并结合YOLO(You Only Look Once)算法,我们…...
个人网站制作 Part 14 添加网站分析工具 | Web开发项目
文章目录 👩💻 基础Web开发练手项目系列:个人网站制作🚀 添加网站分析工具🔨使用Google Analytics🔧步骤 1: 注册Google Analytics账户🔧步骤 2: 获取跟踪代码 🔨使用Vue.js&#…...
数据按设定单位(分辨率)划分的方法
1. 问题描述 需要将使用公式计算后的float数值换算到固定间隔数轴的对应位置上的数据,比如2.186这个数据,将该数据换算到以0.25为间隔的数轴上,换算后是2.0,还是2.25呢?该方法就是解决这个问题。 2. 方法 输入&…...
Ubuntu 搭建gitlab服务器,及使用repo管理
一、GitLab安装与配置 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的Web服务。 1、安装Ubuntu系统(这个教程很多,就不展开了)。 2、安装gitlab社区版本,有需…...
QT(19)-QNetworkRequest
attribute(QNetworkRequest::Attribute code, const QVariant &defaultValue QVariant()) const 获取指定的请求属性。如果该属性未设置,则返回默认值。 hasRawHeader(const QByteArray &headerName) const 检查是否存在指定名称的原始请求头。 header(Q…...
基于Vue的社区旧衣回收利用系统的设计与实现
经济的高速发展使得每一个家庭的收入都获得了大幅增长,随之而来的就是各种梦想的逐步实现,首当其冲的就是各类衣服的更新换代而导致了大量旧衣物在家中的积存。为了帮助人们解决旧衣物处理的问题而以当前主流的互联网技术构建一个可于社区中实现旧衣回收…...
【网站项目】291校园疫情防控系统
🙊作者简介:拥有多年开发工作经验,分享技术代码帮助学生学习,独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。🌹赠送计算机毕业设计600个选题excel文件,帮助大学选题。赠送开题报告模板ÿ…...
win git filter-repo教程
git filter-repo 是一个用于过滤和清理 Git 仓库历史的工具,它可以高效地批量修改提交历史中的文件内容、删除文件、重命名文件以及进行其他历史重构操作。相较于 git filter-branch,它通常更快且更易于使用。 以下是一个基本示例,说明如何使…...
阶段零:AI、机器学习、深度学习之间的关系
AI、机器学习、深度学习:一文讲透三者的关系从零开始,用最直观的方式理解AI核心概念一、一句话说清楚 深度学习 ⊂ 机器学习 ⊂ 人工智能 这三个概念是层层包含的关系,就像俄罗斯套娃一样: 最外层:人工智能(…...
nomic-embed-text-v2-moe效果对比:在低资源语言(如尼泊尔语)上的零样本迁移能力
nomic-embed-text-v2-moe效果对比:在低资源语言(如尼泊尔语)上的零样本迁移能力 1. 引言:当AI遇到“小众”语言 想象一下,你正在开发一个面向全球用户的智能搜索应用。对于英语、中文这类主流语言,市面上…...
NSudo完整指南:解锁Windows系统管理终极权限的5种方法
NSudo完整指南:解锁Windows系统管理终极权限的5种方法 【免费下载链接】NSudo [Deprecated, work in progress alternative: https://github.com/M2Team/NanaRun] Series of System Administration Tools 项目地址: https://gitcode.com/gh_mirrors/ns/NSudo …...
Qt 树模型(Tree Model)的增删改查实战解析
1. Qt树模型基础概念解析 第一次接触Qt的树模型时,我完全被那些抽象概念绕晕了。直到做了几个实际项目后才明白,Tree Model本质上就是个数据管家,它帮我们管理树形结构的数据,并让这些数据能通过Qt的视图组件(比如QTre…...
LiuJuan Z-Image详细步骤:自定义权重注入全流程(含键名清洗脚本)
LiuJuan Z-Image详细步骤:自定义权重注入全流程(含键名清洗脚本) 1. 引言:为什么需要自定义权重注入? 如果你用过一些开源的图片生成模型,可能会发现一个头疼的问题:好不容易找到一个别人训练…...
猫抓浏览器插件:网页资源嗅探与下载的完整指南
猫抓浏览器插件:网页资源嗅探与下载的完整指南 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 你是否经常遇到这样的情况:看…...
创新视角:OpCore Simplify如何重新定义Hackintosh系统定制
创新视角:OpCore Simplify如何重新定义Hackintosh系统定制 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 在开源系统定制领域,…...
7个实用技巧!Vue组件测试指南:基于TypeScript-Vue-Starter的Jest单元测试实战
7个实用技巧!Vue组件测试指南:基于TypeScript-Vue-Starter的Jest单元测试实战 【免费下载链接】TypeScript-Vue-Starter A starter template for TypeScript and Vue with a detailed README describing how to use the two together. 项目地址: https…...
从Claude Agent Skills到Hatchify多Agent:我是如何把团队知识库变成自动化工作流的
从静态文档到智能工作流:基于Claude与Hatchify的团队知识自动化实践 当研发团队的文档库膨胀到Confluence里300页面、GitLab中50Markdown文件时,我们突然意识到一个残酷事实——这些耗费心血整理的代码规范、部署清单和排障手册,正以每月15%的…...
AudioSeal Pixel Studio惊艳效果展示:水印嵌入前后MOS语音质量主观评测结果
AudioSeal Pixel Studio惊艳效果展示:水印嵌入前后MOS语音质量主观评测结果 1. 专业级音频水印技术揭秘 AudioSeal Pixel Studio是一款基于Meta开源的AudioSeal算法构建的音频保护工具。它能在几乎不影响音质的情况下,为音频添加隐形的数字水印&#x…...
