مقدمة
لقد صادفت مؤخرًا موقفًا معتادًا للإنترنت - طلب كلاسيكي من أحد الأقارب للإدلاء بصوته لصالحه في نوع من التصويت. اتضح أن المحتالين "تم اختراقهم" من قبل المحتالين ، وكانت الروابط للتصويت على موارد التصيد.
أنا مغرم بالأمان ، لذلك قررت التحقق من أمان مورد التصيد الاحتيالي.
تم اختراق لوحة إدارة المخادعين بنجاح ، وكان هناك عدد من الحسابات المسروقة. تم نقل تسجيلات دخولهم إلى خدمة أمن VK ، بالإضافة إلى إرسال شكاوى "الإساءة" المقابلة إلى المسجلين والمضيفين.
والآن سأخبرك كيف وما هي لوحات التصيد كخدمة التي اتضح أنها ...
بدأ كل شيء كالمعتاد ، طلب من أحد الأقارب للإدلاء بصوته له في نوع من التصويت:
نسبي:
مرحبًا ، أريد فقط الفوز :) http://x-vote.ru/votes/701738#vote

في الواقع ، من المرجح أن يتجاهل مثل هذا الطلب ، ولكن من وجهة نظر الأمن ، كان هناك اهتمام بالتحقق من حالة السباق في التصويت نفسه - هل سيكون من الممكن لحساب واحد الإدلاء ببضعة أصوات في الواقع عن طريق إرسال العديد منهم في فترة زمنية قصيرة واحدة.
, . , , , Oauth , .

, , .
, Race Condition , , , , , - - .
, , , - , , , , / "" HTML+JS, Blind XSS. , — / .
xsshunter — . XSS, :
- url, ;
- IP;
- Cookie;
- Dom-;
… . , , , VPS.
, blind XSS- .

, XSS " " ( document.cookie).
, — "httpOnly", JS.
XSS , - API , (), .
, "" .
, , .
, , , — .


. bootstrap , , :
:

:

API:

IP.

, , :


:


, :



… .
API , , , , .., execute.getDialogsWithProfilesNewFixGroups.php, :
https://vk.com/dev/execute
.
— VK .
access-, , .
:
GET /method/execute.getDialogsWithProfilesNewFixGroups?access_token=****b750be150c961c******ace8d9dd54e448d5f5e5fd2******7e21388c497994536a740e3a45******&lang=ru&https=1&count=40&v=5.69 HTTP/1.1
Host: vk-api-proxy.xtrafrancyz.net
HTTP/1.1 200 OK
Date: Tue, 03 Mar 2020 09:57:08 GMT
Content-Type: application/json; charset=utf-8
Connection: close
Vary: Accept-Encoding
Server: vk-proxy
X-Powered-By: PHP/3.23359
Cache-Control: no-store
X-Frame-Options: DENY
Access-Control-Allow-Origin: *
Content-Length: 57453
{"response":{"a":{"count":271,"unread_dialogs":151,"items":[{"message":{"id":592***,"date":1583222677,"out":0,"user_id":14967****,"read_state":1,"title":"","body":" : 063725.","owner_ids":[]},"in_read":592***,"out_read":592***}
, . , — "" , . , + , , .
, , , , .
, , ?
-, , , , , : , , blind xss , VK Bo0oM, , , , .
complaint' . cloudflare', . , , , . - Cloudflare , https://www.cloudflare.com/abuse/form, — 1 url ¯ \ (ツ) / ¯
— 10 .

, , .
UPD: QIWI Yandex, .