


Description du problème: Pendant le processus de développement de l'utilisation du framework séparé Ruoyi, le front-end utilise la demande post-demande pour transmettre des données à l'arrière-end, mais le back-end reçoit une valeur nulle.
Code frontal:
// Modifiez la fonction d'exportation d'état de commande UpdateOrderstatus (id, status) { const data = { identifiant, statut } Return Request ({ URL: "/ Business / OrderInfo / UpdateState", Méthode: "Post", Données: données }) }
Capture d'écran des données de demande frontale: (La capture d'écran des données de demande frontale doit être incluse ici)
Code backend (code d'origine):
@APIOperation ("Statut de commande de mode de gestion des commandes") @APIIMPLICITPARAMS ({ @APIIMPLICTPARAM (name = "id", valeur = "ID de clé primaire", obligatoire = true, dataType = "Integer"), @APIIMPLICtParam (name = "Status", Value = "Status 0 se termine par 1", requis = true, dataType = "Integer") }) @Postmapping ("/ updateState") public ajaxresult updateState (ID entier, statut entier) { System.out.println ("Modifier le numéro de commande:" id "\ n"); System.out.println ("Modifier l'état de l'ordre:" Statut "\ n"); // ... (autre code) }
Capture d'écran des résultats de l'impression backend: (Cela devrait inclure des captures d'écran des résultats d'impression backend, montrant l'ID et le statut NULL)
Analyse des problèmes: le backend utilise Integer id, Integer status
pour recevoir des paramètres. Lors du traitement des demandes de poste, Spring Boot ne peut pas analyser correctement les données JSON dans le corps de la demande à ces paramètres par défaut.
Solution: modifiez le code backend et liez les données JSON dans le corps de la demande à un objet en utilisant l'annotation @RequestBody
.
Code backend modifié:
@APIOperation ("Statut de commande de mode de gestion des commandes") @Postmapping ("/ updateState") public ajaxresult updateState (@Requestbody Orderstatusdto orderstatusdto) { System.out.println ("Modifier le numéro de commande:" Orderstatusdto.getID () "\ n"); System.out.println ("Modifier l'état de l'ordre:" Orderstatusdto.getStatus () "\ n"); if (orderstatusdto.getId () == null) { return ajaxResult.Error ("Entrez ID de clé primaire"); } if (orderstatusdto.getstatus () == null) { return ajaxresult.error ("statut d'entrée"); } BorderInfo borderInfo = new borderInfo (); borderInfo.setid (orderstatusdto.getId ()); borderInfo.setstatus (orderstatusdto.getStatus ()); System.out.println ("Modifier l'état de l'ordre:" borderInfo.ToString () "\ n"); OrderInfoService.update (borderInfo); return ajaxResult.success (); }
Ajout de la classe Orderstatusdto:
classe publique Orderstatusdto { ID entier privé; Statut entier privé; // Getters et Setters }
En utilisant l'annotation @RequestBody
et en créant une classe OrderStatusDTO
pour recevoir les données JSON transmises par l'avant, le backend peut analyser correctement les données pour éviter le problème des valeurs NULL
. Veuillez vous assurer que les données JSON envoyées par le frontal sont cohérentes avec le nom de champ d' OrderStatusDTO
. Dans le même temps, vérifiez si la fonction request
frontale a correctement défini headers
, tels que Content-Type: application/json
.
Cette solution est plus conforme aux spécifications de conception de l'API RESTful que la solution d'origine @RequestParam
, et traite également plus clairement les données corporelles des demandes de poste.
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!

JVM gère les différences d'API du système d'exploitation via JavanativeInterface (JNI) et Java Standard Library: 1. JNI permet au code Java d'appeler le code local et d'interagir directement avec l'API du système d'exploitation. 2. La bibliothèque Java Standard fournit une API unifiée, qui est mappée en interne sur différentes API du système d'exploitation pour s'assurer que le code se déroule sur les plates-formes.

ModularityDoesNotDirectlyAffectedJava'splatformIndependence.java'splatformIndependensemAINENENEYBYTHEJVM, ButModularityInfluencesPlicationsStructureAndManagement, indirectly ImpactingPlatFatFindependence.1)

Bytecodeinjavaisheintermediaterepresentation the-steplatefortiveindependence.1) javacodeiscompilentocodedestoredin.classfiles.2) thejvMinterpretsorcompiltesthisbytecodeintomachinecotetruntime, permettant à la nom de codécodèdetorunonanydevicewithajvm, ainsi en nomycodetorunonananydevicewithajvm, ainsi.

JavaachievesPlatformIndependencethroughthejavavirtualmachine (jvm), quixecutesbytecodeonanydevicewithajvm.1) javacodeiscompilentocode.2) thejvMinterpretsAndexExectestySByteintomachine-spécificestructions, permettre la réduction de la réduction de la masse

L'indépendance de la plate-forme dans le développement de Javagui est confrontée à des défis, mais peut être traitée en utilisant Swing, Javafx, l'apparence unificatrice, l'optimisation des performances, les bibliothèques tierces et les tests multiplateformes. Le développement de Javagui repose sur AWT et Swing, qui vise à fournir une cohérence multiplateforme, mais l'effet réel varie du système d'exploitation au système d'exploitation. Les solutions comprennent: 1) l'utilisation de Swing et Javafx comme cases d'outils GUI; 2) Unifier l'apparence via uimanager.setLookAndFeel (); 3) Optimiser les performances en fonction des différentes plates-formes; 4) en utilisant des bibliothèques tierces telles que l'apachepivot ou le SWT; 5) effectuer des tests multiplateformes pour assurer la cohérence.

JavadevelopmentSnotentivelyPlatform-indépendant de la duetoseveralfactors.1) jvmvariationSAffecctPerformanceAndbehavioracrossdifferentos.2) nativelibrarysviajniintroduceplatform-specificiss.3) goypathesystempropertiesdifferbetweenweenplateforms.4) goypathesmepropertiesdifferbetweenweenplateforms.4) guiaplicapropertiesdifferbetweenweenplateforms.4) guiaplicapropertiesdifferbetweenweenplateforms.4) guiaplicaaPropertiesdifferbetweenweenplateforms.4) GuiaplicaAplicaAplisses.

Java Code aura des différences de performances lors de l'exécution sur différentes plates-formes. 1) Les stratégies de mise en œuvre et d'optimisation de JVM sont différentes, comme OracleJDK et OpenJDK. 2) Les caractéristiques du système d'exploitation, telles que la gestion de la mémoire et la planification des threads, affecteront également les performances. 3) Les performances peuvent être améliorées en sélectionnant le JVM approprié, en ajustant les paramètres JVM et l'optimisation du code.

Java'splatformindependensencehaslimitations incluant la performance de la tête, les versions de verso, les défis avec l'intégration de la plate-forme spécifique et lajvminstallation / maintenance.


Outils d'IA chauds

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.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à 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

Navigateur d'examen sécurisé
Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft

Version Mac de WebStorm
Outils de développement JavaScript utiles

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel
