Table des matières
Qu'est-ce que Sonarqube?
Comment intégrer sonarqube dans le projet Java?
Règles de qualité clés et meilleures pratiques
Conseils: Évitez les pièges communs
Maison Java javaDidacticiel Qualité de code Java et analyse statique avec Sonarqube

Qualité de code Java et analyse statique avec Sonarqube

Jul 29, 2025 am 02:03 AM
java Qualité du code

Sonarqube est une plate-forme de gestion de la qualité de code open source utilisée pour détecter les défauts de code, les vulnérabilités de sécurité, les odeurs de code, le code en double dans plus de 20 langues telles que Java et évaluer la couverture et la complexité des tests. 1. Installez le serveur Sonarqube et accédez à http: // localhost: 9000 pour terminer l'initialisation; 2. Configurez l'outil Sonarscanner ou utilisez le plug-in Maven / Gradle; 3. Créez le fichier sonar-project.properties dans le répertoire racine du projet, spécifiez les informations du projet, le chemin du code source, la sortie de compilation et le chemin du rapport de test; 4. Utilisez Jacoco pour générer un rapport de couverture de test, et configurez Prépare-Agent et rapportez l'exécution via le plug-in Maven; 5. Exécutez la commande MVN Clean Verify Sonar: Sonar ou sonar-scanner, et soumettez les résultats de l'analyse en combinaison avec l'authentification de jeton -dsonar.login. Les règles clés comprennent l'évitement des blocs de capture vides, le contrôle de la complexité du cercle, l'élimination du code en double, la garantie de plus de 80% de couverture de test et la gestion des points chauds de sécurité. Le contrôle de la qualité d'accès peut être appliqué dans des processus CI tels que les actions Jenkins ou GitHub via des seuils de qualité personnalisés (tels que la nouvelle couverture du code ≥ 80%, aucun problème sérieux, un code en double

Qualité de code Java et analyse statique avec Sonarqube

La qualité du code Java et l'analyse statique sont des liens clés pour assurer la maintenabilité et la stabilité à long terme des projets, et Sonarqube est actuellement l'une des plateformes de gestion de la qualité du code les plus populaires. Il peut aider les équipes de développement à détecter automatiquement les défauts potentiels, les odeurs de code, les vulnérabilités de sécurité et le code en double dans le code, améliorant ainsi en continu la qualité du code.

Qualité de code Java et analyse statique avec Sonarqube

Qu'est-ce que Sonarqube?

Sonarqube est une plate-forme open source pour une inspection continue de la qualité du code. Il prend en charge plus de 20 langages de programmation, y compris Java, et donne un aperçu des dimensions suivantes en analysant statiquement le code source:

  • Détection de bogues : a trouvé un problème de code qui peut entraîner des erreurs d'exécution.
  • Identification de la vulnérabilité : détecter les problèmes de sécurité, tels que l'injection SQL, les mots de passe à code dur, etc.
  • L'odeur du code : souligne le code avec une mauvaise structure et difficile à maintenir.
  • Répéter le code : Identifiez les blocs de code en double pour réduire les coûts de maintenance.
  • Couverture de test : Intégrez les rapports de test unitaires pour évaluer la couverture du code.
  • Analyse de la complexité : mesurez la complexité du cercle des classes et des méthodes pour éviter une complexité excessive.

Comment intégrer sonarqube dans le projet Java?

Pour appliquer Sonarqube à un projet Java, les étapes suivantes sont généralement requises:

Qualité de code Java et analyse statique avec Sonarqube
  1. Installez et démarrez le serveur Sonarqube

    • Téléchargez gratuitement SonarQube (Community Edition) et démarrez le service (Port par défaut 9000).
    • Visitez http://localhost:9000 pour terminer la configuration initiale.
  2. Configurer sonarscanner

    Qualité de code Java et analyse statique avec Sonarqube
    • Sonarscanner est un outil de ligne de commande pour effectuer une analyse et doit être téléchargé et configuré dans le chemin du système.
    • Ou utilisez le plug-in Maven / Gradle pour intégrer plus facilement.
  3. Ajouter des fichiers de configuration au projet

    • Créer un fichier sonar-project.properties dans le répertoire racine du projet, exemple de contenu:

       sonar.projectKey = my-java-project
      Sonar.projectName = mon projet Java
      sonar.projectVersion = 1,0
      
      sonar.sources = src / main / java
      sonar.tests = src / test / java
      sonar.java.binaries = cible / classes
      sonar.java.test.binaries = cible / classes de test
      
      Sonar.Junit.ReportPaths = Target / SureFire-Reports
      Sonar.jacoco.ReportPaths = Target / Jacoco.exec
  4. Générer le rapport de couverture de code (Jacoco recommandé)

    • Si vous utilisez Maven, ajoutez le plugin Jacoco:

       <fruit>
          <GroupId> org.jacoco </rombandid>
          <ArtefactId> Jacoco-Maven-Plugin </Retifactid>
          <version> 0.8.11 </ version>
          <Cecultes>
              <exécution>
                  <buts>
                      <butard> prépare-agent </ but>
                  </ buts>
              </ Execution>
              <exécution>
                  <id> Rapport </id>
                  <gase> Test </stophe>
                  <buts>
                      <FORME> RAPPORT </FORST>
                  </ buts>
              </ Execution>
          </IMICATION>
      </ plugin>
  5. Analyse en cours

    • Exécuter la commande:
       MVN Clean Verify Sonar: Sonar \
        -Dsonar.login = your-token \
        -Dsonar.host.url = http: // localhost: 9000
    • Ou utilisez sonarscanner:
       sonar-scanner -dsonar.login = votre-token

