代码质量管理工具-SonarQube

SonarQube概述

SonarQube在代码质量检测领域的"江湖地位",就相当于前端界的 Vue 或 React,依然是绝大多数中大型企业的"默认标配"。

配置步骤

docker安装两个镜像

  • sonarquebe
  • sonarsource/sonar-scanner-cli

前端项目

  • 终端运行命令npm install -g sonar-scanner
  • 前端根目录新增文件sonar-project.properties,如下
bash 复制代码
# ======================
# 项目基本信息
# ======================
sonar.projectKey=ts-r
sonar.projectName=ts-r
sonar.sourceEncoding=UTF-8

# ======================
# SonarQube 服务地址 & Token
# ======================
sonar.host.url=http://localhost:9000
sonar.login=sqp_855c49d8c7aab612ab1886b92d206b007ce713e9

# ======================
# 扫描目录
# ======================
sonar.sources=src

# ======================
# ✅ 明确指定要扫描的文件类型(关键)
# ======================
sonar.inclusions=**/*.js,**/*.jsx,**/*.ts,**/*.tsx,**/*.less,**/*.scss,**/*.css

# ======================
# ❌ 排除不需要扫描的目录
# ======================
sonar.exclusions=**/node_modules/**,**/dist/**,**/build/**,**/*.test.*,**/*.spec.*,**/*.es.js

# ======================
# ✅ 启用 JavaScript / TypeScript 分析
# ======================
sonar.javascript.file.suffixes=.js,.jsx
sonar.typescript.file.suffixes=.ts,.tsx

# ======================
# ✅ CSS / Less / Scss 支持
# ======================
sonar.css.file.suffixes=.css,.less,.scss
  • 新增脚本文件scripts/sonar-scan.js,如下
javascript 复制代码
const { execSync } = require('child_process');

const hostUrl = 'http://host.docker.internal:9000'; //指向本机docker中 sonarqube的配置
const projectDir = process.cwd().replace(/\\/g, '/');

const cmd = [
  'docker run --rm',
  `-e SONAR_HOST_URL="${hostUrl}"`,
  `-v "${projectDir}:/usr/src"`,
  'sonarsource/sonar-scanner-cli'
].join(' ');

console.log('🚀 Running SonarScanner...\n');
console.log(cmd);

execSync(cmd, { stdio: 'inherit' });
  • 修改package.json,如下
bash 复制代码
{
 "scripts":{
   "sonar-scan": "node scripts/sonar-scan.js",
   }
 }

代码扫描

  • 终端运行yarn sonar-scan命令就是通过node运行脚本scripts/sonar-scan.js,本质上就是执行那个docker命令
  • 浏览器访问localhost:9999,页面如下


相关推荐
JustHappy13 小时前
古法编程秘籍(二):什么是代码模块化?别背概念,把房间收拾明白就够了
前端·后端
小江的记录本13 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
weixin_4713830313 小时前
图片预解码缓存
前端·浏览器缓存·图片预解码
郑洁文15 小时前
基于网络爬虫的Web敏感信息泄露自动化检测工具
前端·爬虫·网络安全·自动化
郑洁文16 小时前
可视化Web渗透分析工具的设计与实现
前端
罗超驿16 小时前
18.Web API 实战:元素与表单属性的获取和修改
开发语言·前端·javascript
边界条件╝16 小时前
微前端进阶(四)
前端·状态模式
无风听海16 小时前
JSON Web Token(JWT)完全指南
java·前端·json
IT_陈寒17 小时前
Python闭包里藏的这个坑,差点让我加班到凌晨
前端·人工智能·后端
IT_陈寒17 小时前
Java注解空指针?这个坑我踩得莫名其妙
前端·人工智能·后端