Обход защиты CloudFlare C# xNet

CLAY
Оффлайн
Регистрация
25.01.17
Сообщения
763
Реакции
225
Репутация
292
  1. Итак для реализации брутов на некоторые сайты с защитой от CloudFlare пришлось как-то разбираться с этим делом, решил поделиться опытом, так что нам понадобится:

    1. Прямые руки
    2. Visual Studio 2008-2015

    Итак, первым делом тыкаем правой кнопочкой на проекте, управление пакетами NuGet, ищем и устанавливаем Jint, интерпритатор Js для c#

    Ну а далее код:
Код:
using (var req = new xNet.HttpRequest())
            {
                var con = "";
                var JSEngine = new Jint.Engine();
                var uri = new Uri("Сайт.ру");

                try
                {
                    req.Cookies = new CookieDictionary();
                    req.UserAgent = Http.ChromeUserAgent();
                    //Делаем запрос к сайту с защитой CF, вероятнее всего он выдаст ошибку 503 и отправимся мы в блок Catch
                    con = req.Get("Сайт.ру").ToString();
                }
                catch (Exception)
                {
                    //В переменную Con заносим ответ от сайта и парсим нужную инфу
                    con = req.Response.ToString();
                    var challenge = Regex.Match(con, "name=\"jschl_vc\" value=\"(\\w+)\"").Groups[1].Value;
                    var challenge_pass = Regex.Match(con, "name=\"pass\" value=\"(.+?)\"").Groups[1].Value;

                    var builder = Regex.Match(con, @"setTimeout\(function\(\){\s+(var t,r,a,f.+?\r?\n[\s\S]+?a\.value =.+?)\r?\n").Groups[1].Value;
                    builder = Regex.Replace(builder, @"a\.value =(.+?) \+ .+?;", "$1");
                    builder = Regex.Replace(builder, @"\s{3,}[a-z](?: = |\.).+", "");
                    builder = Regex.Replace(builder, @"[\n\\']", "");

                    //Выполняем JS
                    long solved = long.Parse(JSEngine.Execute(builder).GetCompletionValue().ToObject().ToString());
                    solved += uri.Host.Length; //add the length of the domain to it.

                    //Ждем 3 сек, иначе CF пошлет нас к хуям
                    Thread.Sleep(3000);

                    //Генерируем запрос
                    string cookie_url = string.Format("{0}://{1}/cdn-cgi/l/chk_jschl", uri.Scheme, uri.Host);
                    var uri_builder = new UriBuilder(cookie_url);
                    var query = HttpUtility.ParseQueryString(uri_builder.Query);
                    query["jschl_vc"] = challenge;
                    query["pass"] = challenge_pass;
                    query["jschl_answer"] = solved.ToString();
                    uri_builder.Query = query.ToString();

                    req.AllowAutoRedirect = false;
                    req.Referer = "Сайт.ру";

                    //Отправляем запрос
                    con = req.Get(uri_builder.Uri).ToString();

                    //После данного запроса спокойно можем шакалить по сайту
                    //Конечно же с данным экземпляром класса

                }
 
Сверху Снизу