Удаленный сервер возвратил ошибку 400 недопустимый запрос

I am getting The remote server returned an error: (400) Bad Request error while running the following code. I am trying to upload xml file on the http server. My xml file contains tag for the usern...

I am getting The remote server returned an error: (400) Bad Request error while running the following code.
I am trying to upload xml file on the http server.
My xml file contains tag for the username,password and domain and when i am trying to connect is manually i am able to connect it,but using same credentials when i am trying to connect it through this code, i am getting 400 Bad Request error.
Please suggest me how to overcome this issue.
Thanks
`

  public static void UploadHttp(string xml)     
    {

        string txtResults = string.Empty;
        try
        {
            string url = "http://my.server.com/upload.aspx ";
            HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(url);
            request.KeepAlive = false;
            request.SendChunked = true;
            request.AllowAutoRedirect = true;
            request.Method = "Post";
            request.ContentType = "text/xml";
            var encoder = new UTF8Encoding();
            var data = encoder.GetBytes(xml);
            request.ContentLength = data.Length;
            var reqStream = request.GetRequestStream();
            reqStream.Write(data, 0, data.Length);
            reqStream.Close();
            WebResponse response = null;
            response = request.GetResponse();
            var reader = new StreamReader(response.GetResponseStream());
            var str = reader.ReadToEnd();
        }
        catch (WebException ex)
        {
            if (ex.Status == WebExceptionStatus.ProtocolError)
            {
                HttpWebResponse err = ex.Response as HttpWebResponse;
                if (err != null)
                {
                    string htmlResponse = new StreamReader(err.GetResponseStream()).ReadToEnd();
                    txtResults = string.Format("{0} {1}", err.StatusDescription, htmlResponse);
                }
            }
            else
            {

            }
        }
        catch (Exception ex)
        {
            txtResults = ex.ToString();
        }
    }`

asked Jan 10, 2013 at 16:04

user1301587's user avatar

2

Are you sure you should be using POST not PUT?

POST is usually used with application/x-www-urlencoded formats. If you are using a REST API, you should maybe be using PUT? If you are uploading a file you probably need to use multipart/form-data. Not always, but usually, that is the right thing to do..

Also you don’t seem to be using the credentials to log in — you need to use the Credentials property of the HttpWebRequest object to send the username and password.

answered Jan 10, 2013 at 16:46

Ben's user avatar

BenBen

34.5k6 gold badges73 silver badges111 bronze badges

1

400 Bad request Error will be thrown due to incorrect authentication entries.

  1. Check if your API URL is correct or wrong. Don’t append or prepend spaces.
  2. Verify that your username and password are valid. Please check any spelling mistake(s) while entering.

Note: Mostly due to Incorrect authentication entries due to spell changes will occur 400 Bad request.

Nae's user avatar

Nae

13.4k5 gold badges54 silver badges78 bronze badges

answered Oct 14, 2015 at 9:33

tamil's user avatar

tamiltamil

311 bronze badge

1

What type of authentication do you use?
Send the credentials using the properties Ben said before and setup a cookie handler.
You already allow redirection, check your webserver if any redirection occurs (NTLM auth does for sure). If there is a redirection you need to store the session which is mostly stored in a session cookie.

answered Jan 10, 2013 at 16:57

YvesR's user avatar

YvesRYvesR

5,7146 gold badges45 silver badges70 bronze badges

//use «ASCII» or try with another encoding scheme instead of «UTF8».

using (StreamWriter postStream = new StreamWriter(request.GetRequestStream(), System.Text.Encoding.UTF8))
{
    postStream.Write(postData);
    postStream.Close();
}

answered Jan 20, 2022 at 11:59

Paras's user avatar

