亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
1. 後端:Spring Boot(Java)
核心組件:
示例:一個(gè)簡單的用戶API
數(shù)據(jù)庫連接(application.yml):
2. 前端:React( Vite 或Create React App)
常用技術(shù)棧:
示例:獲取用戶列表
3. 前後端聯(lián)調(diào)與部署
開發(fā)階段解決跨域
4. 認(rèn)證與安全(JWT 示例)
Spring Security JWT 關(guān)鍵點(diǎn):
5. 項(xiàng)目結(jié)構(gòu)建議(前後端分離)
6. 部署方案
方案一:前後端分離部署
方案二:內(nèi)嵌前端(可選)
總結(jié)
首頁 Java java教程 使用Java,Spring Boot和React的全堆棧Web開發(fā)

使用Java,Spring Boot和React的全堆棧Web開發(fā)

Jul 31, 2025 am 03:33 AM
java

選擇Java Spring Boot React技術(shù)??蓸?gòu)建穩(wěn)定高效的全棧Web應(yīng)用,適合從中小型到大型企業(yè)級(jí)系統(tǒng)。 2. 後端使用Spring Boot快速搭建RESTful API,核心組件包括Spring Web、Spring Data JPA、Spring Security、Lombok和Swagger,通過@RestController返回JSON數(shù)據(jù)實(shí)現(xiàn)前後端分離。 3. 前端採用React(配合Vite或Create React App)開發(fā)響應(yīng)式界面,使用Axios調(diào)用後端API,React Router管理路由,結(jié)合useState或Redux Toolkit進(jìn)行狀態(tài)管理,並用Tailwind CSS或Bootstrap美化界面。 4. 聯(lián)調(diào)階段通過Spring Boot配置CORS或React設(shè)置proxy代理解決跨域問題,確保前端請求能正確轉(zhuǎn)發(fā)至後端服務(wù)。 5. 認(rèn)證採用JWT方案,用戶登錄後由Spring Security生成Token,前端存儲(chǔ)並在後續(xù)請求中攜帶Authorization頭完成身份驗(yàn)證。 6. 推薦項(xiàng)目結(jié)構(gòu)為前後端分離的獨(dú)立目錄,便於職責(zé)清晰與獨(dú)立部署。 7. 部署可選方案一:Spring Boot打包為jar運(yùn)行,React構(gòu)建靜態(tài)文件由Nginx託管並反向代理API請求;或方案二:將React構(gòu)建產(chǎn)物放入Spring Boot的static目錄由後端統(tǒng)一服務(wù),適用於小型項(xiàng)目。該技術(shù)棧成熟、生態(tài)完善、社區(qū)活躍,關(guān)鍵在於掌握REST通信、狀態(tài)管理、JWT認(rèn)證和Nginx部署機(jī)制,即可高效構(gòu)建企業(yè)級(jí)應(yīng)用。

Full-Stack Web Development with Java, Spring Boot, and React

如果你想用現(xiàn)代技術(shù)棧構(gòu)建一個(gè)完整的Web 應(yīng)用, Java Spring Boot React是一個(gè)非常穩(wěn)健且廣泛使用的選擇。這個(gè)組合結(jié)合了後端的穩(wěn)定性與企業(yè)級(jí)特性(Java/Spring Boot)和前端的響應(yīng)式用戶體驗(yàn)(React),適合開發(fā)從中小型項(xiàng)目到大型企業(yè)系統(tǒng)的各種應(yīng)用。

Full-Stack Web Development with Java, Spring Boot, and React

下面是一個(gè)實(shí)用的全棧開發(fā)路線,涵蓋關(guān)鍵步驟、技術(shù)要點(diǎn)和最佳實(shí)踐。


1. 後端:Spring Boot(Java)

Spring Boot 簡化了Java 後端開發(fā),自動(dòng)配置、內(nèi)嵌服務(wù)器、豐富的生態(tài)讓REST API 開髮變得高效。

Full-Stack Web Development with Java, Spring Boot, and React

核心組件:

  • Spring Web :構(gòu)建RESTful 接口
  • Spring Data JPA :數(shù)據(jù)庫操作(支持MySQL、PostgreSQL 等)
  • Spring Security :認(rèn)證與授權(quán)(JWT 常見)
  • Spring Boot DevTools :熱部署提升開發(fā)效率
  • Lombok :減少樣板代碼(getter/setter/constructor)
  • Swagger/OpenAPI :API 文檔生成

