Développement Web complet avec Java, Spring Boot et React
Jul 31, 2025 am 03:33 AMLa sélection de la pile de technologie Java Spring Boot React peut créer des applications Web complètes stables et efficaces, adaptées aux systèmes de petite et moyenne taille à de grandes entreprises. 2. Le backend utilise Spring Boot pour construire rapidement une API RESTful. Les composants principaux incluent Spring Web, Spring Data JPA, Spring Security, Lombok et Swagger. La séparation frontale est réalisée via @RestController renvoyant les données JSON. 3. Le front-end utilise React (avec Vite ou Create React App) pour développer une interface réactive, utilise Axios pour appeler l'API back-end, React Router gère le routage, combine Usestate ou Redux Toolkit pour la gestion de l'état et utilise CSS ou bootstrap de Tailwind pour embellir l'interface. 4. Pendant la phase de débogage conjointe, le problème du domaine croisé est résolu en configurant les COR ou en réagissant pour configurer le proxy proxy via Spring Boot, garantissant que les demandes frontales peuvent être correctement transmises vers le service back-end. 5. L'authentification adopte le schéma JWT. Une fois que l'utilisateur se connecte, le jeton est généré par Spring Security, et le frontal le stocke et porte l'en-tête d'autorisation pour compléter l'authentification dans les demandes suivantes. 6. La structure du projet recommandée est un répertoire indépendant séparé par les extrémités avant et arrière, ce qui facilite les responsabilités claires et le déploiement indépendant. 7. Déployer la solution facultative 1: Spring Boot est emballé sous forme de pot, et les fichiers statiques de construction React sont hébergés par NGINX et les demandes d'API proxy inverses; ou Solution 2: Mettez le produit React Build dans le répertoire statique de Spring Boot et est servi par le backend, adapté aux petits projets. La pile technologique est mature, a un écosystème parfait et est actif dans la communauté. La clé est de ma?triser la communication de repos, la gestion de l'état, l'authentification JWT et les mécanismes de déploiement NGINX, et de créer efficacement les applications au niveau de l'entreprise.
Si vous souhaitez créer une application Web complète avec une pile technologique moderne, Java Spring Boot React est une option très robuste et largement utilisée. Cette combinaison combine la stabilité du backend avec les fonctionnalités de niveau de l'entreprise (Java / Spring Boot) et l'expérience utilisateur réactive frontale (REACT), et convient au développement d'applications à partir de projets de petite et moyenne taille aux grandes entreprises.

Vous trouverez ci-dessous une route pratique de développement complet couvrant les étapes clés, les points techniques et les meilleures pratiques.
1. Backend: Spring Boot (Java)
Spring Boot simplifie le développement du backend Java, la configuration automatique, les serveurs embarqués et le développement de l'écosystème riche Make REST API Effectif.

