1.JavaEE进阶篇 - 为什么要学习SpringBoot呢?

news2024/11/25 19:38:48

文章目录

  • 1.为什么要学框架?
  • 2.框架的优点展示(SpringBoot VS Servlet)
    • 2.1 Servlet 项⽬开发
      • 2.1.1 创建项⽬
      • 2.1.2 添加引⽤
      • 2.1.3 添加业务代码
      • 2.1.4 运⾏项⽬(配置tomcat)
      • 2.1.5 Maven配置
        • 2.1.5.1修改本地Maven仓库地址
        • 2.1.5.2 配置settings.xml文件
        • 2.1.5.3项目 本地仓库 中央仓库 私服 区别与联系
        • 2.1.5.4Maven包下载不下来
        • 2.1.5.5快捷修改文件名
      • 2.1.6 Servlet 痛点分析
    • 2.2 SpringBoot 项⽬开发
      • 2.2.1 创建并添加引⽤
      • 2.2.2 添加代码并运⾏程序
      • 2.2.3 发布程序
      • 2.2.5 SpringBoot VS Servlet
  • 3.怎么学框架?
  • 4.框架学习中的难点

大家好,我是晓星航。今天为大家带来的是 JavaEE 进阶导读 相关的讲解!😀

1.为什么要学框架?

  1. 学习框架相当于从“小作坊”到“工厂”的升级,小作坊什么都要自己做,工厂是组件式装配,特点就是高效。
  2. 框架更加易用、简单且高效。

框架主要体现在思维方式和编程思想上,与代码语言无关。

易⽤、简单、⾼效的特性体现在哪些⽅⾯呢?继续往下看。

2.框架的优点展示(SpringBoot VS Servlet)

使⽤ Spring Boot 项⽬演示框架相⽐于 Servlet 所具备的以下优点:

  1. ⽆需配置 Tomcat,点击“运⾏”按钮就可以运⾏项⽬,Spring Boot 内置了 Web 容器(可直接运 ⾏)。
  2. 快速添加外部 jar 包。
  3. 快速发布项⽬(使⽤ java -jar ⽅式就可以发布)。
  4. 对象⾃动装配。

使⽤ SpringBoot 和 Servlet 对⽐,演示⼀个⽤户添加的案例,展示以上优点。

2.1 Servlet 项⽬开发

2.1.1 创建项⽬

image-20240301142439609

2.1.2 添加引⽤

打开 https://mvnrepository.com 搜索 servlet 添加框架应⽤到 pom.xml 中,如下图所示:

image-20240301142550725

PS:其中还需要注意使⽤的版本号。

image-20240301143229112

在项⽬中右键添加“源代码”⽂件夹,如下图所示:

image-20240301143321941

image-20240301143344128

2.1.3 添加业务代码

配置路由⽂件 web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
 http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
 version="3.1"
 metadata-complete="false">
</web-app>

添加实体类:

public class User {
 private Integer id;
 private String name;
 private Integer age;
 private String password;
 // 其他属性...
 public Integer getId() {
 return id;
 }
 public void setId(Integer id) {
 this.id = id;
 }
 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }
 public Integer getAge() {
 return age;
 }
 public void setAge(Integer age) {
 this.age = age;
 }
 public String getPassword() {
 return password;
 }
 public void setPassword(String password) {
 this.password = password;
 }
 @Override
 public String toString() {
 return String.format("{id:%d,name:%s,age:%d,password:%s}",
 id,name,age,password);
 }
}

添加控制器:

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet("/adduser")
public class AddUser extends HttpServlet {
 @Override
 protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
 this.doPost(req, resp);
 }
 @Override
 protected void doPost(HttpServletRequest req, HttpServletResponse resp
) throws ServletException, IOException {
 // 1.获取参数
 String name = req.getParameter("name");
 //...
 // 2.插⼊数据库
 System.out.println("插⼊数据库");
 // 3.返回结果
 resp.setContentType("text/html");
 resp.setCharacterEncoding("utf-8");
 resp.getWriter().println("添加成功:" + name);
 }
}

2.1.4 运⾏项⽬(配置tomcat)

