Vue+spring boot前后端分離項目搭建---小白入門

首先,介紹一下軟件準備工作

1.vscode

2.maven

3.vue搭建:node.js+yarn+vite

一.后端搭建

打開vscode,建立一個springboot項目,參考鏈接:sping boot項目搭建

建立一個項目,目錄結構如下:

helloController.java

package example.example1;import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@CrossOrigin // 允許所有跨域請求(僅用于開發)
public class HelloController {@GetMapping("/hello")public String hello() {return "你好,Spring Boot! 當前時間: " + new java.util.Date();}
}

訪問瀏覽器:http://localhost:8080/hello

運行界面如下:

二.前端搭建

打開一個文件夾,建立一個vue項目,參考鏈接:vue項目創建

項目目錄結構如下:

public/index.html如下:

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>極簡Vue+SpringBoot</title>
</head>
<body><div id="app"></div>
</body>
</html>

Components/App.vue如下:

<template><div><h1>Vite + Spring Boot 測試</h1><button @click="fetchData">獲取后端數據</button><div v-if="message">{{ message }}</div><div v-if="error" style="color: red">{{ error }}</div></div>
</template><script>
export default {data() {return {message: '',error: ''}},methods: {async fetchData() {try {const response = await fetch('/api/hello') // 注意 /api 前綴this.message = await response.text()this.error = ''} catch (err) {this.error = '請求失敗: ' + err.message}}}
}
</script>

main.js如下:

import './assets/main.css'import { createApp } from 'vue'
import App from './App.vue'createApp(App).mount('#app')

vite.config.js如下

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'export default defineConfig({plugins: [vue()],server: {proxy: {'/api': {target: 'http://localhost:8080', // 你的 Spring Boot 后端地址changeOrigin: true,rewrite: (path) => path.replace(/^\/api/, '') // 去掉 /api 前綴}}}
})

運行界面如下:

點擊獲取后臺數據:

這樣就完成了前后端分離啦。

注意:要先運行后端再運行前端。

關鍵步驟總結:

一.后端搭建

1.首先,搭建后端,在servlet里面設置@CrossOrigin

2.用@GetMapping()定義訪問映射

編寫@GetMapping("/hello")定義訪問的映射

二.前端搭建:

1.用fetch方法來獲取數據

fetch?是瀏覽器內置的一個用于發送網絡請求(如 HTTP 請求)的函數。它可以用來向服務器獲取數據或提交數據,常用于前后端分離項目中前端與后端的通信。

const response = await fetch('/api/hello')

這行代碼的意思是:向?/api/hello?這個接口發送一個 GET 請求,等待服務器返回響應,然后把響應結果賦值給?response?變量。

2.其中,api接口是自己在vite.config.js中定義的

?proxy: {
? ? ? '/api': {
? ? ? ? target: 'http://localhost:8080', // 你的 Spring Boot 后端地址
? ? ? ? changeOrigin: true,
? ? ? ? ?rewrite: (path) => path.replace(/^\/api/, '') // 去掉 /api 前綴
? ? ? }
? ? }

這樣訪問也就是訪問了http://localhost:8080/hello

當然,你也可以選擇把接口直接定義為hello,這樣地址就不用重寫了,就可以寫成,

?proxy: {
? ? ? '/hello': {
? ? ? ? target: 'http://localhost:8080', // 你的 Spring Boot 后端地址
? ? ? ? changeOrigin: true
? ? ? }
? ? }

不過,這樣?const response = await fetch('/api/hello') 也要改成?const response = await fetch('/hello')?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/88341.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/88341.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/88341.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

“蘇超”拉動周末消費,抖音生活服務:比賽城市迎來普遍消費上漲

“蘇超”爆火&#xff0c;有力拉升了緊隨賽程的周末消費。抖音生活服務數據顯示&#xff0c;剛剛過去的周末&#xff08;6月21日至22日&#xff09;&#xff0c;江蘇商圈休閑運動團購訂單消費環比增長225%&#xff0c;到店消費金額環比增長181%。雖然幾個比賽城市周末天氣欠佳&…

使用python開發一個exe版本的計算器項目練習

最近在練習python開發軟件&#xff0c;就開發了一個 客戶端版的 計算器。先給大家看一下 做出來的樣子 python版本&#xff1a;3.8 以上 主要是 使用 import tkinter as tk 這個庫來實現圖形界面開發 代碼還是比較簡單的&#xff1a; # 創建主窗口 root tk.Tk() root.title…

uniapp開發小程序,導出文件打開并保存,實現過程downloadFile下載,openDocument打開

uniapp開發小程序&#xff0c;導出文件打開并保存 實現思路 1、調用請求獲取到后端接口返回的下載文件的url路徑 &#xff08;注意必須是https的路徑&#xff0c;域名需要配置在微信小程序后臺的合法域名里面&#xff09; 2、使用 uni.downloadFile 方法 &#xff08;下載文件…

vue2中前端實現圖片裁剪上傳到服務器

在 Vue 2 中實現圖片裁剪并上傳到服務器&#xff0c;你可以結合使用 Cropper.js 來進行圖片裁剪&#xff0c;并通過 Axios 或者其他 HTTP 客戶端庫將裁剪后的圖片上傳至服務器。以下是一個基本的實現步驟和示例代碼&#xff1a; 步驟 安裝依賴&#xff1a;你需要安裝 cropperj…

C# 網絡編程-關于HttpWebRequest使用方式(二)

項目開發用到數據請求時候&#xff0c;會用的到HttpWebRequest的請求方式&#xff0c;主要涵蓋GET、POST、PUT、DELETE等方法 一、HttpWebRequest簡介 HttpWebRequest是.NET Framework中用于發送HTTP請求的核心類&#xff0c;適用于構建HTTP客戶端。它支持GET、POST、PUT、DE…

git變更記錄

目錄 wvp-ui -new Dji 10.60.2.175:8000上的編譯 個人拉分支 目前約定2025-06-25 wvp-ui -new branch new BASE_URL /new/ ci-cd : wvp-newui Config [Jenkins] 禁 用 10.30.2.8 ssh 10.30.2.8 /home/dualven/wvp-server/deployNewUi.sh Dji 主分支的構建&#xf…

前端如何禁止用戶復制?

禁用右鍵菜單 document.addEventListener(contextmenu, function(e) {e.preventDefault(); });禁用快捷鍵&#xff08;CtrlC/X/A等&#xff09; document.addEventListener(keydown, function(e) {if (e.ctrlKey && [c, x, v, a].includes(e.key.toLowerCase())) {e.…

阿里云無影:開啟云端辦公娛樂新時代

阿里云無影云電腦&#xff1a;打破傳統束縛&#xff0c;暢享云端自由 在數字化浪潮洶涌澎湃的當下&#xff0c;云計算技術持續革新&#xff0c;為我們的工作與生活帶來前所未有的變革。阿里云作為云計算領域的佼佼者&#xff0c;推出的無影云電腦無疑是一顆璀璨的明星&#xf…

Windows 和 macOS 串口調試軟件

在 Windows 和 macOS 上&#xff0c;你可以使用以下串口調試軟件來查看開發板的打印信息。以下是常見且好用的工具推薦&#xff1a; Windows 推薦工具 PuTTY 免費、輕量級&#xff0c;支持串口&#xff08;COM&#xff09;和 SSH/Telnet下載地址&#xff1a;https://www.putty.…

Redis 的作用及詳細分析

網上查詢總結了一下Redis相關的信息 記錄一下 &#xff0c;有問題的地方&#xff0c;望多加指正&#xff0c;我們共同學習。 什么是Redis Redis是一款內存高速緩存數據庫。Redis全稱為&#xff1a;Remote Dictionary Server &#xff08;遠程數據服務&#xff09;&#xff0c;…

【邊緣計算】引論基礎

&#xff08;1&#xff09;在不遠的未來&#xff0c;將有超過50%的數據需要在網絡邊緣側分析、處理與儲存。智能互聯的網絡邊緣側將會面臨如下挑戰&#xff1a; 聯接設備的海量與異構 隨著聯接設備數量的劇增&#xff0c;網絡運維管理、靈活擴展和可靠性保障都面臨著巨大挑戰。…

SpringBoot中4種登錄驗證碼實現方案

文章目錄 詳解方案一&#xff1a;基于kaptcha的圖形驗證碼實現步驟 方案二&#xff1a;基于短信驗證碼實現步驟 方案三&#xff1a;基于Spring Mail的郵箱驗證碼實現步驟 方案四&#xff1a;基于AJ-Captcha的滑動拼圖驗證碼實現步驟 總結 詳解 在Web應用中&#xff0c;驗證碼是…

基于版本控制+WORM的OSS數據保護:防勒索攻擊與法規遵從實踐

1. 數據保護的核心挑戰與解決方案架構 &#xff08;1&#xff09;現代數據保護的三大矛盾 勒索軟件進化 vs 傳統備份脆弱性&#xff1a;攻擊者已掌握備份系統刪除技術&#xff08;如vssadmin delete shadows&#xff09;法規保留要求&#xff08;GDPR第17條&#xff09;vs 技…

混合架構入門:如何選組合恰當的云 + 私有節點?

如果你最近剛開始搭建業務系統&#xff0c;或者準備從傳統IDC遷移到云上&#xff0c;你很可能已經被“混合云”、“多云”、“私有部署”這些概念繞得頭暈。而今天這篇文章&#xff0c;不會再羅列概念或抄定義&#xff0c;而是站在一個運維工程師、架構規劃者的角度&#xff0c…

CDN+OSS邊緣加速實踐:動態壓縮+智能路由降低30%視頻流量成本(含帶寬峰值監控與告警配置)

1 背景與挑戰分析 &#xff08;1&#xff09;流量成本結構剖析 視頻業務帶寬成本公式&#xff1a; C_{total} \sum_{i1}^{n} (P_{peak_i} T_i R_{region}) C_{req} N_{req}其中 P p e a k P_{peak} Ppeak? 為區域峰值帶寬&#xff08;GB/s&#xff09;&#xff0c; T …

Flink內存配置

通過本文可以解決以下3個問題。 了解flink內存和配置項相關概念。清楚UI中TM和JM各內存組件實際內存值的計算規則。根據實際情況對內存進行調整。 1. Flink進程內存 TM和JM二者均為JVM進程&#xff08;JVM通常分成堆內和堆外兩部分&#xff09;。TM和JM的內存定義為進程總內…

最新發布 | “龍躍”(MindLoongGPT)大模型正式發布!龍躍而起,推動中國方案走向全球智能體前沿

在人工智能快速演進的今天&#xff0c;生成式大模型正成為推動技術變革的核心引擎。繼語言、圖像、視頻等領域實現突破之后&#xff0c;下一階段的技術焦點&#xff0c;正加速向“具身智能”遷移。具身智能強調智能體對物理世界的感知、理解與互動能力&#xff0c;是實現通用人…

【系統分析師】2019年真題:論文及解題思路

文章目錄 試題一 論系統需求分析方法試題二 論系統自動化測試及其應用試題三 論處理流程設計方法及應用試題四 論企業智能運維技術與方法 試題一 論系統需求分析方法 系統需求分析是開發人員經過調研和分析&#xff0c;準確理解用戶和項目 的功能、性能、可靠 性等要求&#x…

在PHP環境下使用SQL Server的方法

當您處在PHP環境并想使用SQL Server作為數據庫服務器時&#xff0c;您需要將SQL Server連接到PHP。這涉及到一些步驟&#xff0c;我們會逐一說明并提供示例以指導你。 1.安裝SQL Server驅動&#xff1a; 首先&#xff0c;您需要在PHP環境中安裝對應的SQL Server驅動&#xff0…

RISC-V h拓展

https://tinylab.org/riscv-kvm-virt-mode-switch/ https://tinylab.org/riscv-kvm-virt-trap/ 特權模式 指令集中約定用虛擬化模式 V (virtualization mode) 來標記當前是否是在 Guest 系統中運行。V1 表示當前確實運行在 Guest 系統中&#xff0c;V0 則表示不運行在 Guest 中…