Remarque: il est recommandé d'utiliser le jeton utilisateur généré par SonarQube pour l'authentification, plutôt que le nom d'utilisateur et le mot de passe en texte clair.

Règles de qualité clés et meilleures pratiques

Sonarqube a des centaines de règles établies, et en voici certaines qui sont particulièrement dignes d'attention dans les projets Java:

  • Évitez les blocs de capture vides
    catch(Exception e) {} masquera l'exception et devrait au moins les journaux de journaux.

  • Réduire la complexité du cercle (complexité cyclomatique)
    La méthode est trop complexe (par défaut> 10 alarmes) signifie qu'il est difficile à tester et à maintenir, et la logique doit être divisée.

  • Éliminer le code en double
    SonarQube marquera des blocs de code similaires, ce qui incite à extraire des méthodes ou des classes publiques.

  • Assurer la couverture des tests unitaires
    Il est recommandé de définir un seuil de couverture minimum (tel que la couverture des lignes ≥ 80%) et d'être des chèques obligatoires dans le processus CI.

  • Hotspots de sécurité
    Tels que les références à code dur, la génération de nombres aléatoires dangereuse ( Math.random() est utilisée dans des scénarios sûrs), etc.

Vous pouvez personnaliser les seuils de qualité dans l'interface Sonarqube, par exemple:

  • Le taux de couverture des nouveaux codes est ≥ 80%
  • Problème de grave (bloqueur) zéro
  • Nombre de lignes de code répétées

Ces règles peuvent être appliquées dans le processus d'intégration continue du projet (CI), telles que l'intégration des analyses Sonarqube dans les actions de Jenkins ou GitHub, et le blocage des fusions s'ils échouent.

Conseils: Évitez les pièges communs

  • Erreur de configuration de ClassPath compilée
    Assurez-vous que sonar.java.binaries pointe vers le répertoire de sortie compilé correct (tel que target/classes ), sinon certaines règles ne prendront pas effet.

  • Le chemin du rapport de test est incorrect
    Si sonar.junit.reportPaths et sonar.jacoco.reportPaths ne sont pas configurés correctement, la couverture sera affichée comme 0.

  • Analyse incrémentale vs analyse complète
    Sonarqube effectue une analyse complète par défaut. Si vous analysez uniquement le code de modification, vous pouvez utiliser sonar-scm-provider-git pour coopérer.

  • Les annotations chinoises entraînent des problèmes de codage
    Assurez-vous que le fichier de code source est un codage UTF-8 pour éviter les échecs d'analyse en raison de problèmes de jeu de caractères.

Fondamentalement, c'est tout. Ce qui rend sonarqube puissant, c'est qu'il transforme la qualité du code en un processus mesurable et traçable. Pour les projets Java, l'intégration de Sonarqube n'est pas compliquée, mais les avantages à long terme sont très importants - moins de bogues en ligne, une meilleure maintenabilité et un travail d'équipe plus efficace.

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 grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Porce de variable PHP expliquée
1 Il y a quelques mois By 百草
Commentant le code en php
1 Il y a quelques mois By 百草
<🎜>: Grow A Garden - Guide complet des marchands itinérants
4 Il y a quelques semaines By Jack chen
Conseils pour écrire des commentaires PHP
1 Il y a quelques mois By 百草

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)

Sujets chauds

Tutoriel PHP
1511
276
Python Argparse exigence de l'argument requis Python Argparse exigence de l'argument requis Aug 11, 2025 pm 09:42 PM

