ApplicationInspector

ApplicationInspector

微软开源源代码特征识别工具 支持多语言分析与报告生成

ApplicationInspector是微软开发的开源源代码特征识别工具,基于库和API调用模式识别软件组件编码特征。支持多种编程语言分析,生成HTML、JSON和文本格式报告。该工具可用于确定软件功能、安全合规检查、特征差异识别等场景,有助于提升软件开发全周期的安全性。ApplicationInspector不进行好坏模式判断,而是客观报告发现的特征,帮助开发者快速了解开源或其他组件的实际功能。

应用程序检查器源代码分析安全检查特征识别开源工具Github开源项目

简介

CodeQL Nuget Nuget

Microsoft Application Inspector是一款软件源代码特征分析工具,旨在识别第一方或第三方软件组件的编码特征,基于众所周知的库/API调用,适用于安全和非安全用例。它使用数百条规则和正则表达式模式来揭示源代码的有趣特征,帮助确定软件是什么它做什么,包括它使用的文件操作、加密、shell操作、云API、框架等。该工具在ZDNetSecurityWeekCSOOnlineLinux.com/newsHelpNetSecurity、Twitter等平台上受到业界关注,被认为是对开源软件的新颖且有价值的贡献,并首次在Microsoft.com上亮相。

Application Inspector与传统的静态分析工具不同,它不试图识别"好"或"坏"的模式;它只是根据400多条规则模式报告发现的特征,包括影响安全的特征,如加密的使用等。这在减少确定开源或其他组件功能所需的时间方面极为有用,通过直接检查源代码而不是依赖有限的文档或建议。

该工具支持扫描各种编程语言,包括C、C++、C#、Java、JavaScript、HTML、Python、Objective-C、Go、Ruby、PowerShell等更多语言,并可以扫描混合语言文件的项目。它支持生成HTML、JSON和文本格式的结果,默认输出为HTML报告,类似于此处所示。

appinspector-Features

请务必查看我们完整的项目wiki页面 https://Github.com/Microsoft/ApplicationInspector/wiki 以获取更多信息和帮助。

快速入门

获取Application Inspector

.NET工具(推荐)

  • 下载并安装.NET 6 SDK
  • 运行 dotnet tool install --global Microsoft.CST.ApplicationInspector.CLI

更多信息请参见wiki

平台依赖二进制文件

  • 通过选择发布页的Assets部分下所示的适用于所选操作系统的预构建包来下载Application Inspector。

运行Application Inspector

  • Nuget工具:appinspector analyze -s path/to/src
  • 特定平台:applicationinspector.cli.exe analyze -s path/to/src

目标

Microsoft Application Inspector帮助您从开始到部署阶段确保应用程序的安全。

设计选择 - 使您能够选择哪些组件满足您的需求,减少不必要或未知特性的占用,从而保持应用程序攻击面较小,同时帮助验证预期特性,如仅使用行业标准加密。

识别特性差异 - 检测组件版本之间的变化,这对于检测后门注入至关重要。 自动化安全合规检查 - 用于识别具有需要额外安全审查、批准或SDL合规的特性的组件,作为构建流程的一部分,或创建包含所有企业应用程序元数据的存储库。

贡献

我们有一个强大的默认特性检测规则起始基础。但仍有许多特性识别模式有待定义,我们邀请您提交您想看到的想法或尝试定义一些。这是一个切实影响开源生态系统的机会,提供一个每个人都可以使用的工具。更多信息请参阅wiki的规则部分。

正式发布

Application Inspector 现处于普通用户发布状态。您的反馈对我们很重要。如果您有兴趣贡献,请查看CONTRIBUTING.md。

Application Inspector 可作为命令行工具或NuGet包使用,支持Windows、Linux或MacOS。

ApplicationInspector CLI的特定平台二进制文件可在我们的GitHub发布页面上获取。

C#库在NuGet上以Microsoft.CST.ApplicationInspector.Commands的形式提供。

.NET全局工具在NuGet上以Microsoft.CST.ApplicationInspector.CLI的形式提供。

如果您使用.NET Core版本,您需要安装.NET 6.0或更高版本。更多信息请参阅JustRunIt.mdBuild.md文件。

CLI使用信息

> appinspector --help
ApplicationInspector.CLI 1.8.4-beta+976ee3cdd1
c Microsoft Corporation. 保留所有权利。

  analyze        检查源目录/文件/压缩文件(.tgz|zip)是否符合定义的特征

  tagdiff        比较两个源路径之间的唯一标签值

  exporttags     导出与指定规则相关的标签列表。不扫描源代码。

  verifyrules    验证自定义规则语法是否有效

  packrules      将多个规则文件合并为一个文件以便于分发

  help           显示特定命令的更多信息。

  version        显示版本信息。

示例:

命令帮助

要获取特定命令的帮助,请运行appinspector <command> --help

Analyze命令

Analyze命令是Application Inspector的主力。

简单默认分析

这将在当前目录中使用默认参数和规则生成分析的output.html。

appinspector analyze -s path/to/files

输出Sarif

appinspector analyze -s path/to/files -f sarif -o output.sarif

使用通配符排除文件

这将在当前目录中创建名为data.json的分析json输出,使用提供的通配符模式排除test.git文件夹中的所有文件。

appinspector analyze -s path/to/files -o data.json -f json -g **/tests/**,**/.git/**

其他使用信息

有关控制台界面使用的其他帮助,请参阅CLI使用

有关使用NuGet包的帮助,请参阅NuGet支持

构建说明

请参阅build.md

编辑推荐精选

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
下拉加载更多