Qualité de code Java et analyse statique avec Sonarqube
Jul 29, 2025 am 02:03 AMSonarqube 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
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.

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:

-
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.
-
Configurer sonarscanner
- 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.
-
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
-
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>
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
- Exécuter la commande:
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 quesonar.java.binaries
pointe vers le répertoire de sortie compilé correct (tel quetarget/classes
), sinon certaines règles ne prendront pas effet.Le chemin du rapport de test est incorrect
Sisonar.junit.reportPaths
etsonar.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 utilisersonar-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!

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

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

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

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

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

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

Le fichier SetfitS.JSON est situé dans le chemin de niveau utilisateur ou au niveau de l'espace de travail et est utilisé pour personnaliser les paramètres VScode. 1. Chemin de niveau utilisateur: Windows est C: \ Users \\ AppData \ Roaming \ Code \ User \ Settings.json, macOS est /users//library/applicationsupport/code/user/settings.json, Linux est /home//.config/code/user/settings.json; 2. Chemin au niveau de l'espace de travail: .vscode / Paramètres dans le répertoire racine du projet

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

L'installation du plug-in Emmet peut réaliser une fermeture automatique intelligente des balises et une syntaxe d'abréviation de support; 2. Activer "Auto_Match_enabled": TRUE permet à Sublime de terminer automatiquement les balises simples; 3. Utilisez Alt. (Win) ou Ctrl Shift. (MAC) Les touches de raccourci pour fermer manuellement l'étiquette actuelle - il est recommandé d'utiliser Emmet dans la vie quotidienne. Les deux dernières méthodes peuvent être combinées, ce qui est efficace et simple à définir.
