Только метод 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;
Где вы видите это использование? '[ResponseType (typeof (void))]' –
Я тестирую метод POST для первого добавления записи в БД. и в случае PUT я фокусируюсь, чтобы получить StatusCode как NoContent –
Удалить этот атрибут. Это не нужно. – Amy