2016-11-17 5 views
0

Только метод GET работает все время, но всегда получает ошибку для PUT, POST и DELETE. Я попытался обновить отображение обработчика через web.config, а также под сайтом IIS. Первоначально я получал ошибку с кодом состояния 405 как метод не разрешен. Когда я изменил отображение Handler вОшибка для PUT, POST и DELETE RestAPI

<system.webServer> 
    <handlers> 
    <remove name="ExtensionlessUrlHandler-Integrated-4.0" /> 
    <remove name="OPTIONSVerbHandler" /> 
    <remove name="TRACEVerbHandler" /> 
    <remove name="WebDAV" /> 
    <remove name="ExtensionlessUrlHandler-Integrated-4.0" /> 
    <add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" /> 

    <remove name="ExtensionlessUrl-Integrated-4.0" /> 
    <add name="ExtensionlessUrl-Integrated-4.0" 
     path="*." 
     verb="GET,HEAD,POST,DEBUG,DELETE,PUT" 
     type="System.Web.Handlers.TransferRequestHandler" 
     preCondition="integratedMode,runtimeVersionv4.0" /> 
</handlers> 

<validation validateIntegratedModeConfiguration="false" /> 

<modules> 
    <remove name="ApplicationInsightsWebTracking" /> 
    <add name="ApplicationInsightsWebTracking" type="Microsoft.ApplicationInsights.Web.ApplicationInsightsHttpModule, Microsoft.AI.Web" preCondition="managedHandler" /> 
    <remove name="WebDAVModule"/> 
</modules> 

начал получать ошибку в 415, как "неподдерживаемый тип медиа" является repsonce Следуя за я получаю

{StatusCode: 415, ReasonPhrase: «неподдерживаемый Тип носителя »Версия: 1.1 Содержание: System.Net.Http.StreamContent, заголовки: { Cache-Control: нет кэша Pragma: нет кэша Сервер: Microsoft-IIS/8.5 X-Сеть САШ-Version: 4.0 .30319 X-Powered-B y: ASP.NET Дата: Чт, 17 Ноя 2016 16:44:52 GMT Тип контента: приложение/октет-поток; charset = utf-8 Истекает: -1 Содержание: 100 }}

. Ниже приведены мои API-коды

// PUT: api/CreditRequests/5 
    [ResponseType(typeof(void))] 
    public IHttpActionResult PutCreditRequest(Guid id, CreditRequest creditRequest) 
    { 
     if (!ModelState.IsValid) 
     { 
      return BadRequest(ModelState); 
     } 

     if (id != creditRequest.CreditRequestId) 
     { 
      return BadRequest(); 
     } 

     db.Entry(creditRequest).State = EntityState.Modified; 

     try 
     { 
      db.SaveChanges(); 
     } 
     catch (DbUpdateConcurrencyException) 
     { 
      if (!CreditRequestExists(id)) 
      { 
       return NotFound(); 
      } 
      else 
      { 
       throw; 
      } 
     } 

     return StatusCode(HttpStatusCode.NoContent); 
    } 

    // POST: api/CreditRequests 
    [ResponseType(typeof(CreditRequest))] 
    public IHttpActionResult PostCreditRequest(CreditRequest creditRequest) 
    { 
     if (!ModelState.IsValid) 
     { 
      return BadRequest(ModelState); 
     } 

     db.CreditRequests.Add(creditRequest); 

     try 
     { 
      db.SaveChanges(); 
     } 
     catch (DbUpdateException) 
     { 
      if (CreditRequestExists(creditRequest.CreditRequestId)) 
      { 
       return Conflict(); 
      } 
      else 
      { 
       throw; 
      } 
     } 

     return CreatedAtRoute("DefaultApi", new { id = creditRequest.CreditRequestId }, creditRequest); 
    } 

    // DELETE: api/CreditRequests/5 
    [ResponseType(typeof(CreditRequest))] 
    public IHttpActionResult DeleteCreditRequest(Guid id) 
    { 
     CreditRequest creditRequest = db.CreditRequests.Find(id); 
     if (creditRequest == null) 
     { 
      return NotFound(); 
     } 

     db.CreditRequests.Remove(creditRequest); 
     db.SaveChanges(); 

     return Ok(creditRequest); 
    } 

И я вызываю их, используя объект HttpClient. с кодом

string jsondata = JsonConvert.SerializeObject(item); 
      var content = new StringContent(jsondata, System.Text.Encoding.UTF8, "application/json"); 
      HttpResponseMessage response = null; 
      using (var client = GetFormattedHttpClient())// Adding basic authentication in HttpClientObject before using it. 
      { 
       if (IsNew == true) 
        response = client.PostAsync (_webUri, content).Result; 
       else if (IsNew == false) 
        response = client.PutAsync(_webUri, content).Result; 

      } 
      if (!response.IsSuccessStatusCode) 
           return false; 
      else 
      return true; 
+0

Где вы видите это использование? '[ResponseType (typeof (void))]' –

+0

Я тестирую метод POST для первого добавления записи в БД. и в случае PUT я фокусируюсь, чтобы получить StatusCode как NoContent –

+0

Удалить этот атрибут. Это не нужно. – Amy

ответ

0

Это работает для меня.

protected async Task<String> connect(String URL,WSMethod method,StringContent body) 
{ 
     try 
     { 

      HttpClient client = new HttpClient 
      { 
       Timeout = TimeSpan.FromSeconds(Variables.SERVERWAITINGTIME) 
      }; 
      if (await controller.getIsInternetAccessAvailable()) 
      { 
       if (Variables.CURRENTUSER != null) 
       { 
        var authData = String.Format("{0}:{1}:{2}", Variables.CURRENTUSER.Login, Variables.CURRENTUSER.Mdp, Variables.TOKEN); 
        var authHeaderValue = Convert.ToBase64String(Encoding.UTF8.GetBytes(authData)); 

        client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", authHeaderValue); 
       } 

       HttpResponseMessage response = null; 
       if (method == WSMethod.PUT) 
        response = await client.PutAsync(URL, body); 
       else if (method == WSMethod.POST) 
        response = await client.PostAsync(URL, body); 
       else 
        response = await client.GetAsync(URL); 

       .... 
} 
Смежные вопросы