Maison >Java >javaDidacticiel >L'interface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

L'interface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBavant
2023-05-15 15:01:141239parcourir

Le développement continue d'être mis à jour

La section précédente a dessiné une page frontale approximative. Aujourd'hui, nous allons principalement implémenter l'interface back-end, puis ajuster le front-end et le back-end pour implémenter de nouvelles fonctions de l'interface. Prévisualisez d'abord l'effet :

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

1. Partie backend

Ajoutez une nouvelle méthode de traitement dans la classe ApiDefinitionController pour gérer les nouvelles requêtes de l'interface :

@PostMapping("/add")
  public Result add(@RequestBody ApiDefinition request) {
      try {
          apiDefinitionService.add(request);
          return Result.success();
      } catch (Exception e) {
          return Result.fail(e.toString());
      }
  }

La méthode d'ajout correspondante est implémentée dans la couche de service :

public void add(ApiDefinition request) {
      if (StringUtils.isEmpty(request.getProjectId().toString())) {
          BtException.throwException("项目id为空");
      }
      if (StringUtils.isEmpty(request.getModuleId().toString())) {
          BtException.throwException("模块id为空");
      }
      if (StringUtils.isEmpty(request.getName())) {
          BtException.throwException("接口名称为空");
      }
      request.setCreateTime(new Date());
      request.setUpdateTime(new Date());
      apiDefinitionDAO.insert(request);
  }

Enregistrer La mise en œuvre n'est pas difficile et plusieurs jugements nuls de paramètres importants sont ajoutés.

2. Partie front-end

Dans la page dessinée dans la section précédente, il reste encore deux onglets, paramètre de repos et corps de la requête, qui n'ont pas été dessinés, merci de les compléter au préalable.

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

1. paramètres de repos

Il s'agit principalement des demandes d'interfaces de style reposant, telles que /bloomtest/project/list/1/10. sont requis. Définissez les variables dans les paramètres et récupérez-les. /bloomtest/project/list/1/10,这时候后面的1 和 10,就要在参数里设置变量去取了。

形式还是跟前面的 请求头 和 query参数一样的:

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

对应的增加这个字段:

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

关于这里面的 key,是组件里需要的,我试过去掉,但是会有问题。暂时先留着,存进来目前不影响我后续的操作。

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

2. 请求体

这个请求体内容,目前只考虑一般都情况,需要对其进行 json 格式化展示。我依然在 github 上找现成的组件,结果找到了一个vue-json-editor

Le formulaire est toujours le même que l'en-tête de requête et les paramètres de requête précédents :

springboot L'interface de la plateforme de test Vue définit comment implémenter de nouvelles fonctions front-end et back-end

Ajoutez ce champ en conséquence :

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-endl'interface de la plateforme de test Springboot Vue définit comment implémenter de nouvelles fonctions front-end et back-end

À propos de la clé ici, elle est requise dans le composant. I j'ai essayé de le supprimer, mais il y aura des problèmes. Je le garde pour l'instant. Le sauvegarder n'affectera pas mes opérations ultérieures.

définition de l'interface de la plateforme de test Springboot Vue comment implémenter de nouveaux front-end et back- end function Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

2. Corps de la requête

Le contenu de ce corps de requête n'est actuellement pris en compte que pour des situations générales et doit être affiché au format json. Je cherchais toujours des composants prêts à l'emploi sur github et j'ai trouvé un vue-json-editor.

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-endCe composant prend en charge l'édition. Celui que j'ai utilisé pour renvoyer l'affichage dans la section précédente ne peut pas être modifié.

npm install vue-json-editor --save

Après l'installation, importez-le dans le fichier vue.

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

Ce composant prend également en charge certaines fonctions, mais il me suffit de pouvoir le formater. Il y a une démo dans le code de l'auteur.

C'est également très simple à utiliser dans mon code. Il suffit de trouver l'endroit où vous souhaitez mettre la zone de saisie et de copier le code pour le modifier.

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

Champ de liaison bidirectionnelle v-model : mode="'code'" est le mode d'affichage par défaut, comme suit

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

Bien que la fonction soit disponible, je n'aime pas beaucoup le style et la couleur beaucoup. J'ai essayé de modifier le code source et de l'ajuster, mais cela n'a pas fonctionné. Je vais le faire pour l'instant et en parler plus tard.

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end3. Paramètres de la demande

Étant donné que ma page entière est divisée en de nombreux formulaires différents, j'ai donc besoin d'un endroit pour la traiter maintenant, collecter le contenu de ces formulaires et les placer au même endroit pour la demande d'interface finale.

Ajoutez une nouvelle méthode handleSaveRequest et attribuez des valeurs aux champs à l'intérieur :

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

Notez qu'il y a un jugement dans la méthode. Parmi ces trois onglets, celui sur lequel je clique attribuera le contenu ajouté à this.saveApiRequest.request :

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

🎜🎜De plus, il convient également de noter que pour apiHeader, request et réponse, il y a Vous devez utiliser JSON .stringify() pour le convertir en chaîne Json afin de faciliter le stockage back-end. 🎜🎜4. Interface de requête 🎜🎜Tout d'abord, vous devez ajouter cette interface dans apiDefinition.js : 🎜🎜🎜🎜🎜Puis importer : 🎜🎜🎜🎜

Enfin, implémentez la nouvelle méthode d'interface saveApi Bien entendu, l'événement de clic @click="saveApi" sur le bouton [Enregistrer] est indispensable. saveApi,当然了,在【保存】按钮上的@click="saveApi"点击事件不能少了。

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-end

在这个saveApi方法里,要做这么几件事:

先调用方法handleSaveRequest

définition de l'interface de la plateforme de test Springboot Vue comment implémenter de nouveaux front-end et back- end function

Linterface de la plate-forme de test Springboot vue définit comment implémenter de nouvelles fonctions front-end et back-endDans cette méthode saveApi, il y a plusieurs choses à faire :

Appelez d'abord la méthode handleSaveRequest, affectez l'interface de requête aux paramètres de la requête, et invitez le résultat à fermer la boîte de dialogue nouvellement ajoutée. La boîte de dialogue actualise la liste

🎜🎜🎜🎜De cette façon, la nouvelle fonction de l'interface est réalisée, mais le module ici est temporairement codé en dur avec un 0 par défaut. L'interface est d'abord stockée sous le nœud supérieur. Plus tard, un arbre de sélection doit être implémenté ici, utilisé pour lier des modules spécifiques. 🎜

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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer