Skip to content

Latest commit

 

History

History
133 lines (114 loc) · 6.23 KB

README_EN.md

File metadata and controls

133 lines (114 loc) · 6.23 KB

nacs: event-driven pentest scanner

[中文 Readme] | [English Readme]

Release Release

✨ Features

  • Detect if the target machine is alive
  • Service scan (regular & non-regular ports)
  • poc detection (xray & nuclei format)
  • Weak password blasting for services such as databases
  • Common Vulnerability Exploitation of Intranet

⭐️ Highlights

  • Log4j vulnerability detection of common components (such as spring) and common HTTP request headers image
  • Service scanning and utilization of unconventional ports (such as ssh on port 2222, etc.)
  • Retrieve available assets from fofa as a supplement (TODO)
  • Automatically identify the input box of a simple web page for weak password blasting and log4j detection (TODO)

Mechanism

Environment configuration
    Weak password configuration, public key to be written, bounced address, ceye's API, etc.
detect alive
    icmp ping
fingerprint scan
    Determine which port corresponds to which service, especially unconventional ports
Vulnerability management (sent to the corresponding module according to the fingerprint information)
    Detect or exploit non-web services that can be RCE (redis, EternalBlue, etc.)
    PoC scanning of web services, such as log4j
    Unauthorized and blasting of non-web services
    Auto-explosive login (TODO) for web services
    Key services OA, VPN, Weblogic, honeypot, etc.

Instructions

Quick start

sudo ./nacs -h "IP or IP segment" -o result.txt
sudo ./nacs -hf "File of IP or IP segment" -o result.txt
sudo ./nacs -u url(s) -o result.txt
sudo ./nacs -uf "File of url(s)" -o result.txt

Demo

  • (1) Add target IP: scan the 10.15.196.135 machine, manually add the password, and turn off the test of the reverse platform (ie not test log4j, etc.)

    sudo ./nacs -h 10.15.196.135 -passwordadd "xxx,xxx" -noreverse
    

    image It can be seen that nacs discovered the permission bypass vulnerability of nacos and successfully blasted each service

  • (2) Add the target url directly: Blast the ssh port of 10.211.55.7, add the username and password as test, and execute ifconfig after the blasting is successful; try the log4j vulnerability on a shooting range url

    sudo ./nacs -u "ssh://10.211.55.7:22,http://123.58.224.8:13099" -usernameadd test -passwordadd test -command ifconfig
    

    image It can be seen that the two log4j pocs are successfully detected, and the injection point is in the X-Api-Version field of the request header; the blasting of ssh is also successful

Common parameters

-o output log file
-np do not perform liveness detection, directly scan the port
-po use only these ports
-pa add these ports
-fscanpocpath The poc path of fscan is in the format "web/pocs/"
-nucleipocpath nuclei's poc path format is "xxx/pocs/**"
-nopoc do not perform poc detection, including xray and nuclei
-nuclei Use nuclei for detection (it is not strongly recommended to add this parameter, because nuclei has too many pocs)
-nobrute do not blast
-pocdebug print all information when poc probes
-brutedebug print all information when blasting
-usernameadd add username when blasting
-passwordadd add password when blasting
-noreverse do not use reverse platform
-ceyekey your own ceye token
-ceyedomain your own ceye domain

Reference

Inspired by the following excellent tools

TODO dynamic update

  • Automatically scan and collect assets from fofa to supplement the scan results
  • Support custom header for host collision, etc.
  • Improve the proxy function
  • Add progress bar
  • Support xrayV2
  • Supports the automatic generation of weak passwords, and dynamically supplements the explosive dictionary according to prefixes, suffixes, acquired information, etc.
  • Automatic exploitation of common Spring vulnerabilities
  • Simple web login service automatically detects interfaces and parameters to achieve blasting
  • ...

Disclaimer

This tool is only for legally pentest activities. In order to avoid malicious use, all the POCs included in this project are theoretical judgments of vulnerabilities, there is no vulnerability exploitation process, and no real attacks or exploits will be launched on the target. When using this tool for detection, you should ensure that the behavior complies with local laws and regulations and has obtained sufficient authorization. Do not scan unauthorized targets. If you have any illegal behavior in the process of using this tool, you shall bear the corresponding consequences by yourself, and we will not bear any legal and joint responsibility.

Stargazers over time

Visit

Visitor Count

Star

Stargazers over time