百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Eclipse+Spring boot开发教程(eclipse spring boot怎么运行)

liuian 2025-01-26 23:18 11 浏览

一、安装

其实spring boot官方已经提供了用于开发spring boot的定制版eclipse(STS,Spring Tool Suite)直接下载使用即可,但考虑到可能有些小伙伴不想又多装个eclipse,我们这里还是介绍使用原版eclipse再在其上安装spring插件进行开发的方法。

STS地址:
http://spring.io/tools3/sts/all

1.1 安装jdk

jdk一是用于运行eclipse,二是用于开发spring boot项目。

安装方法可参考链接:
https://www.cnblogs.com/lsdb/p/6497816.html

jdk官方地址:
https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html

1.2 安装eclipse

eclipse可用于开发多种语言的项目,选择Eclipse IDE for Java EE Developers版本下载,解压即可(Eclipse IDE for Java Developers版本应该也可以)

官方地址:
https://www.eclipse.org/downloads/packages/

1.3 安装spring插件

打开eclipse----菜单----Help----Eclipse Marketplace----在Find搜索框中输入spring----回车搜索

注意这里不是我们点Finish就安装完成了,注意看eclipse右下角installing software到百分之百时才是安装完成,安装完成后会提示重启如下选择重启即可。

(一是插件比较大二是外国网站网速比较慢三是在线安装感觉就是经常有问题,其实不太推荐在线安装;但是离线安装又有问题没搞定所以只能演示在线安装)

二、新建spring boot项目

打开eclipse----菜单
----File----New----Project(插件装成功后才会有Spring Boot项)

