Мне нужно опубликовать информацию о вебхуке в моей базе данных. Это достаточно просто, и я могу это сделать, но у меня возникают проблемы с обновлением позиции, которая уже была вставлена в базу данных. Я подумал, что могу изменить пост, который у меня есть, на пут, но это не добавит новых записей. Я попытался сделать решение с помощью этого кода.
var responseString7 = await url
.GetAsync()
.ConfigureAwait(true);
if (responseString7.IsSuccessStatusCode)
{
var responseString = await url
.WithHeader("Accept", "application/json")
.PutJsonAsync(new
{
trackingNumber = stuff.result.tracking_code,
EPTrackingStatus = stuff.result.status,
EPStatusDetails = stuff.result.status_detail,
EPUpdatedAt = stuff.result.updated_at
})
.ReceiveString();
}
else
{
var responseString3 = await "url you cant see"
.WithHeader("Accept", "application/json")
.PostJsonAsync(new
{
trackingNumber = stuff.result.tracking_code,
EPTrackingStatus = stuff.result.status,
EPStatusDetails = stuff.result.status_detail,
EPUpdatedAt = stuff.result.updated_at
})
.ReceiveString();
Это решение будет PUT, но не POST. Есть ли более простой способ сделать это?
Что вы подразумеваете под запуском с помощью POST? Вы имеете в виду, выполняется ли инструкция else? Или вы имеете в виду, когда я только что использовал Put, и он не создал новую позицию.
Вы сказали: «Это решение будет PUT, но не POST» ... так что, предположительно, возникает ошибка, когда вы пытаетесь POST? Если Put работает, нам не нужно сосредотачиваться на этом. (PS добавляет ли Put новую строку или нет, зависит от сервера. Соглашение в API-интерфейсах стиля REST/CRUD заключается в том, что POST создает новую запись, а PUT обновляет запись, но это просто соглашение. Сервер может делать все, что угодно. на самом деле нравится)
Или, может быть, я просто неправильно понял вас. Сначала вы говорите, что у вас возникли проблемы с обновлением существующей позиции. Затем вы говорите «но это не будет добавлять новые записи». Но, конечно, если вы хотите обновить, то не создавать новые записи - это хорошо?? Я не знаю, правильно ли вы сформулировали вопрос, но вы, кажется, немного запутались в том, чего вы на самом деле хотите достичь, или в чем проблема. Вы можете уточнить?
Спасибо за помощь! Чтобы уточнить часть, где я сказал, что у меня возникли проблемы с обновлением позиций, я был глуп и опечатался, поэтому, пожалуйста, игнорируйте эту часть. Вот проблема сформулирована как можно лучше. Моя программа получает вызовы веб-перехватчика из нескольких заказов, и мне нужно поместить информацию о веб-перехватчике, отправляемую мне, в мою базу данных. Проблема в том, что я не могу делать повторяющиеся записи для заказов с одинаковым идентификатором, поэтому я должен делать отдельные сообщения или звонить в зависимости от того, есть ли уже запись с этим идентификатором. По какой-то причине приведенный выше код только помещает запрос.
то есть вы имеете в виду, что он никогда не входит в блок else для попытки POST? Если это так, я ожидаю, что это потому, что SuccessStatusCode всегда истинен. Я не знаю, что должен возвращать этот URL-адрес GetAsync, но я ожидаю, что код состояния HTTP всегда будет успешным, даже если запрос не вернул результатов. Отсутствие результатов не означает технический сбой фактического запроса. Вам нужно проверить содержимое ответа, чтобы узнать, каков был результат с точки зрения возвращенных данных.





Flurl ведет себя иначе (по умолчанию), чем HttpClient. относительно ошибок. Если он попадает в ответ, отличный от 2xx, он выбрасывает. Таким образом, он не попадает в ваш блок else, потому что сначала выдается исключение. Самый простой способ исправить ваш код — отключить это поведение:
url.AllowAnyHttpStatus().GetAsync();
В следующем вызове, если все, кроме глагола, одинаково в двух случаях (URL, заголовок, данные), вы можете немного упростить это, используя SendJsonAsync Flurl, где вы указываете HTTP-глагол в качестве переменной.
var method = getResponse.IsSuccessStatusCode ? HttpMethod.Put : HttpMethod.Post;
var responseString3 = await url
.WithHeader(...)
.SendJsonAsync(method, new { ... })
.ReceiveString();
Вау, я не могу поверить, что .AllowAnyHttpStatus() исправил это, спасибо!
Кроме того, я не уверен, что вторая часть кода будет работать с моим кодом. POST и PUT требуют разных URL-адресов
Ах. Ну, вы всегда можете добавить var url = getResponse.IsSuccessStatusCode ? .... Или не. Полное суждение, просто кажется, что там может быть место для сокращения кода.
Что значит "не будет"? Что именно происходит, когда вы запускаете его с помощью POST? Возможно, вы получаете какой-то ответ об ошибке от сервера?