代码质量管理工具-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,页面如下


相关推荐
ZFSS1 小时前
WebExtrator 网页渲染与内容提取 API 使用指南
前端·人工智能·ai·ai编程
M ? A1 小时前
VuReact:Vue转React的增量编译利器
前端·vue.js·后端·react.js·面试·开源·vureact
csj502 小时前
前端基础之《React(9)—React组件》
前端·react.js
研究点啥好呢2 小时前
Muses | 搭建属于你自己的AI生图网站
前端·人工智能·ai·github
aircrushin2 小时前
给宝宝办了个宴,朋友用trae做的工具帮了大忙
前端·后端
程序员Sunday2 小时前
爆肝万字!这应该是全网最全的 Codex 实战教程了
前端·后端·ai编程
aircrushin2 小时前
朋友用trae搭建的工具,解决了旅行拍照共享的大事儿
前端·后端
ZC跨境爬虫2 小时前
跟着 MDN 学 HTML day_41:(DOMParser 接口详解)
前端·javascript·ui·html·音视频
光影少年2 小时前
useLayoutEffect 和 useEffect 区别、使用场景
开发语言·前端·javascript