1

  • Remove From My Forums
  • Question

  • Hello all..

    I have builded a soap request.. but it’s still not working, can some one help me out..?

    Error:

    System.Net.WebException: The remote server returned an error: (400) Bad Request. 
     
       at System.Net.HttpWebRequest.GetResponse() 
       at CallReportsConsole.MainClass.Main(String[] args) in C:**ConsoleProgram.cs:line 57 
    The remote server returned an error: (400) Bad Request. 

    Code:

    using System; 
    using System.Net; 
    using System.IO; 
    using System.Text; 
    using System.Xml; 
     
    namespace CallReportsConsole 
     
        class MainClass 
        { 
             
     
            public static void Main(string[] args) 
            { 
                 
     
                try 
                { 
                    int username = 123456
                    string password = «wachtwoord»
     
                    //Create SOAP XML 
     
                    StringBuilder sbSoap = new StringBuilder(); 
     
                    //1. Build SOAP string 
                    sbSoap.Append(«<? xml version=»1.0″ encoding=»utf-8″ ?>«); 
                    sbSoap.Append(«<soap:Envelope xmlns:xsi=»http://www.w3.org/2001/XMLSchema-instance» xmlns:xsd=»http://www.w3.org/2001/XMLSchema» xmlns:soap=»http://schemas.xmlsoap.org/soap/envelope/»>n»); 
                    sbSoap.Append(«<soap:Body>n»); 
                    sbSoap.Append(» <GetProductSpecifications xmlns=»http://www.bascomputers.nl/»>n»); 
                    sbSoap.Append(«<customerID>» + username + «</customerID>n»); 
                    sbSoap.Append(«<password>» + password + «</password>n»); 
                    sbSoap.Append(«</GetProductSpecifications>n»); 
                    sbSoap.Append(«</soap:Body></soap:Envelope>«); 
     
                    string soapAction = «http://www.bascomputers.nl/GetProductSpecifications»
     
                    //2. Send XML to CDR server 
                    string cdrURL = «http://xtract.bascomputers.nl:4040/xtract.asmx»
                    HttpWebRequest req = (HttpWebRequest)WebRequest.Create(cdrURL); 
     
                    req.ContentType = «text/xml; charset=utf-8»
                    req.Accept = «text/xml»
                    req.Method = «POST»
                    req.ContentLength = sbSoap.Length; 
                    req.Headers.Add(«SOAPAction», soapAction); 
                    req.KeepAlive = false
     
                    Stream strm = req.GetRequestStream(); 
                    byte[] bytes = 
                    System.Text.Encoding.ASCII.GetBytes(sbSoap.ToString()); 
                    strm.Write(bytes, 0, bytes.Length); 
                    strm.Close(); 
     
                    //3. Get response & send back filename 
                    HttpWebResponse resp = (HttpWebResponse)req.GetResponse(); 
     
                    StreamReader r = new 
                    StreamReader(resp.GetResponseStream()); 
     
                    XmlTextReader xmlRead = new XmlTextReader(r); 
     
                    while (xmlRead.Read()) 
                    { 
                        Console.Write(xmlRead.Value.ToString()); 
                    } 
     
                    r.Close(); 
                    strm.Close(); 
     
                } 
     
                catch (WebException wex) 
                { 
                Console.Write(wex.ToString()); 
                Console.Write(wex.Message.ToString()); 
                } 
     
                catch (Exception ex) 
                { 
                Console.Write(ex.ToString()); 
                Console.Write(ex.Message.ToString()); 
                } 
                 
                Console.Read(); 
                 
            } 
        } 

Answers

  •  

    Use the following code.  

    try  

                {  
                    string soapRequest=  
                        «<soap:Envelope xmlns:xsi=’http://www.w3.org/2001/XMLSchema-instance’ xmlns:xsd=’http://www.w3.org/2001/XMLSchema’ xmlns:soap=’http://schemas.xmlsoap.org/soap/envelope/’>» + «n»  +  
                        «<soap:Body>  » + «n» +  
                        «<m:GetProductSpecifications xmlns:m=‘http://www.bascomputers.nl/’>»  + «n» +  
                        «<m:customerID>123456</m:customerID>«+ «n» +  
                        «<m:password>wachtwoord</m:password>» + «n» +  
                        «</m:GetProductSpecifications>»   + «n» +  
                        «</soap:Body>»   + «n» +  
                        «</soap:Envelope>» + «n» ;  
     
                        
                    string soapAction = «http://www.bascomputers.nl/GetProductSpecifications»;  
     
                    //2. Send XML to CDR server     
                    string cdrURL = «http://xtract.bascomputers.nl:4040/xtract.asmx»;  
                    HttpWebRequest req = (HttpWebRequest)WebRequest.Create(cdrURL);  
     
                    req.ContentType = «text/xml; charset=utf-8»;  
                    req.Accept = «text/xml»;  
                    req.Method = «POST»;  
                    //req.ContentLength = sbSoap.Length;  
                    req.Headers.Add(«SOAPAction», soapAction);  
                    req.KeepAlive = false;  
                   XmlDocument doc = new XmlDocument();    
                    doc.LoadXml(soapRequest);    
                    using (Stream strm = req.GetRequestStream())  
                    {  
                        doc.Save(strm);  
                    }  
                    //XmlDocument doc = new XmlDocument();    
                    //  doc.LoadXML(soapRequest);    
                        
     
                    //3. Get response & send back filename     
                    HttpWebResponse resp = (HttpWebResponse)req.GetResponse();  
     
                    //StreamReader r = new 
                    //StreamReader(resp.GetResponseStream());  
                    using (Stream respStm = resp.GetResponseStream())  
                    {  
                        using (StreamReader r = new StreamReader(respStm))  
                        {  
                              
                                string str = r.ReadToEnd();  
                             
                        }  
                    }  
                    
                } 

    Be Happy

    • Marked as answer by

      Tuesday, February 10, 2009 12:51 PM

Ошибка 400 Bad Request – это код ответа HTTP, который означает, что сервер не смог обработать запрос, отправленный клиентом из-за неверного синтаксиса. Подобные коды ответа HTTP отражают сложные взаимоотношения между клиентом, веб-приложением, сервером, а также зачастую сразу несколькими сторонними веб-сервисами. Из-за этого поиск причины появления ошибки может быть затруднён даже внутри контролируемой среды разработки.

В этой статье мы разберём, что значит ошибка 400 Bad Request (переводится как «Неверный запрос»), и как ее исправить

  • На стороне сервера или на стороне клиента?
  • Начните с тщательного резервного копирования приложения
  • Диагностика ошибки 400 Bad Request
  • Исправление проблем на стороне клиента
    • Проверьте запрошенный URL
    • Очистите соответствующие куки
    • Загрузка файла меньшего размера
    • Выйдите и войдите
  • Отладка на распространённых платформах
    • Откатите последние изменения
    • Удалите новые расширения, модули или плагины
    • Проверьте непреднамеренные изменения в базе данных
  • Поиск проблем на стороне сервера
    • Проверка на неверные заголовки HTTP
    • Просмотрите логи
  • Отладьте код приложения или скриптов

Все коды ответа HTTP из категории 4xx считаются ошибками на стороне клиента. Несмотря на это, появление ошибки 4xx не обязательно означает, что проблема как-то связана с клиентом, под которым понимается веб-браузер или устройство, используемое для доступа к приложению. Зачастую, если вы пытаетесь диагностировать проблему со своим приложением, можно сразу игнорировать большую часть клиентского кода и компонентов, таких как HTML, каскадные таблицы стилей (CSS), клиентский код JavaScript и т.п. Это также применимо не только к сайтам. Многие приложения для смартфонов, которые имеют современный пользовательский интерфейс, представляют собой веб-приложения.

С другой стороны, ошибка 400 Bad Request означает, что запрос, присланный клиентом, был неверным по той или иной причине. Пользовательский клиент может попытаться загрузить слишком большой файл, запрос может быть неверно сформирован, заголовки HTTP запроса могут быть неверными и так далее.

Мы рассмотрим некоторые из этих сценариев (и потенциальные решения) ниже. Но имейте в виду: мы не можем однозначно исключить ни клиент, ни сервер в качестве источника проблемы. В этих случаях сервер является сетевым объектом, генерирующим ошибку 400 Bad Request и возвращающим её как код ответа HTTP клиенту, но возможно именно клиент ответственен за возникновение проблемы.

Важно сделать полный бэкап вашего приложения, базы данных и т.п. прежде, чем вносить какие-либо правки или изменения в систему. Ещё лучше, если есть возможность создать полную копию приложения на дополнительном промежуточном сервере, который недоступен публично.

Подобный подход обеспечит чистую тестовую площадку, на которой можно отрабатывать все возможные сценарии и потенциальные изменения, чтобы исправить или иную проблему без угрозы безопасности или целостности вашего «живого» приложения.

Ошибка 400 Bad Request означает, что сервер (удалённый компьютер) не может обработать запрос, отправленный клиентом (браузером), вследствие проблемы, которая трактуется сервером как проблема на стороне клиента.

Существует множество сценариев, в которых ошибка 400 Bad Request может появляться в приложении. Ниже представлены некоторые наиболее вероятные случаи:

  • Клиент случайно (или намеренно) отправляет информацию, перехватываемую маршрутизатором ложных запросов. Некоторые веб-приложения ищут особые заголовки HTTP, чтобы обрабатывать запросы и удостовериться в том, что клиент не предпринимает ничего зловредного. Если ожидаемый заголовок HTTP не найден или неверен, то ошибка 400 Bad Request – возможный результат.
  • Клиент может загружать слишком большой файл. Большинство серверов или приложений имеют лимит на размер загружаемого файла, Это предотвращает засорение канала и других ресурсов сервера. Во многих случаях сервер выдаст ошибку 400 Bad Request, когда файл слишком большой и поэтому запрос не может быть выполнен.
  • Клиент запрашивает неверный URL. Если клиент посылает запрос к неверному URL (неверно составленному), это может привести к возникновению ошибки 400 Bad Request.
  • Клиент использует недействительные или устаревшие куки. Это возможно, так как локальные куки в браузере являются идентификатором сессии. Если токен конкретной сессии совпадает с токеном запроса от другого клиента, то сервер/приложение может интерпретировать это как злонамеренный акт и выдать код ошибки 400 Bad Request.

Устранение ошибки 400 Bad Request (попробуйте позже) лучше начать с исправления на стороне клиента. Вот несколько советов, что следует попробовать в браузере или на устройстве, которые выдают ошибку.

Наиболее частой причиной ошибки 400 Bad Request является банальный ввод некорректного URL. Доменные имена (например, internet-technologies.ru) нечувствительны к регистру, поэтому ссылка, написанная в смешанном регистре, такая как interNET-technologies.RU работает так же, как и нормальная версия в нижнем регистре internet-technologies.ru. Но части URL, которые расположены после доменного имени, чувствительными к регистру. Кроме случаев, когда приложение/сервер специально осуществляет предварительную обработку всех URL и переводит их в нижний регистр перед исполнением запроса.

Важно проверять URL на неподходящие специальные символы, которых в нем не должно быть. Если сервер получает некорректный URL, он выдаст ответ в виде ошибки 400 Bad Request.

Одной из потенциальных причин возникновения ошибки 400 Bad Request являются некорректные или дублирующие локальные куки. Файлы куки в HTTP – это небольшие фрагменты данных, хранящиеся на локальном устройстве, которые используются сайтами и веб-приложениями для «запоминания» конкретного браузера или устройства. Большинство современных веб-приложений использует куки для хранения данных, специфичных для браузера или пользователя, идентифицируя клиента и позволяя делать следующие визиты быстрее и проще.

Но куки, хранящие информацию сессии о вашем аккаунте или устройстве, могут конфликтовать с другим токеном сессии от другого пользователя, выдавая кому-то из вас (или вам обоим) ошибку 400 Bad Request.

В большинстве случаев достаточно рассматривать только ваше приложение в отношении файлов куки, которые относятся к сайту или веб-приложению, выдающему ошибку 400 Bad Request.

Куки хранятся по принципу доменного имени веб-приложения, поэтому можно удалить только те куки, которые соответствуют домену сайта, сохранив остальные куки не тронутыми. Но если вы не знакомы с ручным удалением определённых файлов куки, гораздо проще и безопаснее очистить сразу все файлы куки.

Это можно сделать разными способами в зависимости от браузера, который вы используете:

  • Google Chrome;
  • Internet Explorer;
  • Microsoft Edge;
  • Mozilla Firefox;
  • Safari.

Если вы получаете ошибку 400 Bad Request при загрузке какого-либо файла, попробуйте корректность работы на меньшем по размеру файле, Это включает в себя и «загрузки» файлов, которые не загружаются с вашего локального компьютера. Даже файлы, отправленные с других компьютеров, считаются «загрузками» с точки зрения веб-сервера, на котором работает ваше приложение.

Попробуйте выйти из системы и войти обратно. Если вы недавно очистили файлы куки в браузере, это приводит к автоматическому выходу из системы при следующей загрузке страницы. Попробуйте просто войти обратно, чтобы посмотреть, заработала ли система корректно.

Также приложение может столкнуться с проблемой, связанной с вашей предыдущей сессией, являющейся лишь строкой, которую сервер посылает клиенту, чтобы идентифицировать клиента при будущих запросах. Как и в случае с другими данными, токен сессии (или строка сессии) хранится локально на вашем устройстве в файлах куки и передаётся клиентом на сервер при каждом запросе. Если сервер решает, что токен сессии некорректен или скомпрометирован, вы можете получить ошибку 400 Bad Request.

В большинстве веб-приложений выход повторный вход приводит к перегенерации локального токена сессии.

Если вы используете на сервере распространённые пакеты программ, которые выдают ошибку 400 Bad Request, изучите стабильность и функциональность этих платформ. Наиболее распространённые системы управления контентом, такие как WordPress, Joomla! и Drupal, хорошо протестированы в своих базовых версиях. Но как только вы начинаете изменять используемые ими расширения PHP, очень легко спровоцировать непредвиденные проблемы, которые выльются в ошибку 400 Bad Request.

Если вы обновили систему управления контентом непосредственно перед появлением ошибки 400 Bad Request, рассмотрите возможность отката к предыдущей версии, которая была установлена, как самый быстрый и простой способ убрать ошибку 400 bad request.

Аналогично, любые расширения или модули, которые были обновлены, могут вызывать ошибки на стороне сервера, поэтому откат к предыдущим версиям этих расширений также может помочь.

Но в некоторых случаях CMS не предоставляют возможности отката к предыдущим версиям. Так обычно происходит с популярными платформами, поэтому не бойтесь, если вы не можете найти простой способ вернуться к использованию старой версии той или иной программной платформы.

В зависимости от конкретной CMS, которую использует приложение, имена этих компонентов будут различаться. Но во всех системах они служат одной и той же цели: улучшение возможностей платформы относительно её стандартной функциональности.

При этом имейте в виду, что расширения могут так или иначе получать полный контроль над системой, вносить изменения в код PHP, HTML, CSS, JavaScript или базу данных. Поэтому мудрым решением может быть удаление любых новых расширений, которые были недавно добавлены.

Даже если удалили расширение через панель управления CMS, это не гарантирует, что внесенные им изменения были полностью отменены. Это касается многих расширений WordPress, которым предоставляется полный доступ к базе данных.

Расширение может изменить записи в базе данных, которые «не принадлежат» ему, а созданы и управляются другими расширениями (или даже самой CMS). В подобных случаях модуль может не знать, как откатить назад изменения, внесенные в записи базы данных.

Я лично сталкивался с такими случаями несколько раз. Поэтому лучшим путём будет открыть базу данных и вручную просмотреть таблицы и записи, которые могли быть изменены расширением.

Если вы уверены, что ошибка 400 Bad Request не связана с CMS, вот некоторые дополнительные советы, которые могут помочь найти проблему на стороне сервера.

Ошибка, которую вы получаете от приложения, является результатом недостающих или некорректных специальных заголовков HTTP, которые ожидает получить приложение или сервер. В подобных случаях нужно проанализировать заголовки HTTP, которые отправляются на сторону сервера.

Почти любое веб-приложение будет вести логи на стороне сервера. Они представляют собой историю того, что делало приложение. Например, какие страницы были запрошены, к каким серверам оно обращалось, какие результаты предоставлялись из базы данных и т.п.

Логи сервера относятся к оборудованию, на котором выполняется приложение, и зачастую представляют собой детали о статусе подключённых сервисов или даже о самом сервере. Поищите в интернете “логи [ИМЯ_ПЛАТФОРМЫ]”, если вы используете CMS, или “логи [ЯЗЫК_ПРОГРАММИРОВАНИЯ]” и “логи [ОПЕРАЦИОННАЯ_СИСТЕМА]”, если у вас собственное приложение, чтобы получить подробную информацию по поиску логов.

Если это не помогло, проблема может быть в исходном коде, который выполняется внутри приложения. Попытайтесь диагностировать, откуда может исходить проблема, отлаживая приложение вручную и параллельно просматривая логи приложения и сервера.

Создайте копию всего приложения на локальном устройстве для разработки и пошагово повторите тот сценарий, который приводил к возникновению ошибки 400 Bad Request. А затем просмотрите код приложения в тот момент, когда что-то пойдёт не так.

Независимо от причины возникновения ошибки, даже если вам удалось исправить её в этот раз, появление в вашем приложении такой проблемы — это сигнал для того, чтобы внедрить инструмент обработки ошибок, который поможет автоматически обнаруживать их и оповещать в момент возникновения.

Понравилась статья? Поделить с друзьями:
  • Уделять внимание лексическая ошибка
  • Удаленный компьютер не отвечает на подключения через порт 443 как исправить
  • Уделить внимание это лексическая ошибка
  • Удаленный вызов процедур rpc как изменить
  • Уаз патриот ошибка abs