image-20240301143708466

image-20240301143734124

image-20240301143832528

2.1.5 Maven配置

本地仓库地址查询:

image-20240301145522151

上图可以看到,博主的仓库地址包含中文,因此需要重新选择仓库位置,将仓库进行转移,转移仓库位置方法在后面为大家进行讲解!!!

我们把本地仓库地址拷贝到c盘中查询

image-20240301145707345

可以看到我们本地仓库有这么多的地址

image-20240301145737397

例如我们进入mysql可以看到我们mysql的Maven配置文件

2.1.5.1修改本地Maven仓库地址

最初的Maven默认地址位置:

image-20240301145522151

1.首先找到我们之前的Maven本地地址所在的位置

image-20240301150524646

2.创建好新的文件夹位置并将C盘中旧的Maven仓库中的资源全部拷贝过来!

image-20240301150744358

3.再返回idea的设置中,找到设置Maven仓库位置进行更改

image-20240301151224227

如此我们便大功告成了!!!(注意文件夹的命名千万不要包含中文,否则日后使用的时候可能会报错!)

2.1.5.2 配置settings.xml文件

从网上下载资源包并解压放在文件夹中

image-20240301155545023

右键使用vscode或者其他文本编辑器打开查看(因为文本编辑器可以把代码部分高亮表示出来,方便我们查看以及修改)

image-20240301155636096

从图中我们可以发现,这个settings.xml 文件使用的是阿里云的镜像仓库

image-20240301155727516

最后我们需要选择一下,让我们以后的新项目都会自动配置到我们Maven的新仓库去下载

image-20240301160408309

可以看到打开后还是我们的setting设置中

image-20240301160544680

找到Maven设置出发现我们新项目的Maven仓库位置还是默认的C盘

image-20240301160534905

重复之前的操作将此处的位置更改到我们更改的文件夹中,点击Apply然后OK即可

image-20240301160729852

此时便配置完成了,我们的代码会优先从阿里云中下载所需的依赖,如果阿里云没有的话才会转而找到中央仓库去下载。

2.1.5.3项目 本地仓库 中央仓库 私服 区别与联系

本地仓库:自己电脑上存储资源的仓库,连接远程仓库获取资源。

远程仓库:非本机电脑上的仓库,为本地仓库提供资源。
远程仓库又分私服和中央仓库:

中央仓库:Maven 团队维护,存储所有资源的仓库。

私服:部门/公司范围内存储资源的仓库,从中央仓库获取资源;

项目 本地仓库 中央仓库 关系图:

image-20240301151641247

项目 本地仓库 中央仓库 私服 关系图:

image-20240301152817794

项目 本地仓库 中央仓库 私服 镜像仓库 关系图:

image-20240301152134866

2.1.5.4Maven包下载不下来

1.确认包是否存在

2.如果包存在,就多下几次

3.如果下载了很多次,都下载不下来

1)是否配置了国内源 setting.xml

2)目录是否是全英文 存在中文的话,修改路径

3)删除本地仓库的jar包,重新下载
可能存在的一个原因是,上次下载时,因为网络原因,造成jar包下载了一半
解决方法是删除指定没下载完的jar包就可以啦

2.1.5.5快捷修改文件名

shift + F6可以快捷改文件夹的名字

不要直接修改文件名,通过idea提供的方式修改文件名的好处:
1.idea 会帮我们查找相关的代码
2.idea 会进行提示
3.idea 会帮我们把关联的文件名相关的代码
全部修改

2.1.6 Servlet 痛点分析

  1. 添加外部 jar 不⽅便,容易出错,⽐如添加了⼀个不匹配的外部 jar 版本;
  2. 运⾏和调试的时候需要配置 tomcat 不⽅便;
  3. 发布不⽅便,servlet 项⽬必须依靠外置的 tomcat(外置的 web 容器)运⾏。
  4. 路由配置不⽅便,⼀个访问地址对应⼀个 Servlet 类。

⽽以上痛点问题,都可以通过 JavaEE 进阶框架解决,接下来我们⼀起来看。

2.2 SpringBoot 项⽬开发

