Spring Boot 一.基础和项目搭建(上)

之前也自学过SSM框架,Spring Boot框架,也动手写过几个项目,但是这是第一次完整的记录。从0开始,把一些细节整理了一下。
大概会分为十几小节,这是一个学习的过程,更是一个思考的过程,废话不多说那就正式开始了。😊

Spring Boot 第一节 基础与入门[上]

  • 一.思维导图
  • 二.基本概念
  • 三.项目搭建
    • 1.项目搭建环境
    • 2.maven仓库
      • (1)maven安装于配置
      • (2)idea中的maven配置
    • 3.创建Spring Boot项目
      • (1)项目搭建
      • (2)项目起步
  • 四.idea配置热加载

一.思维导图

这是我的个人亿图脑图笔记,整理了一下,也是本节的大概内容。
分为上下两篇,上主要是项目配置和搭建,下为一些插件,项目目录结构,父子工程,以及一些接口工具的使用。
在这里插入图片描述

二.基本概念

  1. 先看百度搜索指数对比:(简洁明了)
    在这里插入图片描述

  2. 和传统的SSM框架不一样,Springboot框架将很多配置都简化了,自动配置好了,这一点使得它成为当代主流,当然也有一些老项目依旧是SSM框架。

  3. 其中一个主要特点:约定大于配置(知道即可)
    在这里插入图片描述

  4. 特性:简略,可以自行百度。(不影响)

三.项目搭建

1.项目搭建环境

工具:idea
jdk17(以上)
Spring Boot3
Maven仓库配置
mysql8.0

注意:如果版本不一样,可以使用老版本搭配:
jdk1.8,Spring boot2也是可以的

2.maven仓库

(1)maven安装于配置

  1. 下载好maven仓库工具,maven官网下载地址
    在这里插入图片描述
  2. 下载完成后,配置环境变量,系统的高级配置。[寻找教程]
    cmd测试一下:mvn -version,看看显示是否成功。
  3. 目录如下:其中要修改conf目录下的setting.xml文件,添加阿里云的镜像(清华的也行),配置放在下面,需要修改为自己的路径。
  4. 创建文件夹:repo,存放地址(名字随便取,英文)
    在这里插入图片描述
<?xml version="1.0" encoding="UTF-8"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.2.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.2.0 https://maven.apache.org/xsd/settings-1.2.0.xsd">//注意,/Users/moqi/tools/maven_jar要改为自己路径<localRepository>/Users/moqi/tools/maven_jar</localRepository><mirrors><mirror><id>aliyunmaven</id><mirrorOf>*</mirrorOf><name>阿里云公共仓库</name><url>https://maven.aliyun.com/repository/public</url></mirror></mirrors>
</settings>

(2)idea中的maven配置

上面配置完了,进行idea中的maven配置,打开setting,如下所示,修改为自己下载的maven仓库地址,下面两个同样改为自己的配置文件和储存文件夹。
在这里插入图片描述

3.创建Spring Boot项目

(1)项目搭建

  1. 打开idea,创建一个新项目,填写如下所示,配置完点击next:[域名用自己的]
    Name:项目名
    Location:项目存放地址
    Group:用自己域名的反写,一般默认com.example,可以自己修改
    jdk和java要对应:这里都是版本号17
    Packaging:jar
    在这里插入图片描述
  2. 下一步后勾选如下:
    可以一口气都勾选上,以后都要用,但是这样的话,下面的配置文件要连接数据库,否则会报错。
    如果先不连接数据库的话,只需要Lombok和SpringBootDevTools就行了。(这也是可以的,后续依赖配置我会发一个总的文件,复制粘贴即可)
    在这里插入图片描述
  3. 点击创建完成后,如下所示,创建成功:
    其中我们可选的依赖,maven仓库已经帮我们执行导入了,我们可以在pom文件中查看一下。
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/a74c835c8d644fc195a0d76ad90acebf.png

(2)项目起步

  1. 其中这个类我们的运行主类,如果创建时没有,要手写一下,如下所示。
    在这里插入图片描述
  2. rescource目录下的配置文件为application.yml或者默认application.properties。推荐使用application.yml格式,可以删除原来的,创建application.yml文件[基本配置如下]。
    其中这种格式:需要注意缩进。[这种是已经导入数据库依赖的,要配置连接的,没有导入的可以先忽略]
