开源工具系列4:Nuclei

news2024/11/15 22:37:51

前言

Nuclei 用于基于模板跨目标发送请求,从而实现零误报并提供对大量主机的快速扫描。Nuclei 提供对各种协议的扫描,包括 TCP、DNS、HTTP、SSL、File、Whois、Websocket、Headless 等。凭借强大而灵活的模板,Nuclei 可用于对各种安全检查进行建模。

Nuclei 是什么

  • Nuclei 是一种新型检测器,它摆脱了漏洞检测器的传统模型,允许通过非常简单且易于使用的 YAML 模板语法。

  • Nuclei 是一个检测器——它发送 HTTP/DNS 请求并检查一些响应以发现目标中的异常。

  • 用户可以轻松定义匹配器,它检查各种类型的模式(例如单词或正则表达式)的响应,提取器使用正则表达式从响应中提取一些内容。

  • 除了强大的匹配和提取功能外,用户还可以完全自定义发送的请求,从而完全控制请求/响应过程的每个部分。

Nuclei 有什么不同?

Nuclei 方法不是将检测器与漏洞检查捆绑在一起,而是专注于核心引擎,将创建漏洞检查的任务留给最终用户。

内核从一开始就被设计为非常可扩展,允许用户根据需要自定义一切。以下是 Nuclei 项目的核心目标:

  • 简单性:Nuclei 模板以非常易于阅读的yaml格式定义,这使非开发人员也可以轻松创建模板,而无需编写冗长的代码并对其进行调试以使其正常工作。

  • 灵活性:可以根据用户的喜好自定义模板。很少有事情是模板本身无法完成的。请求的每个部分都可以根据需要进行定制,并且可以完美运行。

  • 可移植性:核心目标之一是允许用户相互共享模板。每个模板都是一个文件,可以独立运行,无需任何先决条件。您所需要的只是一个核安装。通过这种方式,核概念增加了社区共享。

安装 Nuclei

一键安装

Nuclei需要go1.19才能安装成功。运行以下命令安装最新版本-Nuclei需要go1.19才能安装成功。运行以下命令以安装最新版本

go install -v github.com/projectdiscovery/nuclei/v2/cmd/nuclei@latest 
# brew 
brew install nuclei 
# docker 
docker pull projectdiscovery/nuclei:latest

下载安装包

当然也可以根据自己的需要,下载对应版本的安装包,进行离线安装,例如

tar -xzvf nuclei-linux-amd64.tar> mv nuclei-linux-amd64 /usr/bin/nuclei> nuclei -h

快速使用

Nuclei 是如何工作

如前文介绍的,Nuclei将创建漏洞检查的任务留给最终用户,用户需要通过yaml格式定义模板,之后基于模板进行漏洞扫描。

使用单一模板运行 Nuclei。

下列命令将会对 urls.txt 文件中列出的主机进行检测,并返回匹配的结果

nuclei -l urls.txt -t git-core.yaml -o results.txt

你还能够以标准输入(STDIN)的方式传递目标主机列表,下列命令同样可以对 urls.txt 文件中列出的主机进行检测,并返回匹配的结果

cat urls.txt | nuclei -t git-core.yaml -o results.txt

可以使用多个模板来执行

下列命令将能够使用 path-to-templates 目录中所有模板来对 urls.txt 文件中列出的主机进行检测,并返回匹配的结果

nuclei -l urls.txt -t "path-to-templates/*.yaml" -o results.txt

使用子检测器和其他类似工具自动化运行 Nuclei

subfinder -d hackerone.com -silent | httprobe | nuclei -t "path-to-templates/*.yaml" -o results.txt

可以执行 nuclei -h 来获取帮助信息,以下是部分帮助信息内容

Nuclei 的模板

nuclei-templates 是该 nuclei 项目的主要重点。它是一个社区构建的可用于核检测仪的模板集合。这些模板由 nuclei 用户提供,并经过精心策划,以清除长期以来一直是检测仪问题的误报、恶意代码等。