各个目录文件夹解析:

image-20240304172456383

2.2.1 创建并添加引⽤

还可以通过
start.spring.io
网址来创建项目,通过网页编程,然后将文件保存知道本地

image-20240304172149373

由于博主是专业版idea因此不需要额外安装插件来导入SpringBoot

image-20240304152645022

这里Java版本无8,jdk使用1.8不适应Java17的版本要求不能创建项目,因此我们先默认创建进去之后再改jdk版本和Java版本,之后文章会教,注意阅读噢!!!(这里我们选用Java17版本,jdk17,SpringBoot版本3)

springboot3.0更新后,idea创建springboot2.x项目 - CSDN App

选择 SpringBoot 版本和添加外部引⽤:

image-20240304155816966

image-20240304155901600

2.2.2 添加代码并运⾏程序

⽤户实体:

import lombok.Data;
@Data
public class User {
 private Integer id;
 private String name;
 private Integer age;
 private String password;
}

添加控制器:

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RequestMapping("/user")
@RestController
public class UserController {
 @RequestMapping("/add")
 public String add(User user){
 return user.toString();
 }
}

点击调试运行按钮即可运⾏项⽬:

image-20240304161006604

程序2:

image-20240304161555862
package org.example.demo.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
/**
 * Created with IntelliJ IDEA
 * Description
 * User: 晓星航
 * Date: 2024 -03 -04
 * Time: 16:13
 */
public class HelloController {
    @RequestMapping("/sayhi")
    public String sayHi() {
        return "hello,SpringBoot";
    }

}

写好代码后,我们找到下图中的运行程序类直接运行,即可将程序跑到网页上,不需要再去花大量时间配置Tomcat了。

image-20240304162014952

注: @RequestMapping("/sayhi") 这里代码意为将上述代码放入了sayhi这个文件夹中

我们输入 127.0.0.1:8080/sayhi 即可成功访问并展示我们刚才所写的代码

image-20240304161926142

关闭运行,再次访问

image-20240304162701077

可以发现我们程序运行了了

image-20240304162941135

如果我们再加一个网页进来,我们仍然只需要重新返回image-20240304163022495
中点击重新运行就可

image-20240304163108302

image-20240304163130040

2.2.3 发布程序

image-20240304161032394

image-20240304161054292

2.2.4 Tomcat启动失败

image-20240304174647471

2.2.5 SpringBoot VS Servlet

SpringBoot 相⽐于 Servlet 的优点总结:

  1. 添加外部 jar 更容易,不易出错(版本问题⽆需关注);
  2. 调试项⽬更加⽅便,⽆需配置 Tomcat;
  3. 发布项⽬更加⽅便,⽆需配置 Tomcat;
  4. 添加路由更加⽅便,⽆需每个访问地址都添加⼀个类。

现在我们已经知道了框架的优点了,哪怎么去学呢?

3.怎么学框架?

  • 先从基础框架 Spring 开始(⼯具箱)
  • Spring Boot 快速开发 Spring 脚⼿架
  • MyBatis 快速操作数据库
  • 其他:⽇志、事务、拦截器…

框架学习中需要注意什么呢?

4.框架学习中的难点

  1. 配置⽐较多。
  2. 需要⼤量的外部 jar 包,在下载时容易出错。
  3. 会涉及简单的软件⼯程的设计思想(分层思想:前、后端的分层思想;后端⼯程的分层思想)。
  4. 知识点相对来说⽐之前的知识更加的分散,要仔细听才能搞懂各个知识点的逻辑关系。
  5. 要记的东⻄很多,所以要⼤量地重复练习才能记住,⽐如各种注解。

感谢各位读者的阅读,本文章有任何错误都可以在评论区发表你们的意见,我会对文章进行改正的。如果本文章对你有帮助请动一动你们敏捷的小手点一点赞,你的每一次鼓励都是作者创作的动力哦!😘

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

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

相关文章

Nginx开发实战三:替换请求资源中的固定数据

