У меня есть существующая служба Web API 2 и вам нужно изменить один из методов, чтобы использовать пользовательский объект в качестве другого параметра, в настоящее время метод имеет один параметр, который является простой строкой, исходящей из URL-адреса. После добавления пользовательского объекта в качестве параметра я получаю 415 неподдерживаемый тип носителя при вызове службы из приложения .NET windows. Интересно, что я могу успешно вызвать этот метод с помощью javascript и метода jQuery ajax.
Метод службы Web API 2 выглядит следующим образом:
<HttpPost>
<HttpGet>
<Route("{view}")>
Public Function GetResultsWithView(view As String, pPaging As Paging) As HttpResponseMessage
Dim resp As New HttpResponseMessage
Dim lstrFetchXml As String = String.Empty
Dim lstrResults As String = String.Empty
Try
'... do some work here to generate xml string for the response
'// write xml results to response
resp.Content = New StringContent(lstrResults)
resp.Content.Headers.ContentType.MediaType = "text/xml"
resp.Headers.Add("Status-Message", "Query executed successfully")
resp.StatusCode = HttpStatusCode.OK
Catch ex As Exception
resp.StatusCode = HttpStatusCode.InternalServerError
resp.Headers.Add("Status-Message", String.Format("Error while retrieving results from view {0}: {1}", view, ex.Message))
End Try
Return resp
End Function
Метод допускает как POST
, так и GET
, потому что объект Paging
не является обязательным. Если я вызываю этот метод с запросом GET
, он работает.
И простой клиентский код .NET, вызывающий службу, выглядит следующим образом:
Dim uri As String = BASE_URI + "fetch/someview"
Dim resp As HttpWebResponse
Dim sr As StreamReader
Dim lstrResponse As String
Dim reqStream As Stream
Dim bytData As Byte()
Dim req As HttpWebRequest = WebRequest.Create(uri)
Dim lstrPagingJSON As String
Dim lPaging As New Paging
Try
lPaging.Page = 1
lPaging.Count = 100
lPaging.PagingCookie = ""
req.Method = "POST"
lstrPagingJSON = JsonSerializer(Of Paging)(lPaging)
bytData = Encoding.UTF8.GetBytes(lstrPagingJSON)
req.ContentLength = bytData.Length
reqStream = req.GetRequestStream()
reqStream.Write(bytData, 0, bytData.Length)
reqStream.Close()
req.ContentType = "application/json"
resp = req.GetResponse()
sr = New StreamReader(resp.GetResponseStream, Encoding.UTF8)
lstrResponse = sr.ReadToEnd
'// do something with the response here
Catch exweb As WebException
txtOutput.AppendText("Error during request: " + exweb.Message)
Catch ex As Exception
txtOutput.AppendText(String.Format("General error during request to {0}: {1}", uri, ex.Message))
End Try
Клиент .NET работает на платформе 4.5, а служба - на платформе 4.5.2. Ошибка выводится на строку resp = req.GetResponse()
. Некоторые вещи, которые я уже пробовал:
- на клиенте, установите для параметра
req.Accept
значение "application/xml" или "Текст/XML" - в методе службы, удалите строку `resp.Content.Headers.ContentType.MediaType = "text/xml"
- заменить содержимое ответа XML на какой-то статический JSON, попытался исключить любые проблемы с отправкой в JSON по запросу и получить XML обратно в ответ
До сих пор я получаю тот же ответ на ошибку 415 независимо от того, что я пытаюсь сделать.
Я упомянул об этом, когда вызывается из javascript, здесь работает мой ajax-вызов:
$.ajax({
headers: {},
url: "api/fetch/someview",
type: "POST",
data: "{Count:100,Page:1,PagingCookie:\"\"}",
contentType: "application/json; charset=utf-8",
dataType: "xml",
success: function (data) {
alert("call succeeded");
},
failure: function (response) {
alert("call failed");
}
});
На стороне обслуживания ничего не происходит с конфигурацией маршрута или чем-то еще, это почти все готовые Web-API 2. Я знаю, что маршрутизация работает, вызовы правильно маршрутизируются в метод, они не собираются куда-то еще неожиданно, так что мне не хватает в .NET-клиенте? Любая помощь очень ценится!
--- UPDATE ---
Я попытался создать совершенно новую службу веб-API, чтобы исключить любые возможные проблемы с существующей службой, я создал контроллер с единственным методом, который принимает в качестве параметра пользовательский объект. Затем я попытался называть это из .NET-клиента и получил ту же ошибку. Я также пытался использовать WebClient вместо HttpWebRequest, но все равно получаю ту же ошибку. Это также то, что ранее работало для меня с веб-API (до веб-API 2).
--- UPDATE ---
Я также попытался создать новое веб-приложение с использованием Web API 1, когда я вызываю это с помощью POST, мой комплексный параметр объекта теперь имеет значение null. У меня есть еще одна веб-служба, работающая с веб-интерфейсом API 1 и проверенная, что я все еще могу успешно ее разрешить с помощью сложных объектов. Независимо от моей проблемы, это похоже на что-то с JSON, проходящим между клиентом и сервером. Я проверил JSON, который я отправляю, и его значение действительно, определение объекта также является точным совпадением между клиентом и сервером, поэтому JSON должен быть проанализирован сервером.