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

Table des matières
1. Backend: Spring Boot (Java)
Composants centraux:
Exemple: une API utilisateur simple
Connexion de la base de données (application.yml):
2. Front-end: React (Vite ou Create React App)
Pile technologique couramment utilisée:
Exemple: Obtenez la liste d'utilisateurs
3. Débogage conjoint frontal et déploiement
Résoudre le domaine croisé au stade de développement
4. Authentification et sécurité (exemple JWT)
Points clés de Spring Security JWT:
5. Suggestions de structure du projet (séparation avant et arrière)
6. Plan de déploiement
Solution 1: déploiement de séparation frontale et back-end
Solution 2: intégrer frontal (facultatif)
Résumer
Maison Java javaDidacticiel Développement Web complet avec Java, Spring Boot et React

Développement Web complet avec Java, Spring Boot et React

Jul 31, 2025 am 03:33 AM
java

La 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.

Développement Web complet avec Java, Spring Boot et React

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.

Développement Web complet avec Java, Spring Boot et React

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.

Développement Web complet avec Java, Spring Boot et React

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&#39;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).

Développement Web complet avec Java, Spring Boot et React

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 &#39;react&#39;;
importer axios à partir de ?Axios?;

fonction userList () {
  const [utilisateurs, SetUsers] = UseState ([]);

  useEFFECT (() => {
    axios.get (&#39;http: // localhost: 8080 / api / utilisateurs&#39;)
      .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:

  1. Connexion de l'utilisateur (post /login )
  2. Mot de passe de vérification backend, générez un jeton JWT
  3. Jetons de stockage frontaux (localstorage ou cookies)
  4. 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 (&#39;/ api / ligin&#39;, {nom d&#39;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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefa?on, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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?!

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Un guide du développeur à Maven pour la gestion de projet Java Un guide du développeur à Maven pour la gestion de projet Java Jul 30, 2025 am 02:41 AM

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

Construire des API RESTful à Java avec Jakarta EE Construire des API RESTful à Java avec Jakarta EE Jul 30, 2025 am 03:05 AM

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

Exemple de bascule du mode sombre CSS Exemple de bascule du mode sombre CSS Jul 30, 2025 am 05:28 AM

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

Développer une application blockchain en Java Développer une application blockchain en Java Jul 30, 2025 am 12:43 AM

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

Exemple de décorateur de propriété Python Exemple de décorateur de propriété Python Jul 30, 2025 am 02:17 AM

@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.

Comment utiliser Java MessagediGest pour le hachage (MD5, SHA-256)? Comment utiliser Java MessagediGest pour le hachage (MD5, SHA-256)? Jul 30, 2025 am 02:58 AM

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é.

Exemple de menu déroulant CSS Exemple de menu déroulant CSS Jul 30, 2025 am 05:36 AM

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

Exemple de cha?ne de date d'analyse Python Exemple de cha?ne de date d'analyse Python Jul 30, 2025 am 03:32 AM

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

See all articles