Nuclei 集成了对下载和管理 nuclei-templates 存储库的本地副本的支持。用户只需运行 nuclei -update-templates 即可在本地下载存储库。如果发布了更新,用户会收到通知,并且只需再次运行相同的命令即可更新其副本。

自定义模板

Nuclei支持通过.yaml文件来自动传递和执行多个模板任务,如需开发自定义模板,请参考 Github 模板项目地址:projectdiscovery/nuclei-templates

Nuclei 项目信息

Github 项目地址:

https://github.com/projectdiscovery/nuclei

Github 模板项目地址:

https://github.com/projectdiscovery/nuclei-templates

关于HummerRisk

HummerRisk 是开源的云原生安全平台,以非侵入的方式解决云原生的安全和治理问题,核心能力包括混合云的安全治理和K8S容器云安全检测。

Github 地址:https://github.com/HummerRisk/HummerRisk

Gitee 地址:https://gitee.com/hummercloud/HummerRisk

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/343005.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ArcGIS中ArcMap创建渔网Create Fishnet:生成指定大小的格网矢量文件

本文介绍在ArcMap软件中,通过“Create Fishnet”工具创建渔网,从而获得指定大小的矢量格网数据的方法。 首先,我们在创建渔网前,需要指定渔网覆盖的范围。这里我们就以四川省为例,在这一范围内创建渔网;其中…

2.13作业【设备树解析,按自己理解】