文章目录 1.效果预览2.下载Nginx解压并初始化3.字符串替换模块安装4.修改nginx配置文件并重启 1.效果预览 页面初始效果 页面替换后效果 说明:页面是内网的一个地址&#xff0c;我们通过nginx可以很便捷的将其改为外网访问&#xff0c;但是在外网访问这个地址后&#xff0c…

剑指offer--数组中重复的数字

一.题目描述 在一个长度为 n 的数组 nums 里的所有数字都在 0&#xff5e;n-1 的范围内。数组中某些数字是重复的&#xff0c;但不知道有几个数字重复了&#xff0c;也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。 算法1.排序,然后遍历,时间复杂度O(nlogn),空…

CVE-2023-4427:Out-of-bounds access in ReduceJSLoadPropertyWithEnumeratedKey

文章目录 前言环境搭建for-in && enum cache漏洞分析漏洞利用总结参考 前言 之前分析调试漏洞时&#xff0c;几乎都是对着别人的 poc/exp 调试&#xff0c;感觉对自己的提升不是很大&#xff0c;所以后面分析漏洞时尽可能全面分析&#xff0c;从漏洞产生原理、如何稳定…

前端学习<三>CSS进阶——0102-CSS布局样式

前言 css 进阶的主要内容如下。 1、css 非布局样式 html 元素的分类和特性 css 选择器 css 常见属性&#xff08;非布局样式&#xff09; 2、css 布局相关 css 布局属性和组合解析 常见布局方案 三栏布局案例 3、动画和效果 属于 css 中最出彩的内容。 多背景多投影特…

(C)1007 素数对猜想

1007 素数对猜想 问题描述 输入样例&#xff1a; 20 输出样例&#xff1a; 4 解决方案&#xff1a; #include<stdio.h> #include<string.h> #include<math.h> int main(){int n,d;int a[100000];int flag,jishu0;scanf("%d",&n);memset(a,-1,…

HubSpot出海CRM的优势有哪些?

强大的客户关系管理能力&#xff1a;HubSpot出海CRM提供了一套完整的客户关系管理功能&#xff0c;企业可以轻松地记录、整理和分析客户的各种信息&#xff0c;包括基本资料、购买历史、沟通记录等。这使得企业能够更深入地了解客户的需求和偏好&#xff0c;为后续的营销和销售…

持续交付/持续部署流水线介绍(CD)

目录 一、概述 二、典型操作流程 2.1 CI/CD典型操作流 2.2 CI/CD操作流程说明 2.3 总结 三、基于GitHubDocker的持续交付/持续部署流水线&#xff08;公有云&#xff09; 3.1 基于GitHubDocker的持续交付/持续部署操作流程示意图 3.2 GitHubDocker持续交付/持续部署流水…

2023.4.7 机器学习周报

目录 引言 Abstract 文献阅读 1、题目 2、引言 3、过去方案和Motivation 4、Segment Anything模型 5、创新点 6、实验过程 7、实验结果 1、评价绩效 2、检测评价 3、跟踪评价 8、 结论 总结 引言 本周阅读了一篇关于高效的任意分割模型的文献&#xff0c;用于自…

1区、TOP、CCF推荐,最快16天录用!4月刊源表已更新!

毕业推荐 SSCI • 社科类&#xff0c;分区稳步上升&#xff08;最快13天录用&#xff09; IEEE&#xff1a; • 计算机类&#xff0c;1区(TOP)&#xff0c;CCF推荐 SCIE • 计算机工程类&#xff0c;CCF推荐&#xff08;最快16天录用&#xff09; 2024年4月 SCI/SSCI/EI…

环境搭建 | Windows 11系统从0开始搭建SonarQube环境分析C sharp项目代码

1 安装&使用流程 JDK 17环境搭建Sonarqube 10.0安装PostgreSQL 12数据库安装配置MSBuild下载安装SonarScanner for MSBuild使用SonarQube分析C#代码并上传到服务器 注意&#xff1a;SonarQube环境搭建时对各个软件的版本都有要求&#xff0c;如果你不确定使用何版本&…

窥探未来:Web3如何颠覆传统互联网