示例:一個(gè)簡單的用戶API

 @RestController
@RequestMapping("/api/users")
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping
    public List<User> getAllUsers() {
        return userService.findAll();
    }

    @PostMapping
    public User createUser(@RequestBody User user) {
        return userService.save(user);
    }
}

數(shù)據(jù)庫連接(application.yml):

 spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mydb
    username: root
    password: password
  jpa:
    hibernate:
      ddl-auto: update
    show-sql: true

提示:使用@RestController返回JSON,前後端通過JSON 通信。


2. 前端:React( Vite 或Create React App)

React 提供組件化UI 開發(fā),配合現(xiàn)代工具鏈(如Vite)提升構(gòu)建速度。

Full-Stack Web Development with Java, Spring Boot, and React

常用技術(shù)棧:

  • React JSX :構(gòu)建用戶界面
  • Axios :發(fā)送HTTP 請求到Spring Boot 後端
  • React Router :前端路由
  • State Management :useState/useReducer,複雜項(xiàng)目可用Redux Toolkit 或Context API
  • Tailwind CSS / Bootstrap :快速美化界面

示例:獲取用戶列表

import { useEffect, useState } from &#39;react&#39;;
import axios from &#39;axios&#39;;

function UserList() {
  const [users, setUsers] = useState([]);

  useEffect(() => {
    axios.get(&#39;http://localhost:8080/api/users&#39;)
      .then(response => setUsers(response.data))
      .catch(err => console.error(err));
  }, []);

  return (
    <div>
      <h2>Users</h2>
      <ul>
        {users.map(user => (
          <li key={user.id}>{user.name} - {user.email}</li>
        ))}
      </ul>
    </div>
  );
}

注意:跨域問題需在Spring Boot 中配置CORS,或使用代理。


3. 前後端聯(lián)調(diào)與部署

開發(fā)階段解決跨域

在Spring Boot 主應(yīng)用類或配置類中添加:

 @Configuration
public class CorsConfig {
    @Bean
    public WebMvcConfigurer corsConfigurer() {
        return new WebMvcConfigurer() {
            @Override
            public void addCorsMappings(CorsRegistry registry) {
                registry.addMapping("/api/**")
                        .allowedOrigins("http://localhost:3000")
                        .allowedMethods("GET", "POST", "PUT", "DELETE");
            }
        };
    }
}

或者在React 中使用代理( package.json ):

 "proxy": "http://localhost:8080"

這樣前端請求/api/users會(huì)自動(dòng)代理到http://localhost:8080/api/users


4. 認(rèn)證與安全(JWT 示例)

典型流程:

  1. 用戶登錄(POST /login
  2. 後端驗(yàn)證密碼,生成JWT Token
  3. 前端存儲(chǔ)Token(localStorage 或cookies)
  4. 後續(xù)請求攜帶Authorization: Bearer <token>

Spring Security JWT 關(guān)鍵點(diǎn):

  • 自定義UserDetailsService
  • 使用JwtUtil工具類生成和驗(yàn)證Token
  • 添加JwtRequestFilter攔截請求並解析Token

React 登錄示例:

 const handleLogin = () => {
  axios.post(&#39;/api/login&#39;, { username, password })
    .then(res => {
      localStorage.setItem(&#39;token&#39;, res.data.token);
      // 跳轉(zhuǎn)或更新狀態(tài)});
};

5. 項(xiàng)目結(jié)構(gòu)建議(前後端分離)

推薦項(xiàng)目目錄結(jié)構(gòu):

 myapp/
├── backend/ <- Spring Boot 項(xiàng)目│ ├── src/main/java
│ └── pom.xml
├── frontend/ <- React 項(xiàng)目│ ├── src/
│ ├── public/
│ └── package.json
└── README.md

優(yōu)點(diǎn):職責(zé)分離,可獨(dú)立部署,團(tuán)隊(duì)協(xié)作清晰。


6. 部署方案

方案一:前後端分離部署

  • Spring Boot 打成jar 包,運(yùn)行在服務(wù)器(如雲(yún)主機(jī)): java -jar app.jar
  • React 構(gòu)建靜態(tài)文件: npm run build build
  • 使用Nginx 託管前端,並反向代理API 請求到後端

Nginx 配置片段:

 server {
    listen 80;
    root /var/www/myapp-frontend;
    index index.html;

    location / {
        try_files $uri $uri/ /index.html;
    }

    location /api/ {
        proxy_pass http://localhost:8080;
        proxy_set_header Host $host;
    }
}

方案二:內(nèi)嵌前端(可選)

將React 構(gòu)建後的dist文件放入Spring Boot 的src/main/resources/static ,由後端統(tǒng)一提供服務(wù)。適合小型項(xiàng)目。


總結(jié)

層級(jí) 技術(shù)
前端 React Axios Router Tailwind
後端 Spring Boot Spring Data JPA Spring Security
資料庫 MySQL / PostgreSQL
安全 JWT Spring Security
部署 Nginx Java 進(jìn)程靜態(tài)文件

這套技術(shù)棧成熟、文檔豐富、社區(qū)活躍,非常適合構(gòu)建企業(yè)級(jí)全棧應(yīng)用。關(guān)鍵是理解前後端分離的通信機(jī)制(REST JSON)、狀態(tài)管理、認(rèn)證流程和部署方式。

基本上就這些,不復(fù)雜但容易忽略細(xì)節(jié)。

以上是使用Java,Spring Boot和React的全堆棧Web開發(fā)的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
VSCODE設(shè)置。 JSON位置 VSCODE設(shè)置。 JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位於用戶級(jí)或工作區(qū)級(jí)路徑,用於自定義VSCode設(shè)置。 1.用戶級(jí)路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級(jí)路徑:項(xiàng)目根目錄下的.vscode/settings

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動(dòng)提交模式,再執(zhí)行多個(gè)操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個(gè)SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時(shí)應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點(diǎn)實(shí)現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

Python Itertools組合示例 Python Itertools組合示例 Jul 31, 2025 am 09:53 AM

itertools.combinations用於生成從可迭代對像中選取指定數(shù)量元素的所有不重複組合(順序無關(guān)),其用法包括:1.從列表中選2個(gè)元素組合,如('A','B')、('A','C')等,避免重複順序;2.對字符串取3個(gè)字符組合,如"abc"、"abd",適用於子序列生成;3.求兩數(shù)之和等於目標(biāo)值的組合,如1 5=6,簡化雙重循環(huán)邏輯;組合與排列的區(qū)別在於順序是否重要,combinations視AB與BA為相同,而permutations視為不同;

Python Pytest夾具示例 Python Pytest夾具示例 Jul 31, 2025 am 09:35 AM

fixture是用於為測試提供預(yù)設(shè)環(huán)境或數(shù)據(jù)的函數(shù),1.使用@pytest.fixture裝飾器定義fixture;2.在測試函數(shù)中以參數(shù)形式註入fixture;3.yield之前執(zhí)行setup,之後執(zhí)行teardown;4.通過scope參數(shù)控製作用域,如function、module等;5.將共用fixture放在conftest.py中實(shí)現(xiàn)跨文件共享,從而提升測試的可維護(hù)性和復(fù)用性。

故障排除常見的java`ofmemoryError`場景'' 故障排除常見的java`ofmemoryError`場景'' Jul 31, 2025 am 09:07 AM

java.lang.OutOfMemoryError:Javaheapspace表示堆內(nèi)存不足,需檢查大對象處理、內(nèi)存洩漏及堆設(shè)置,通過堆轉(zhuǎn)儲(chǔ)分析工具定位並優(yōu)化代碼;2.Metaspace錯(cuò)誤因類元數(shù)據(jù)過多,常見於動(dòng)態(tài)類生成或熱部署,應(yīng)限制MaxMetaspaceSize並優(yōu)化類加載;3.Unabletocreatenewnativethread因係統(tǒng)線程資源耗盡,需檢查線程數(shù)限制、使用線程池、調(diào)整棧大?。?.GCoverheadlimitexceeded指GC頻繁但回收少,應(yīng)分析GC日誌,優(yōu)化

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當(dāng)前日期時(shí)間;3.使用of()方法創(chuàng)建特定日期時(shí)間;4.利用plus/minus方法不可變地增減時(shí)間;5.使用ZonedDateTime和ZoneId處理時(shí)區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時(shí)通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

了解Java虛擬機(jī)(JVM)內(nèi)部 了解Java虛擬機(jī)(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

See all articles