# 服务端口
server:port: 9090
# 数据库配置,如果没有添加数据库依赖,可以先不加
spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverusername:         #你本地的数据库用户名password:         #你本地的数据库密码url: jdbc:mysql://localhost:3306/数据库名称?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=GMT%2b8&allowPublicKeyRetrieval=trueservlet:multipart:max-file-size: 100MBmax-request-size: 100MB
  1. 运行一下主类:一般默认的端口号为8080,配置文件中可以修改为9090。运行成功:
    在这里插入图片描述

四.idea配置热加载

热加载:就是容器状态在运行的情况下重新加载改变编译后的类.在这种情况下内存不会清空,sessin不会丢失,但容易造成内存溢出,或者找不到方法。因为内存无法转变成对像. 一般改变类的结构和模型就会有异常,在已经有的变量和方法中改变是不会出问题的。在中模式最好是在调试过程中使用,免得整个项目加载.

打开setting,配置如下所示:
在这里插入图片描述

这里Spring Boot第一节上篇,主要分为配置搭建,内容较少,主要在环境搭建与项目的初步建立上,从思维导图上来说,三分之一左右。[但很重要,配置不对,一切白费!!]
下半节:工具和插件使用,各种接口,请求协议。其中下面的各种接口工具的使用,可能会有些难度。[实际操作和联系]
敬请期待下篇的到来:…

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/784126.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

金融汽车科技LLM

汇丰银行 众安保险 1. AIGC重塑保险价值链 小额高频 2.构建智能应用的技术方案演进 增加微服务 长记忆&#xff1a;向量库短记忆&#xff1a;对话历史&#xff0c;思考路径&#xff0c;执行历史 中台架构设计 蔚来汽车在大模型的应用实践 公司介绍 应用架构 应用实践 4.大…

Django框架之DRF(武沛齐全)

一、FBV和CBV FBV&#xff0c;function base views&#xff0c;其实就是编写函数来处理业务请求。 from django.contrib import admin from django.urls import path from app01 import views urlpatterns [path(users/, views.users), ] from django.http import JsonResp…

Java学习笔记NO.28

Java常用类 在Java编程中&#xff0c;有许多常用的类提供了丰富的功能和方法&#xff0c;帮助开发者更高效地完成各种任务。本文将介绍包装类、字符串相关类、日期时间类、Math类和枚举类&#xff0c;并提供相应的代码示例。 1. 包装类&#xff08;Wrapper Classes&#xff0…

快速排序---算法

1、算法概念 快速排序&#xff1a;通过一趟排序将待排记录分隔成独立的两部分&#xff0c;其中一部分记录的数据均比另一部分的数据小&#xff0c;则可分别对这两部分记录继续进行排序&#xff0c;以达到震哥哥序列有序。 快速排序的最坏运行情况是O()&#xff0c;比如说顺序数…

Java agent 使用