设备树定义 设备树(device tree是描述硬件信息的一种树形结构,设备书文件在linux内核启动后被内核解析。描述一个硬件设备信息的节点我们叫做设备节点,一个设备节点内部包含当前硬件的多个不同属性,相同节点不同属性是以链式结构存…

[Datawhale][CS224W]图神经网络(一)

目录一、导读1.1 当前图神经网络的难点1.2 图神经网络应用场景及对应的相关模型:1.3 图神经网络的应用方向及应用场景二、图机器学习、图神经网络编程工具参考文献一、导读 ​ 传统深度学习技术,如循环神经网络和卷积神经网络已经在图像等欧式数据和信号…

RoI Transformer论文翻译详解

Learning RoI Transformer for Oriented Object Detection in Aerial Images 0.摘要 航空图像中的目标检测是计算机视觉中一个活跃而又具有挑战性的任务,因为它具有鸟瞰视角、高度复杂的背景和变化的物体外观。特别是在航空图像中检测密集的目标时,基于…

01-RTOS

对于裸机而言,对于RTOS而言即:对于裸机,打游戏意味着不能回消息 回消息意味着不能打游戏对于RTOS 打游戏和裸机的切换只需要一个时间片节拍 1ms 从宏观来看 就是同时进行的两件事(但要在这两件事情的优先级一样的情况下&#xff0…

HTML面试题

HTML面试题部分知识点梳理 1.如何理解HTML语义化 让页面的内容结构化,便于对浏览器、引擎解析,易于阅读,便于维护理解,利于SEO。 2.H5的新特性 video/audio视频/音频canvas 绘画geolocation 定位 用于定位用户的位置WebSocket…

浅谈业务中台前端设计

做前端中台业务一年多的时间,有一些心得体会,和大家分享分享。 中台是什么中台业务的价值是什么做了哪些前端中台业务如何设计前端中台业务未来展望 中台是什么 百度百科的解释比较言简意赅:“中台,互联网术语,一般…

[数据库]表的约束

●🧑个人主页:你帅你先说. ●📃欢迎点赞👍关注💡收藏💖 ●📖既选择了远方,便只顾风雨兼程。 ●🤟欢迎大家有问题随时私信我! ●🧐版权:本文由[你帅…

【MySQL】MySQL 中 WITH 子句详解:从基础到实战示例

文章目录一、什么是 WITH 子句1. 定义2.用途二、WITH 子句的语法和用法1.语法2.使用示例3.优点三、总结"梦想不会碎,只有被放弃了才会破灭。" "Dreams wont break, only abandoned will shatter."一、什么是 WITH 子句 1. 定义 WITH 子句是 M…

LeetCode——1234. 替换子串得到平衡字符串

一、题目 有一个只含有 ‘Q’, ‘W’, ‘E’, ‘R’ 四种字符,且长度为 n 的字符串。 假如在该字符串中,这四个字符都恰好出现 n/4 次,那么它就是一个「平衡字符串」。 给你一个这样的字符串 s,请通过「替换一个子串」的方式&a…

Kubeadm搭建K8S

目录 一、部署步骤 1、实验环境 2、环境准备 3、所有节点安装Docker 4、 所有节点配置K8S源 5、所有节点安装kubeadm,kubelet和kubectl 6、部署 kubernetes Master 节点 7、token制作 8、k8s-node节点加入master节点 9、 master节点安装部署pod网络插件&a…

ChatGPT被玩疯,问“如果美国倒了,世界会怎样?”回答太吓人了

“ChatGPT”大火不见消停…… 最近这些天,想必大家的社交平台都刷爆了“ChatGPT”这个词吧? 作为OpenAI 的语言模型工具,它可以生成文本、回答问题、对话、摘要、翻译等。 特点是语言表达流畅,思维敏捷,可以回答复杂…

golang语言本身设计点总结

本文参考 1.golang的内存管理分配 golang的内存分配仿造Google公司的内存分配方法TCmalloc算法;她会把将内存请求分为两类,大对象请求和小对象请求,大对象为>32K的对象。 在了解golang的内存分配之前要知道什么事虚拟内存,虚拟内存是把磁盘作为全局…

设计模式之工厂模式详解和应用

目录1 工厂模式的历史由来2.简单工厂模式2.1 简单工厂模式定义2.2 简单工厂模式案例2.3 简单工厂模式相关源码2.4 简单工厂模式优缺点3 工厂方法模式3.1 工厂方法模式定义3.2 工厂方法模式案例3.3 工厂方法模式源码3.4 工厂方法模式优缺点4 抽象工厂模式4.1 抽象工厂模式定义4.…

【项目】基于SpringBoot+Freemarker+Mybatis+MySQL+LayUI实现CRM智能办公系统

这里写目录标题CRM基本概念CRM分类模块功能描述项目代码application-dev.yml部分页面代码CRM基本概念 圈内存在这么一句话:“世上本来没有 CRM,大家的生意越来越难做了,才有了 CRM。” 在同质化竞争时代,顾客资产尤为重要&#x…

CUDA流入门|参加CUDA线上训练营

CUDA 流的概念 CUDA流在加速应用程序方面起到重要的作用,他表示一个GPU的操作队列操作在队列中按照一定的顺序执行,也可以向流中添加一定的操作如核函数的启动、内存的复制、事件的启动和结束等,添加的顺序也就是执行的顺序一个流中的不同操…

SQLi-LABS-Challenges 0~28a解析

Less-1 GET-Error based - Single quotes - String 成功payload 1 union select 1,database(),user()%23 1 and 12 union select user(),1,database()-- 经测试 输出时会输出 3 列,所以此处 union select 需 select 三个数据 * 1‘ order by 4--时会报错&#…

OpenHarmony使用Socket实现一个TCP服务端详解

点击获取BearPi-HM_Nano源码 ,以D4_iot_tcp_server为例: 点击查看:上一篇关于socket udp实现的解析 查看 TCPServerTask 方法实现: static void TCPServerTask(void) {//连接WifiWifiConnect("TP-LINK_65A8",

场测|新能源整车通信功能性能,新能源整车环中国测试,整车2345G及bt,wifi测试

一套全新的用于测试车载通信功能的标准Verson.DH2.0.0 目的: 检测出不同平台、芯片及硬件配置的间的差异,找到凌驾于法规之上好产品配置。开创出行业领先的测试标准,并联合相关部门将地方标准升级成国家标准。推动行业产品的迭代将客户的用…

Ajax 学习笔记

一、Ajax1.1 什么是AjaxAJAX Asynchronous JavaScript and XML(异步的JavaScript和XML)。Ajax是一种在无需加载整个网页的情况下,能够更新部分网页的技术,它不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术…