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


相关推荐
橙子家几秒前
浏览器缓存之【身份与会话管理】:Cookies 和 Private state tokens
前端
最新资讯动态1 小时前
HDC 2026 | 对话鲸鸿动能:存量时代,品牌如何夺回营销“主动权”?
前端
最新资讯动态1 小时前
游戏出海,从产品走向体系
前端
最新资讯动态1 小时前
20人团队跑出百万DAU、大厂也来抢量:谁在鸿蒙生态跑出加速度
前端
最新资讯动态1 小时前
千万开发者背后,鸿蒙商业化的B面
前端
爱勇宝3 小时前
AI 时代:智商决定起点,情商决定走多远
前端·ai编程
kyriewen3 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
IT_陈寒4 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
徐小夕5 小时前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
一份执念5 小时前
uni-app 小程序分包限制处理与主包体积优化实战
前端·微信小程序