Java agent 使用 一、入口 public class ClassAgentApplication {public static void premain(String agentArgs, Instrumentation inst) {System.out.println("premain");}public static void agentmain(String agentArgs, Instrumentation inst){System.out.prin…

网络基础二补充——json与http协议

五、市面上常用序列化和反序列化工具 ​ 常用的有&#xff1a;json、protobuf、xml三种方案&#xff1b; 5.1json的使用 1.安装jsoncpp库&#xff0c;是一个第三方的开发库文件&#xff1b; sudo yum install -y jsoncpp-devel2.使用json ​ 经常使用的头文件是json.h&…

【uC/OS-III篇】uC/OS-III 创建第一个任务(For STM32)

uC/OS-III 创建第一个任务&#xff08;For STM32&#xff09; 日期&#xff1a;2024-3-30 23:55&#xff0c;结尾总结了今天学习的一些小收获 本博客对应的项目源码工程 源码项目工程 1. 首先定义错误码变量 // 用于使用uC/OS函数时返回错误码 OS_ERR err; 2. 定义任务控制…

Golang | Leetcode Golang题解之第2题两数相加

题目&#xff1a; 题解&#xff1a; func addTwoNumbers(l1, l2 *ListNode) (head *ListNode) {var tail *ListNodecarry : 0for l1 ! nil || l2 ! nil {n1, n2 : 0, 0if l1 ! nil {n1 l1.Vall1 l1.Next}if l2 ! nil {n2 l2.Vall2 l2.Next}sum : n1 n2 carrysum, carry …

leetcode350-Intersection of Two Arrays II

这道题目要求返回俩个数组的交集&#xff0c;且元素个数不再是唯一的&#xff0c;而是要和元素在两个数组中都出现的次数一致&#xff0c;如果元素在俩个数组中出现的次数不一样则取那个更小的。这道题目可以继续沿用上一道题目的思路&#xff0c;遍历第一个数组&#xff0c;用…

深入探索语言模型:原理、应用与评估

深入探索语言模型&#xff1a;原理、应用与评估 目录 深入探索语言模型&#xff1a;原理、应用与评估 一、 引言 二、语言模型原理 三、概率语言模型 四、 深度学习语言模型 五、 代码示例 六、 语言模型的评估 七、案例研究 一、 引言 在自然语言处理&#xff08;NL…

好用的编辑器Typora分享

好用的编辑器Typora分享 Typora是一个极简易风格的Markdown编辑器和阅读器&#xff0c;可以提供无缝的编辑和阅读体验。 一、下载和安装 Typora中文网&#xff1a;https://www.typora.net/ 可以下载安装试用版试用15天 如果需要永久使用&#xff0c;则需要安装带激活码的版…

力扣102. 二叉树的层序遍历(O(n)时间复杂度,通过queue实现简单BFS)

Problem: 102. 二叉树的层序遍历 思路 记录层次&#xff0c;要么建立树时记录&#xff0c;要么遍历时记录&#xff08;利用queue&#xff09; 解题方法 queue<pair<TreeNode*,int>>q; 记录节点及其层次 vector<vector> res; res[i]表示第i层(从0开始)的所有…

Github2024-03-31 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-03-31统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目6Jupyter Notebook项目3C项目1TypeScript项目1PHP项目1OpenDevin: 编写更少,实现更多 创建周期:14 天开发语言:Jupyter Notebook协…

npm 常用命令详解 详细

npm&#xff08;Node Package Manager&#xff09;是Node.js的包管理器&#xff0c;它允许JavaScript开发者分享和重用代码包&#xff0c;这样开发者就可以专注于自己的代码&#xff0c;而不必重新发明轮子。npm提供了大量的命令&#xff0c;用于安装、更新、删除和管理项目中的…

Vue ElementPlus Input输入框

Input 输入框 通过鼠标或键盘输入字符 input 为受控组件&#xff0c;它总会显示 Vue 绑定值。 通常情况下&#xff0c;应当处理 input 事件&#xff0c;并更新组件的绑定值&#xff08;或使用v-model&#xff09;。否则&#xff0c;输入框内显示的值将不会改变。不支持 v-mode…

【面试经典150 | 动态规划】最小路径和

文章目录 写在前面Tag题目来源解题思路方法一&#xff1a;动态规划方法二&#xff1a;空间优化 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题…

MCGS学习——水位控制

要求 插入一个水罐&#xff0c;液位最大值为37插入一个滑动输入器&#xff0c;用来调节水罐水位&#xff0c;滑动输入器最大调节为液位最大值&#xff0c;并能清楚的显示出液位情况用仪表显示水位变化情况&#xff0c;仪表最大显示设置直观清楚方便读数&#xff0c;主划线为小…

深入探索前端与后端数据交互:打造稳健、高效的数据通道

在软件开发中&#xff0c;前端与后端的数据交互不仅仅是简单的请求与响应过程&#xff0c;更是一个涉及多个层面、需要综合考虑多种因素的复杂系统。为了深入理解并优化这一过程&#xff0c;本文将从原理、常见的交互方法、技术选型、性能优化、安全性保障等方面展开详细探讨。…

设计模式-结构型-享元模式Flyweight

享元模式的特点&#xff1a; 享元模式可以共享相同的对象&#xff0c;避免创建过多的对象实例&#xff0c;从而节省内存资源 使用场景&#xff1a; 常用于需要创建大量相似的对象的情况 享元接口类 public interface Flyweight { void operate(String extrinsicState); } 享…

如何使用极狐GitLab 自定义 Pages 根域名

本文作者&#xff1a;徐晓伟 GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 本文主要讲述了极狐GitLab Pages …