sonar3 使用 api/measures/componet 获取代码当,Java实现

2024-05-28 12:28

本文主要是介绍sonar3 使用 api/measures/componet 获取代码当,Java实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        最近团队在做一个技术架构相关的优化,当前的目标是想要通过代码量,系统架构入手。先统计到部门的代码量,如何进行代码行数的统计呢,因为我们采用的是Java技术栈,我就Java技术栈进行说明。 

1、如何统计代码行数

        要统计Java代码的行数,你可以根据你的操作系统和可用工具选择不同的方法。下面是一些常见的方法:

1. 使用IDE

        如果你使用的是IDE(如IntelliJ IDEA, Eclipse等),通常它们都有内置的功能或插件来统计项目中的代码行数。你可以查找你所使用的IDE的文档或在线资源来找到具体的操作步骤。

2. 使用命令行工具

在Linux或macOS上

        咱们可以使用find和wc命令组合来统计特定类型的文件的代码行数。例如,要统计一个目录及其子目录中所有Java文件的行数,可以使用:

find . -name '*.java' | xargs wc -l 

        这条命令会列出所有.java文件的行数,并在最后给出总计。如果你想要使用find和xargs命令组合来统计Java代码行数,同时去掉空行,可以通过管道将find的输出传递给grep命令来过滤掉空行,然后再统计行数。这里有一个示例命令,展示了如何实现这一点:

find . -name '*.java' -print0 | xargs -0 grep -vE '^\s*$' | wc -l 

这个命令的解释如下:

  • find . -name '*.java' -print0:查找当前目录及子目录下所有的.java文件。-print0选项与xargs的-0选项配合使用,用于正确处理文件名中可能包含的空格、换行等特殊字符。

  • xargs -0 grep -vE '^\s*$':xargs -0接收find命令的输出作为grep命令的输入。grep -vE '^\s*$'用于过滤掉空行,其中-v选项表示选取不匹配的行,-E选项表示使用扩展正则表达式,'^\s*$'是一个正则表达式,用于匹配只包含空白字符(包括空格、制表符等)的行。

  • wc -l:统计通过grep过滤后剩余的行数,即非空行的数量。

        这样,咱们就可以得到所有.java文件中非空行的总数。请注意,这种方法并不会区分代码行和注释行,它只是简单地去除了完全为空的行。

在Windows上

        可以使用PowerShell来实现类似的功能。以下是一个使用PowerShell统计当前目录及子目录中所有.java文件行数的例子:

(Get-ChildItem -Recurse -Filter *.java | Select-String . -AllMatches).Matches.Count 

3. 使用专门的代码行数统计工具

        cloc(Count Lines of Code)是一个流行的、跨平台的工具,可以统计多种编程语言的代码行数。使用cloc统计Java代码行数的命令如下:

cloc --include-lang=Java . 

这将会输出当前目录中Java代码的文件数量、空行数、注释行数和代码行数。

4. 使用简单的脚本

        如果你的需求比较特殊,也可以编写简单的脚本来统计代码行数,比如使用Python或其他你熟悉的脚本语言。

        选择哪种方法取决于你的具体需求和你使用的环境。上述方法中的大多数都可以很容易地适应来统计其他编程语言的代码行数。

5. 使用sonar WEB API 统计代码行数

        因为我们的项目都接入了sonar,sonar可以在代码提交的时候进行一系列的检查和统计工作,同时他也提供了WebApi的方式对外提供了接口,所以我们用sonar3提供的接口api/measures/componet获取代码当量,使用Java实现。

创建令牌桶

        在SonarQube中创建访问令牌(Access Token)是一个简单的过程,可以通过SonarQube的Web界面完成。访问令牌允许你以编程方式访问SonarQube API,而不需要使用用户名和密码。以下是创建访问令牌的步骤:

  1. 登录SonarQube:首先,使用你的账户登录到SonarQube的Web界面。

  2. 进入账户设置:登录后,点击右上角的用户名,然后在下拉菜单中选择“My Account(我的账户)”。

  3. 选择Security(安全)选项卡:在账户页面中,找到并点击“Security(安全)”选项卡。

  4. 生成Token:在“Security(安全)”页面,你会看到一个“Tokens(令牌)”部分。在这里,输入一个名称来标识你的Token,然后点击“Generate(生成)”按钮。名称可以是任何有意义的标识符,用于帮助你记住Token的用途。

  5. 保存Token:生成后,Token会显示在屏幕上。请确保复制并保存这个Token,因为它不会再次显示。如果你丢失了Token,你需要生成一个新的。

  6. 使用Token:现在你可以在API调用中使用这个Token了。在需要认证的地方,将Token作为用户名,密码部分留空。如果你使用的是HTTP请求,你可以通过在请求头中添加Authorization: Basic <encoded_token>来使用Token,其中<encoded_token>是你的Token经过Base64编码的结果。注意,编码时Token后面要加上冒号(:),即如果你的Token是abc123,你应该对abc123:进行Base64编码。

请注意,保护好你的Token,不要泄露给他人,因为拥有Token就等同于拥有你账户的访问权限。如果你的Token不慎泄露,应立即在SonarQube界面中撤销该Token,并生成一个新的。

sonar3使用api/measures/componet获取代码当量

        要使用SonarQube的API /api/measures/component 来获取代码度量信息,你可以使用Java进行实现。这个API允许你获取特定组件(例如项目或模块)的度量信息,比如代码行数、复杂度等。

        以下是一个简单的Java示例,展示了如何使用HttpURLConnection来调用SonarQube的API,并获取代码度量信息。请注意,你需要替换以下代码中的your_sonarqube_url、your_project_key、your_metric_keys和your_access_token为你自己的SonarQube服务器地址、项目键、度量键和访问令牌。

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;public class SonarQubeApiExample {public static void main(String[] args) {try {// 替换为你的SonarQube服务器地址String sonarQubeUrl = "http://your_sonarqube_url";// 替换为你的项目键String projectKey = "your_project_key";// 替换为你想要获取的度量键,例如:ncloc,complexity等,用逗号分隔String metricKeys = "your_metric_keys";// 替换为你的访问令牌String accessToken = "your_access_token";// 构建API URLString apiUrl = String.format("%s/api/measures/component?component=%s&metricKeys=%s", sonarQubeUrl, projectKey, metricKeys);// 创建URL对象URL url = new URL(apiUrl);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");// 设置认证信息conn.setRequestProperty("Authorization", "Basic " + java.util.Base64.getEncoder().encodeToString((accessToken + ":").getBytes()));// 发送请求并获取响应码int responseCode = conn.getResponseCode();System.out.println("Response Code: " + responseCode);// 读取响应内容BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream()));String inputLine;StringBuilder response = new StringBuilder();while ((inputLine = in.readLine()) != null) {response.append(inputLine);}in.close();// 打印响应内容System.out.println(response.toString());} catch (Exception e) {e.printStackTrace();}}
}

        请确保你已经有了SonarQube的访问令牌,你可以在SonarQube的用户界面中生成它。在调用API时,需要使用基本认证(Basic Authentication),并将访问令牌作为用户名,密码部分留空。

        此代码示例展示了如何构建API请求,设置必要的HTTP头(包括认证信息),发送请求,以及如何处理响应。你可以根据需要调整projectKey和metricKeys参数来获取不同项目的不同度量信息。

这篇关于sonar3 使用 api/measures/componet 获取代码当,Java实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1010563

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数