Composants centraux:
- Web de printemps : créez une interface reposante
- Spring Data JPA : opérations de base de données (prend en charge MySQL, PostgreSQL, etc.)
- Spring Security : Certification and Authorization (JWT Common)
- Spring Boot Devtools : le déploiement à chaud améliore l'efficacité du développement
- Lombok : Réduisez le code du chauffeur (Getter / Setter / Constructeur)
- Swagger / OpenAPI : Génération de documentation API
Exemple: une API utilisateur simple
@RestController @RequestMapping ("/ api / utilisateurs") classe publique UserController { @Autowired Service d'utilisateur privé UserService; @Getmapping Liste publique <Sentraire> getAlUsers () { return userservice.findall (); } @Postmapping Utilisateur public CreateUser (@Requestbody User utilisateur) { return userService.save (utilisateur); } }
Connexion de la base de données (application.yml):
printemps: DataSource: URL: JDBC: mysql: // localhost: 3306 / mydb Nom d'utilisateur: racine Mot de passe: mot de passe JPA: hiberner: DDL-Auto: mise à jour Show-SQL: True
Astuce: utilisez
@RestController
pour retourner JSON, et les extrémités avant et arrière communiquent via JSON.
2. Front-end: React (Vite ou Create React App)
React fournit un développement d'interface utilisateur composé et améliore la vitesse de construction avec des cha?nes d'outils modernes (comme VITE).

Pile technologique couramment utilisée:
- React JSX : créez une interface utilisateur
- Axios : Envoyez la demande HTTP au backend Spring Boot
- Routeur React : routage frontal
- Gestion de l'état : UseState / UseReducer, des projets complexes peuvent être utilisés avec une bo?te à outils Redux ou une API de contexte
- Tailwind CSS / bootstrap : embellit rapidement l'interface
Exemple: Obtenez la liste d'utilisateurs
import {useEffecte, useState} de 'react'; importer axios à partir de ?Axios?; fonction userList () { const [utilisateurs, SetUsers] = UseState ([]); useEFFECT (() => { axios.get ('http: // localhost: 8080 / api / utilisateurs') .Then (Response => SetUsers (réponse.data)) .Catch (err => console.error (err)); }, []); Retour ( <div> <h2> utilisateurs </h2> <ul> {users.map (user => ( <li key = {user.id}> {user.name} - {user.email} </li> ))} </ul> </div> )); }
Remarque: Les problèmes de domaine croisé nécessitent que COR soit configuré dans Spring Boot ou pour utiliser un proxy.
3. Débogage conjoint frontal et déploiement
Résoudre le domaine croisé au stade de développement
Ajouter la classe d'application principale de démarrage Spring ou la classe de configuration:
@Configuration classe publique Corsconfig { @Haricot webmvcConfigurer publique CorsConfigurer () { renvoyer un nouveau webmvcConfigurer () { @Outrepasser public void addCorsMappings (Corsregistry Registry) { registry.addmapping ("/ api / **") .Allowedorigins ("http: // localhost: 3000") .AllowedMethods ("Get", "Post", "Put", "Delete"); } }; } }
Ou utilisez un proxy ( package.json
) dans React:
"Proxy": "http: // localhost: 8080"
De cette fa?on, la demande frontale /api/users
sera automatiquement procassée à http://localhost:8080/api/users
.
4. Authentification et sécurité (exemple JWT)
Processus typique:
- Connexion de l'utilisateur (post
/login
) - Mot de passe de vérification backend, générez un jeton JWT
- Jetons de stockage frontaux (localstorage ou cookies)
-
Authorization: Bearer <token>
Points clés de Spring Security JWT:
- Personnaliser
UserDetailsService
- Générer et vérifier les jetons à l'aide de la classe d'outils
JwtUtil
- Ajouter
JwtRequestFilter
pour intercepter les demandes et analyser les jetons
Exemple de connexion React:
const handlelogine = () => { axios.post ('/ api / ligin', {nom d'utilisateur, mot de passe}) .Then (res => { LocalStorage.SetItem (?Token?, res.data.token); // Jump ou mise à jour de statut}); };
5. Suggestions de structure du projet (séparation avant et arrière)
Structure du répertoire de projet recommandé:
myApp / ├── Backend / <- Spring Boot Project│ ├fique │ └fique ├fiques frontend / <- React Project│ ├fique │ ├fiques │ └fiques └fiques
Avantages: Responsabilités distinctes, peuvent être déployées indépendamment et clairement le travail d'équipe.
6. Plan de déploiement
Solution 1: déploiement de séparation frontale et back-end
- Spring Boot est transformé en package de pot et exécuté sur le serveur (comme un h?te cloud):
java -jar app.jar
- React Build Files statiques:
npm run build
- Utilisez Nginx pour héberger les demandes de l'API proxy avant et inversé au backend
Fragment de configuration Nginx:
serveur { écoutez 80; root / var / www / myapp-frontend; index index.html; emplacement / { try_files $ uri $ uri / /index.html; } Emplacement / API / { proxy_pass http: // localhost: 8080; proxy_set_header host $ host; } }
Solution 2: intégrer frontal (facultatif)
Mettez dist
construit par React dans src/main/resources/static
de Spring Boot, et le service est fourni par le backend. Convient pour les petits projets.
Résumer
Niveau | technologie |
---|---|
l'extrémité avant | React Axios Router Tailwind |
extrémité arrière | Spring Boot Data Spring JPA Spring Security |
base de données | Mysql / postgresql |
Sécurité | JWT Spring Security |
déployer | Fichiers statiques du processus Java Nginx Java |
Cette pile technologique est mature, riche en documents et active dans la communauté, et est très adapté à la création d'applications complètes au niveau de l'entreprise. La clé est de comprendre le mécanisme de communication (REST JSON), la gestion de l'état, les processus d'authentification et les méthodes de déploiement qui sont séparées des avant et de l'arrière.
Fondamentalement, tout est, pas compliqué, mais il est facile d'ignorer les détails.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Maven est un outil standard pour la gestion et la construction de projet Java. La réponse réside dans le fait qu'il utilise pom.xml pour normaliser la structure du projet, la gestion des dépendances, l'automatisation du cycle de vie de la construction et les extensions de plug-in; 1. Utilisez pom.xml pour définir GroupID, Arfactive, version et dépendances; 2. Commandes Master Core telles que MvnClean, compiler, tester, package, installer et déploier; 3. Utiliser la fonction de dépendance et les exclusions pour gérer les versions et les conflits de dépendance; 4. Organisez de grandes applications via la structure du projet multi-modules et sont gérées uniformément par le POM parent; 5

Setupamaven / gradleprojectwithjax-rsDependces likejersey; 2.CreateArestResourceUsingannotationsSuchas @ pathand @ get; 3.ConfigureTheApplicationViaApplicationsUbclassorweb.xml; 4.AddjacksonforjsonBindingByCludingJersey-Media-Json-Jackson; 5.DeploEp

Tout d'abord, utilisez JavaScript pour obtenir les préférences du système utilisateur et les paramètres de thème stockés localement et initialiser le thème de la page; 1. La structure HTML contient un bouton pour déclencher la commutation du sujet; 2. CSS utilise: Root pour définir des variables de thème brillantes, la classe de mode. Dark définit les variables de thème sombres et applique ces variables via var (); 3. JavaScript détecte préfère-Color-Scheme et lit LocalStorage pour déterminer le thème initial; 4. Communiquez la classe en mode noir sur l'élément HTML lorsque vous cliquez sur le bouton et enregistre l'état actuel vers LocalStorage; 5. Tous les changements de couleur sont accompagnés d'une animation de transition de 0,3 seconde pour améliorer l'utilisateur

Comprendre les composants centraux de la blockchain, y compris les blocs, les hachages, les structures de cha?ne, les mécanismes de consensus et l'immuabilité; 2. Créez une classe de bloc qui contient des données, des horodatages, un hachage et nonce précédent, et implémentez le calcul du hachage SHA-256 et la preuve de l'exploitation de travail; 3. Construisez une classe de blockchain pour gérer les listes de blocs, initialiser le bloc Genesis, ajouter de nouveaux blocs et vérifier l'intégrité de la cha?ne; 4. écrivez la blockchain de test principal, ajoutez des blocs de données de transaction à son tour et à l'état de la cha?ne de sortie; 5. Les fonctions d'amélioration facultatives incluent la prise en charge des transactions, le réseau P2P, la signature numérique, la restapi et la persistance des données; 6. Vous pouvez utiliser des bibliothèques Java Blockchain telles que Hyperledgerfabric, Web3J ou Corda pour l'ouverture au niveau de la production

@Property Decorator est utilisé pour convertir les méthodes en propriétés pour implémenter le contr?le de lecture, de réglage et de suppression des propriétés. 1. Utilisation de base: définissez des attributs en lecture seule via @Property, tels que la zone calculée en fonction du rayon et accédé directement; 2. Utilisation avancée: utilisez @ name.setter et @ name.deleter pour implémenter les opérations de vérification et de suppression de l'attribut d'attribut; 3. Application pratique: effectuer la vérification des données dans les setters, tels que BankAccount pour s'assurer que le solde n'est pas négatif; 4. Spécification de dénomination: les variables internes sont préfixées, les noms de méthode de propriété sont cohérents avec les attributs et le contr?le d'accès unifié est utilisé pour améliorer la sécurité et la maintenabilité du code.

Pour générer des valeurs de hachage à l'aide de Java, il peut être implémenté via la classe MessagediGest. 1. Obtenez une instance de l'algorithme spécifié, tel que MD5 ou SHA-256; 2. Appelez la méthode .update () à transmettre les données à chiffrer; 3. Appelez la méthode .digest () pour obtenir un tableau d'octets de hachat; 4. Convertir le tableau d'octets en une cha?ne hexadécimale pour la lecture; Pour les entrées telles que les fichiers gros, lisez dans des morceaux et appelez .Update () plusieurs fois; Il est recommandé d'utiliser SHA-256 au lieu de MD5 ou SHA-1 pour assurer la sécurité.

Oui, un menu déroulant CSS commun peut être implémenté via Pure HTML et CSS sans JavaScript. 1. Utilisez des ul imbriqués et Li pour construire une structure de menu; 2. Utilisez le: Hover Pseudo-Class pour contr?ler l'affichage et la cachette du contenu déroulant; 3. Position définie: relative pour le parent li, et le sous-menu est positionné en utilisant la position: absolue; 4. Le sous-menu défaut par défaut: Aucun, qui devient affichage: Block lorsqu'il a survolé; 5. Le tir-down à plusieurs niveaux peut être réalisé grace à la nidification, combinée à la transition, et à l'ajout d'animations fondues, et adaptées aux terminaux mobiles avec des requêtes multimédias. La solution entière est simple et ne nécessite pas de prise en charge JavaScript, qui convient au grand

Utilisez dateTime.Strptime () pour convertir les cha?nes de date en objet DateTime. 1. Utilisation de base: Parse "2023-10-05" comme objet DateTime via "% y-% m-% d"; 2. prend en charge plusieurs formats tels que "% m /% d /% y" pour analyser les dates américaines, "% d /% m /% y" pour analyser les dates britanniques, "% b% d,% y% i:% m% p" pour analyser le temps avec AM / PM; 3. Utilisez dateUtil.parser.parse () pour déduire automatiquement les formats inconnus; 4. Utiliser .d