填好项目信息,点击next(这里本质还是到https://start.spring.io/页面生成项目)

finish之后我们就得到了一个spring boot项目,其目录结构如下(此时所有东西都是自动生成的未做任何改动)

三、实现REST请求

在上一步中我们已经得到了一个spring boot项目,下边我们以在此基础上实现一个rest请求作为开发演示

3.1 创建项目结构

首先我们按习惯在demo目录下,创建model文件夹(用于存放model)、dao文件夹(用于存放数据访问文件)、controller文件夹(用于存放控制器)、service(用于存放主要的程序逻辑代码)

(不过下面为了简单起见dao和service不用到,只使用model,然后controller直接返回结果。)

3.2 实现model

在model文件夹创建Test.java文件,写入以下内容:

package com.example.demo.model;

public class Test {

    private final long id;
    private final String content;

    public Test(long id, String content) {
        this.id = id;
        this.content = content;
    }

    public long getId() {
        return id;
    }

    public String getContent() {
        return content;
    }
}

3.3 实现controller

在controller文件夹创建TestController.java文件,写入以下内容:

(该内容主要是对test和test1两个请求进行响应,test和test1两个请求的返回结果是一样的写两个是为了强调一个Controller文件就可以处理多个请求,不用每个请求都建一个Controller)

package com.example.demo.controller;

import java.util.concurrent.atomic.AtomicLong;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import com.example.demo.model.Test;

@RestController
public class TestController {

    private static final String template = "Hello, %s!";
    private final AtomicLong counter = new AtomicLong();

    @RequestMapping("/test")
    public Test dealTest(@RequestParam(value="name", defaultValue="World") String name) {
        return new Test(counter.incrementAndGet(),
                            String.format(template, name));
    }
    @RequestMapping("/test1")
    public Test dealTest1(@RequestParam(value="name", defaultValue="World") String name) {
        return new Test(counter.incrementAndGet(),
                            String.format(template, name));
    }
}

完成后项目结构如下:

3.4 运行项目

选择项目----右键----Run As----Spring Boot App

控制台选项卡会打印运行日志,如下我们可以看到监听于本地8080端口

又由于我们前面创建了test请求的响应,此时通过浏览器访问
http://localhost:8080/test,响应结果如下:

3.5 实现热部署

在当前项目中但凡我们对项目文件有所修改,要修其生效都要手动重新运行;比如我们将请求修从test修改为modify,要此修改生效就得手动重新运行这是比较麻烦的。

如果能修改保存之后系统自己重新运行那是非常好的,这就是所谓的热部署,而spring boot通过简单配置就能实现热部署。

首生,打开项目根目录下的pom.xml文件,在标签内加入以下内容:


    org.springframework.boot
    spring-boot-devtools
    true

其次,eclipse菜单----Project菜单----确保Build Automatically处于钩选状态。

经此两步,每当选择“保存”eclipse检测到项目有修改就会自动重新构建项目免去手动重启的麻烦。

四、使用体验

一、关于spring boot本身

如果我们去看ssh的书(比如《Struts2 Spring Hibernate框架技术与项目实战》)就会看到厚厚的一本,然后其中很大部分内容是教你到哪下载什么文件放到哪里然后要修改哪些配置文件----反正就是说搭建ssh开发环境就是一件旁杂的事情。

但到spring boot中一是spring boot其实可以实现ssh的作用消灭了一堆集成配置,二是自带tomcat消灭了tomcat的安装配置,三是自身支持REST,四是maven/gradle简化了jar文件的下载安装及一些配置,通过这几点确实实现了其“简单”的口号。

二、关于技术迭代

网上总存在着这样的感慨----技术迭代得太快了----这大概是asp/dephi/C++年代的前辈声音;而伴随着这种感慨会有一种批评----技术的本质还是不怎么变只要掌握本质再花点时间就能掌握新技术----这大概是移动互联网兴起以来进入计算机的新人发出的声音。

本质未变可以理解,正如我们这里只要会写ssh那么只需要花点时间就能写spring boot。但所谓“花点时间”让我想起以前学数学的时候对某个解法不是很熟练,然后想这应该没多大关系到考试时只要多花两分钟还是能算出来,然而到考试的时候发现并挤不出那所谓的两分钟。生活也许不像考试限定你一两个小时,但生活也不只是写程序每天可以有时间学习。

这里最坏的时代,新的技术总是层出不穷让人疲于奔命;这是最好的时代,规律越来越明显文档越来越清晰框架越来越强大。最坏的时代无法抗拒,只能用最好的时代来安慰自己。


参考:

https://www.yiibai.com/spring-boot/spring_boot_introduction.html

https://blog.csdn.net/Guohenghenghaha/article/details/76080229

相关推荐

【常识】如何优化Windows 7

优化Windows7可以让这个经典系统运行更流畅,特别是在老旧硬件上。以下是经过整理的实用优化方案,分为基础优化和进阶优化两部分:一、基础优化(适合所有用户)1.关闭不必要的视觉效果右键计算机...

系统优化!Windows 11/10 必做的十个优化配置

以下是为Windows10/11用户整理的10个必做优化配置,涵盖性能提升、隐私保护和系统精简等方面,操作安全且无需第三方工具:1.禁用不必要的开机启动项操作路径:`Ctrl+S...

最好用音频剪辑的软件,使用方法?

QVE音频剪辑是一款简单实用的软件,功能丰富,可编辑全格式音频。支持音频转换、合并、淡入淡出、变速、音量调节等,无时长限制,用户可自由剪辑。剪辑后文件音质无损,支持多格式转换,便于存储与跨设备播放,满...

Vue2 开发总踩坑?这 8 个实战技巧让代码秒变丝滑

前端开发的小伙伴们,在和Vue2打交道的日子里,是不是总被各种奇奇怪怪的问题搞得头大?数据不响应、组件传值混乱、页面加载慢……别慌!今天带来8个超实用的Vue2实战技巧,每一个都能直击痛...

Motion for Vue:为Vue量身定制的强大动画库

在前端开发中,动画效果是提升用户体验的重要手段。Vue生态系统中虽然有许多动画库,但真正能做到高性能、易用且功能丰富的并不多。今天,我们要介绍的是MotionforVue(motion-v),...

CSS view():JavaScript 滚动动画的终结

前言CSSview()方法可能会标志着JavaScript在制作滚动动画方面的衰落。如何用5行CSS代码取代50多行繁琐的JavaScript,彻底改变网页动画每次和UI/U...

「大数据」 hive入门

前言最近会介入数据中台项目,所以会推出一系列的跟大数据相关的组件博客与文档。Hive这个大数据组件自从Hadoop诞生之日起,便作为Hadoop生态体系(HDFS、MR/YARN、HIVE、HBASE...

青铜时代的终结:对奖牌架构的反思

作者|AdamBellemare译者|王强策划|Tina要点运维和分析用例无法可靠地访问相关、完整和可信赖的数据。需要一种新的数据处理方法。虽然多跳架构已经存在了几十年,并且可以对...

解析IBM SQL-on-Hadoop的优化思路

对于BigSQL的优化,您需要注意以下六个方面:1.平衡的物理设计在进行集群的物理设计需要考虑数据节点的配置要一致,避免某个数据节点性能短板而影响整体性能。而对于管理节点,它虽然不保存业务数据,但作...

交易型数据湖 - Apache Iceberg、Apache Hudi和Delta Lake的比较

图片由作者提供简介构建数据湖最重要的决定之一是选择数据的存储格式,因为它可以大大影响系统的性能、可用性和兼容性。通过仔细考虑数据存储的格式,我们可以增强数据湖的功能和性能。有几种不同的选择,每一种都有...

深入解析全新 AWS S3 Tables:重塑数据湖仓架构

在AWSre:Invent2024大会中,AWS发布了AmazonS3Tables:一项专为可扩展存储和管理结构化数据而设计的解决方案,基于ApacheIceberg开放表格...

Apache DataFusion查询引擎简介

简介DataFusion是一个查询引擎,其本身不具备存储数据的能力。正因为不依赖底层存储的格式,使其成为了一个灵活可扩展的查询引擎。它原生支持了查询CSV,Parquet,Avro,Json等存储格式...

大数据Hadoop之——Flink Table API 和 SQL(单机Kafka)

一、TableAPI和FlinkSQL是什么TableAPI和SQL集成在同一套API中。这套API的核心概念是Table,用作查询的输入和输出,这套API都是批处理和...

比较前 3 名Schema管理工具

关注留言点赞,带你了解最流行的软件开发知识与最新科技行业趋势。在本文中,读者将了解三种顶级schema管理工具,如AWSGlue、ConfluentSchemaRegistry和Memph...

大数据技术之Flume

第1章概述1.1Flume定义Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集、聚合和传输的系统。Flume基于流式架构,灵活简单。1.2Flume的优点1.可以和...