随着科技的迅速发展&#xff0c;Web3正逐渐成为人们关注的焦点。与传统的Web2相比&#xff0c;Web3代表了一种全新的互联网模式&#xff0c;其潜力和影响力引发了人们对未来的期待和探索。本文将深入探讨Web3如何颠覆传统互联网的各个方面&#xff0c;并展望其可能带来的未来变…

缺省参数

缺省参数 缺省参数概念 缺省参数是声明或定义函数时为函数的参数指定一个缺省值。在调用该函数时&#xff0c;如果没有指定实 参则采用该形参的缺省值&#xff0c;否则使用指定的实参。 void Func(int a 0) {cout<<a<<endl; } int main() {Func(); // 没有传…

websocket 局域网 webrtc 一对一 多对多 视频通话 的示例

基本介绍 WebRTC&#xff08;Web Real-Time Communications&#xff09;是一项实时通讯技术&#xff0c;它允许网络应用或者站点&#xff0c;在不借助中间媒介的情况下&#xff0c;建立浏览器之间点对点&#xff08;Peer-to-Peer&#xff09;的连接&#xff0c;实现视频流和&am…

DC-9靶场

一.环境搭建 1.下载地址 靶机下载地址&#xff1a;https://download.vulnhub.com/dc/DC-9.zip 2.虚拟机配置 设置虚拟机为nat&#xff0c;遇到错误点重试和是 开启虚拟机如下图所示 二.开始渗透 1. 信息收集 查找靶机的ip地址 arp-scan -l 发现靶机的ip地址为192.168.11…

计算机网络面试问题(一)

1.在浏览器中输⼊URL并按下回⻋之后会发⽣什么 2.TCP三次握⼿的过程,为什么三次握手 TCP&#xff08;传输控制协议&#xff09;的三次握⼿是建⽴⽹络连接的过程&#xff0c;确保通信双⽅能够正确地进⾏数据传输。 第⼀次握⼿&#xff08;SYN&#xff09;&#xff1a; 客户端&am…

从原理图到PCB全过程(嘉立创)1

1 将已经画好的原理图更新到PCB中&#xff08;点击应用修改&#xff09; 2 一开始PCB是杂乱的&#xff0c;需要回到原理图&#xff0c;框选各个模块&#xff0c;然后按住CtrlShiftX会自动在PCB显示这个部分&#xff0c;然后把各个部分分开 3 PCB画板需要有板框(嘉立创每个月都i…

2024年限时免费:申领一年免费二级域名

免费申领一年域名 onflashdrive.app&#xff0c;现已可转入 CloudFlare 托管&#xff01; #注册账号 1、打开身份生成网站&#xff0c;然后按照图片下面所填写即可 邮箱填写自己的&#xff0c;密码必须包含大写字母 2、选择 New orders 3、点击选择产品–>Domain 4、输入…

GT收发器第六篇_GT channel内部时钟关系

文章目录 一、TX端时钟二、RX端时钟 一、TX端时钟 TX端可分为4个区域&#xff0c;分别为FPGA TX接口、PCS靠FPGA侧、PCS靠PMA侧、PMA&#xff0c;如下图。GTX/GTH发射器包括TXBUFFER和TX相位校准电路&#xff0c;以解决时钟域之间的相位差。TX相位校准电路用于TXBUFFER被旁路时…

【THM】Passive Reconnaissance(被动侦察)-初级渗透测试

介绍 欢迎来到网络安全模块的第一个房间,该模块涵盖: 1.被动侦察 2.主动侦察 3.Nmap实时主机发现 4.Nmap基本端口扫描 5.Nmap高级端口扫描 6.Nmap后端口扫描 7.协议和服务器 8.协议和服务器2 9.网络安全挑战 在这个房间里,在我们定义被动侦察和主动侦察之后,我们…

windows linux 安装 nvm

windows 一、下载nvm-windows 前往github https://github.com/coreybutler/nvm-windows 进入latest 往下滑下载nvm-setup.exe 二、下载好后直接一直点击下一步就好。 检查一下 nvm -v &#xff0c;会输出版本号 附带常用命令 nvm install 10.15.3 安装v10.15.3版本 nvm u…