Lorsque vous utilisez le module ArgParse, les paramètres qui doivent être fournis peuvent être obtenus en réglant le réglage = TRUE. 1. Utiliser requis = TRUE pour définir des paramètres facultatifs (tels que --inter) à être requis. S'il n'est pas fourni lors de l'exécution du script, une erreur sera signalée; 2. Les paramètres de position sont requis par défaut, et il n'est pas nécessaire de définir requis = true; 3. Il est recommandé d'utiliser les paramètres de position pour les paramètres nécessaires. Parfois, les paramètres facultatifs de requis = TRUE sont utilisés pour maintenir la flexibilité; 4. Required = true est le moyen le plus direct de contrôler les paramètres. Après utilisation, l'utilisateur doit fournir des paramètres correspondants lors de l'appel du script, sinon le programme invitera une erreur et quittera.

Quels sont les commentaires dans Java? Quels sont les commentaires dans Java? Aug 12, 2025 am 08:20 AM

CommentairesInjavaAreignoredBytheCompilerAndUsedforexPlaning, Notes, OrdisablingCode.ThereAreaTheTypes: 1) une seule linecommentStartwith // andLastuntUlLtheendoFtheline; 2) Multi-linecomements Beginwith / AndendWith / andCanspanMultiplelines; 3) documentation sur la documentation avec documentation

The Best Ides for Java Development: une revue comparative The Best Ides for Java Development: une revue comparative Aug 12, 2025 pm 02:55 PM

Thebestjavaidein2024Denpendyourndeds: 1.chooseintellijideaforprofessional, l'entreprise, le development orfulldevelopmentduetoitsSuperiorCodeIntelligence, le framewory

Comment utiliser l'API HTTPClient en Java Comment utiliser l'API HTTPClient en Java Aug 12, 2025 pm 02:27 PM

Le cœur de l'utilisation du javahttpclientapi est de créer un httpclient, de créer un httprequest et de traiter httpResponse. 1. Utilisez httpclient.newhttpclient () ou httpclient.newbuilder () pour configurer les délais d'expiration, proxy, etc. pour créer des clients; 2. Utilisez httpRequest.newBuilder () pour définir URI, méthode, en-tête et corps pour construire des demandes; 3. Envoyez des demandes synchrones via client.send () ou envoyez des demandes asynchrones via client.sendaSync (); 4. Utilisez des handleurs.

Comment comparer les chaînes à Java Comment comparer les chaînes à Java Aug 12, 2025 am 10:00 AM

Utilisez .equals () pour comparer le contenu de la chaîne, car == comparer uniquement les références d'objet plutôt que les caractères réels; 2. Utiliser .EqualSignoreCase () Lors de la comparaison de l'ignorance de cas; 3. Utilisez .CompareTo () lors du tri par ordre alphabétique, et .CompareToIgnoreCase () lors de l'ignorance de cas; 4. Évitez d'appeler des chaînes qui peuvent être nulles. Equals () doit être utilisé pour utiliser "littéral" .equals (variable) ou objets.equals (str1, str2) pour gérer en toute sécurité les valeurs nulles; Bref, faites toujours attention à la comparaison du contenu plutôt qu'à une référence,

Qu'est-ce qu'une liste liée en Java? Qu'est-ce qu'une liste liée en Java? Aug 12, 2025 pm 12:14 PM

LinkedList est une liste liée bidirectionnelle dans Java, implémentant la liste et les interfaces de Deque. Il convient aux scénarios où les éléments sont fréquemment insérés et supprimés. Surtout lorsqu'il fonctionne aux deux extrémités de la liste, il a une efficacité élevée, mais les performances d'accès aléatoire sont médiocres et la complexité du temps est O (n). L'insertion et la suppression peuvent atteindre O (1) à des endroits connus. Par conséquent, il convient à la mise en œuvre de piles, de files d'attente ou de situations où les structures doivent être modifiées dynamiquement et ne convient pas aux opérations à forte intensité de lecture qui accèdent fréquemment par index. La conclusion finale est que LinkedList est meilleur que ArrayList lorsqu'il est fréquemment modifié mais a moins d'accès.

Edge ne sauvant pas l'histoire Edge ne sauvant pas l'histoire Aug 12, 2025 pm 05:20 PM

Tout d'abord, Checkif "ClearbrowsingDataOnClose" IsTurneDOninsettingsandTurnitofftoenSureHistoryissaved.2.Confirmyou'renotusingInprivateMode, asitdoesNotsAvehistoryByDesigr.3.Disable ExtensionStendatoryToUleoutHeleft

Excel trouver et remplacer ne fonctionne pas Excel trouver et remplacer ne fonctionne pas Aug 13, 2025 pm 04:49 PM

CheckkSearchSettings like "MatchEnteRireCellContents" et "MatchCase" ByExpandingOptionsInFindanDreplace, garantissant "lookin" issettominuesand »dans" TOCORRECTSCOPE; 2.LOORHFORHIDDENCHARACTER

See all articles