hacktricks/pentesting-web/account-takeover.md

151 lines
12 KiB
Markdown
Raw Normal View History

# Взлом облікового запису
2022-11-03 10:18:27 +00:00
{% hint style="success" %}
Вивчайте та практикуйте AWS Hacking:<img src="/.gitbook/assets/arte.png" alt="" data-size="line">[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)<img src="/.gitbook/assets/arte.png" alt="" data-size="line">\
Вивчайте та практикуйте GCP Hacking: <img src="/.gitbook/assets/grte.png" alt="" data-size="line">[**HackTricks Training GCP Red Team Expert (GRTE)**<img src="/.gitbook/assets/grte.png" alt="" data-size="line">](https://training.hacktricks.xyz/courses/grte)
2022-11-03 10:18:27 +00:00
<details>
2022-11-03 10:18:27 +00:00
<summary>Підтримка HackTricks</summary>
2024-02-03 12:22:53 +00:00
* Перевірте [**плани підписки**](https://github.com/sponsors/carlospolop)!
* **Приєднуйтесь до** 💬 [**групи Discord**](https://discord.gg/hRep4RUj7f) або [**групи Telegram**](https://t.me/peass) або **слідкуйте** за нами в **Twitter** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)**.**
* **Діліться хакерськими трюками, надсилаючи PR до** [**HackTricks**](https://github.com/carlospolop/hacktricks) та [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) репозиторіїв на GitHub.
2022-11-03 10:18:27 +00:00
</details>
{% endhint %}
2022-11-03 10:18:27 +00:00
2024-03-29 18:49:46 +00:00
## **Проблема авторизації**
2022-11-03 10:18:27 +00:00
Електронну пошту облікового запису слід спробувати змінити, і процес підтвердження **повинен бути перевірений**. Якщо він виявиться **слабким**, електронну пошту слід змінити на адресу жертви та підтвердити.
2022-11-03 10:18:27 +00:00
## **Проблема нормалізації Unicode**
2022-11-03 10:18:27 +00:00
1. Обліковий запис жертви `victim@gmail.com`
2. Слід створити обліковий запис, використовуючи Unicode\
2024-03-29 18:49:46 +00:00
наприклад: `vićtim@gmail.com`
2024-02-06 03:10:38 +00:00
Як пояснено в [**цьому виступі**](https://www.youtube.com/watch?v=CiIyaZ3x49c), попередню атаку також можна здійснити, зловживаючи сторонніми постачальниками ідентичності:
* Створіть обліковий запис у сторонньому постачальнику ідентичності з подібною електронною поштою до жертви, використовуючи деякий символ unicode (`vićtim@company.com`).
* Сторонній постачальник не повинен перевіряти електронну пошту.
* Якщо постачальник ідентичності перевіряє електронну пошту, можливо, ви зможете атакувати доменну частину, наприклад: `victim@ćompany.com` і зареєструвати цей домен, сподіваючись, що постачальник ідентичності згенерує ASCII-версію домену, поки платформа жертви нормалізує ім'я домену.
* Увійдіть через цього постачальника ідентичності на платформу жертви, яка повинна нормалізувати символ unicode і дозволити вам отримати доступ до облікового запису жертви.
Для отримання додаткових деталей зверніться до документа з нормалізації Unicode:
2022-11-03 10:18:27 +00:00
{% content-ref url="unicode-injection/unicode-normalization.md" %}
2022-11-03 10:18:27 +00:00
[unicode-normalization.md](unicode-injection/unicode-normalization.md)
{% endcontent-ref %}
2022-11-03 10:18:27 +00:00
2024-03-29 18:49:46 +00:00
## **Повторне використання токена скидання**
2022-11-03 10:18:27 +00:00
Якщо цільова система дозволяє **повторне використання посилання на скидання**, слід докласти зусиль для **пошуку додаткових посилань на скидання** за допомогою таких інструментів, як `gau`, `wayback` або `scan.io`.
2022-11-03 10:18:27 +00:00
## **Перед взломом облікового запису**
2022-11-03 10:18:27 +00:00
1. Електронну пошту жертви слід використовувати для реєстрації на платформі, і слід встановити пароль (слід спробувати підтвердити його, хоча відсутність доступу до електронних листів жертви може зробити це неможливим).
2. Слід дочекатися, поки жертва зареєструється, використовуючи OAuth, і підтвердить обліковий запис.
2024-03-29 18:49:46 +00:00
3. Сподіваємося, що звичайна реєстрація буде підтверджена, що дозволить отримати доступ до облікового запису жертви.
2024-02-06 03:10:38 +00:00
## **Неправильна конфігурація CORS для взлому облікового запису**
2022-11-03 10:18:27 +00:00
Якщо сторінка містить **неправильні конфігурації CORS**, ви можете **вкрасти чутливу інформацію** у користувача, щоб **взяти під контроль його обліковий запис** або змусити його змінити інформацію для авторизації з тією ж метою:
2022-11-03 10:18:27 +00:00
{% content-ref url="cors-bypass.md" %}
[cors-bypass.md](cors-bypass.md)
{% endcontent-ref %}
## **CSRF для взлому облікового запису**
2022-11-03 10:18:27 +00:00
Якщо сторінка вразлива до CSRF, ви можете змусити **користувача змінити свій пароль**, електронну пошту або аутентифікацію, щоб потім отримати до них доступ:
2022-11-03 10:18:27 +00:00
{% content-ref url="csrf-cross-site-request-forgery.md" %}
[csrf-cross-site-request-forgery.md](csrf-cross-site-request-forgery.md)
{% endcontent-ref %}
## **XSS для взлому облікового запису**
2022-11-03 10:18:27 +00:00
Якщо ви знайдете XSS в додатку, ви можете вкрасти куки, локальне сховище або інформацію зі сторінки, що може дозволити вам взяти під контроль обліковий запис:
2022-11-03 10:18:27 +00:00
{% content-ref url="xss-cross-site-scripting/" %}
[xss-cross-site-scripting](xss-cross-site-scripting/)
{% endcontent-ref %}
## **Те ж саме походження + куки**
2022-11-03 10:18:27 +00:00
Якщо ви знайдете обмежений XSS або захоплення піддомену, ви можете грати з куками (наприклад, фіксуючи їх), щоб спробувати скомпрометувати обліковий запис жертви:
2022-11-03 10:18:27 +00:00
{% content-ref url="hacking-with-cookies/" %}
[hacking-with-cookies](hacking-with-cookies/)
{% endcontent-ref %}
2024-03-29 18:49:46 +00:00
## **Атака на механізм скидання пароля**
2022-11-03 10:18:27 +00:00
{% content-ref url="reset-password.md" %}
[reset-password.md](reset-password.md)
{% endcontent-ref %}
## **Маніпуляція відповіддю**
2022-11-03 10:18:27 +00:00
Якщо відповідь аутентифікації можна **звести до простого булевого значення, просто спробуйте змінити false на true** і подивіться, чи отримаєте ви доступ.
2022-11-03 10:18:27 +00:00
## OAuth для взлому облікового запису
2022-11-03 10:18:27 +00:00
2023-02-16 18:26:56 +00:00
{% content-ref url="oauth-to-account-takeover.md" %}
[oauth-to-account-takeover.md](oauth-to-account-takeover.md)
2022-11-03 10:18:27 +00:00
{% endcontent-ref %}
## Впровадження заголовка Host
2024-02-06 03:10:38 +00:00
1. Заголовок Host змінюється після ініціації запиту на скидання пароля.
2024-03-29 18:49:46 +00:00
2. Заголовок проксі `X-Forwarded-For` змінюється на `attacker.com`.
3. Заголовки Host, Referrer і Origin одночасно змінюються на `attacker.com`.
4. Після ініціації скидання пароля та вибору повторної відправки електронної пошти використовуються всі три вищезгадані методи.
## Маніпуляція відповіддю
2024-02-06 03:10:38 +00:00
1. **Маніпуляція кодом**: Статус-код змінюється на `200 OK`.
2. **Маніпуляція кодом і тілом**:
* Статус-код змінюється на `200 OK`.
* Тіло відповіді змінюється на `{"success":true}` або на порожній об'єкт `{}`.
2024-02-06 03:10:38 +00:00
Ці техніки маніпуляції ефективні в сценаріях, де для передачі та отримання даних використовується JSON.
2024-02-06 03:10:38 +00:00
## Зміна електронної пошти поточної сесії
2024-02-06 03:10:38 +00:00
З [цього звіту](https://dynnyd20.medium.com/one-click-account-take-over-e500929656ea):
* Зловмисник запитує зміну своєї електронної пошти на нову.
* Зловмисник отримує посилання для підтвердження зміни електронної пошти.
* Зловмисник надсилає жертві посилання, щоб вона його клікнула.
* Електронна пошта жертви змінюється на вказану зловмисником.
* Зловмисник може відновити пароль і взяти під контроль обліковий запис.
Це також сталося в [**цьому звіті**](https://dynnyd20.medium.com/one-click-account-take-over-e500929656ea).
### Старі куки
Як пояснено [**в цьому пості**](https://medium.com/@niraj1mahajan/uncovering-the-hidden-vulnerability-how-i-found-an-authentication-bypass-on-shopifys-exchange-cc2729ea31a9), було можливим увійти в обліковий запис, зберегти куки як аутентифікований користувач, вийти, а потім увійти знову.\
При новому вході, хоча можуть бути згенеровані інші куки, старі знову почали працювати.
2024-02-06 03:10:38 +00:00
2024-03-29 18:49:46 +00:00
## Посилання
2022-11-03 10:18:27 +00:00
* [https://infosecwriteups.com/firing-8-account-takeover-methods-77e892099050](https://infosecwriteups.com/firing-8-account-takeover-methods-77e892099050)
* [https://dynnyd20.medium.com/one-click-account-take-over-e500929656ea](https://dynnyd20.medium.com/one-click-account-take-over-e500929656ea)
2022-11-03 10:18:27 +00:00
{% hint style="success" %}
Вивчайте та практикуйте AWS Hacking:<img src="/.gitbook/assets/arte.png" alt="" data-size="line">[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)<img src="/.gitbook/assets/arte.png" alt="" data-size="line">\
Вивчайте та практикуйте GCP Hacking: <img src="/.gitbook/assets/grte.png" alt="" data-size="line">[**HackTricks Training GCP Red Team Expert (GRTE)**<img src="/.gitbook/assets/grte.png" alt="" data-size="line">](https://training.hacktricks.xyz/courses/grte)
2022-11-03 10:18:27 +00:00
<details>
2022-11-03 10:18:27 +00:00
<summary>Підтримка HackTricks</summary>
2024-02-03 12:22:53 +00:00
* Перевірте [**плани підписки**](https://github.com/sponsors/carlospolop)!
* **Приєднуйтесь до** 💬 [**групи Discord**](https://discord.gg/hRep4RUj7f) або [**групи Telegram**](https://t.me/peass) або **слідкуйте** за нами в **Twitter** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)**.**
* **Діліться хакерськими трюками, надсилаючи PR до** [**HackTricks**](https://github.com/carlospolop/hacktricks) та [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) репозиторіїв на GitHub.
2022-11-03 10:18:27 +00:00
</details>
{% endhint %}