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

编辑推荐精选

问小白

问小白

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

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

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

Transly

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

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

讯飞智文

讯飞智文

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

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

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

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

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

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

下拉加载更多