Http-триггеры в функциях Azure - сериализация объектов в Camelcase
Я создал HttpTriggered Azure функцию, которая возвращает ответ в заглавном случае. Как я могу преобразовать это в случай верблюда?
return feedItems != null
? req.CreateResponse(HttpStatusCode.OK, feedItems
: req.CreateErrorResponse(HttpStatusCode.NotFound, "No news articles were found");
Приведенный выше код дает мне прописную букву. Код ниже дает мне ошибку трассировки стека
return feedItems != null
? req.CreateResponse(
HttpStatusCode.OK,
feedItems,
new JsonMediaTypeFormatter
{
SerializerSettings = new JsonSerializerSettings
{
Formatting = Formatting.Indented,
ContractResolver = new CamelCasePropertyNamesContractResolver()
}
})
: req.CreateErrorResponse(HttpStatusCode.NotFound, "No news articles were found");
Трассировки стека
Microsoft.Azure.WebJobs.Host.FunctionInvocationException : Exception while executing function: NewsFeedController ---> System.MissingMethodException : Method not found: 'Void System.Net.Http.Formatting.BaseJsonMediaTypeFormatter.set_SerializerSettings(Newtonsoft.Json.JsonSerializerSettings)'.
at Juna.Zone.NewsFeed.Aggregator.NewsFeedController.Run(HttpRequestMessage req,TraceWriter log)
at lambda_method(Closure ,NewsFeedController ,Object[] )
at Microsoft.Azure.WebJobs.Host.Executors.MethodInvokerWithReturnValue`2.InvokeAsync(TReflected instance,Object[] arguments)
at async Microsoft.Azure.WebJobs.Host.Executors.FunctionInvoker`2.InvokeAsync[TReflected,TReturnValue](Object instance,Object[] arguments)
at async Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.InvokeAsync(IFunctionInvoker invoker,ParameterHelper parameterHelper,CancellationTokenSource timeoutTokenSource,CancellationTokenSource functionCancellationTokenSource,Boolean throwOnTimeout,TimeSpan timerInterval,IFunctionInstance instance)
at async Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.ExecuteWithWatchersAsync(IFunctionInstance instance,ParameterHelper parameterHelper,TraceWriter traceWriter,CancellationTokenSource functionCancellationTokenSource)
at async Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.ExecuteWithLoggingAsync(??)
at async Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.ExecuteWithLoggingAsync(??)
End of inner exception
at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()
at async Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.ExecuteWithLoggingAsync(??)
at async Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.TryExecuteAsync(IFunctionInstance functionInstance,CancellationToken cancellationToken)
at Microsoft.Azure.WebJobs.Host.Executors.ExceptionDispatchInfoDelayedException.Throw()
at async Microsoft.Azure.WebJobs.JobHost.CallAsync(??)
at async Microsoft.Azure.WebJobs.Script.ScriptHost.CallAsync(String method,Dictionary`2 arguments,CancellationToken cancellationToken)
at async Microsoft.Azure.WebJobs.Script.WebHost.WebScriptHostManager.HandleRequestAsync(FunctionDescriptor function,HttpRequestMessage request,CancellationToken cancellationToken)
at async Microsoft.Azure.WebJobs.Script.Host.FunctionRequestInvoker.ProcessRequestAsync(HttpRequestMessage request,CancellationToken cancellationToken,WebScriptHostManager scriptHostManager,WebHookReceiverManager webHookReceiverManager)
at async Microsoft.Azure.WebJobs.Script.WebHost.Controllers.FunctionsController.<>c__DisplayClass3_0.<ExecuteAsync>b__0(??)
at async Microsoft.Azure.WebJobs.Extensions.Http.HttpRequestManager.ProcessRequestAsync(HttpRequestMessage request,Func`3 processRequestHandler,CancellationToken cancellationToken)
at async Microsoft.Azure.WebJobs.Script.WebHost.Controllers.FunctionsController.ExecuteAsync(HttpControllerContext controllerContext,CancellationToken cancellationToken)
at async System.Web.Http.Dispatcher.HttpControllerDispatcher.SendAsync(HttpRequestMessage request,CancellationToken cancellationToken)
at async System.Web.Http.Dispatcher.HttpControllerDispatcher.SendAsync(HttpRequestMessage request,CancellationToken cancellationToken)
at async System.Web.Http.Cors.CorsMessageHandler.SendAsync(HttpRequestMessage request,CancellationToken cancellationToken)
at async Microsoft.Azure.WebJobs.Script.WebHost.Handlers.WebScriptHostHandler.SendAsync(HttpRequestMessage request,CancellationToken cancellationToken)
at async Microsoft.Azure.WebJobs.Script.WebHost.Handlers.SystemTraceHandler.SendAsync(HttpRequestMessage request,CancellationToken cancellationToken)
at async System.Web.Http.HttpServer.SendAsync(HttpRequestMessage request,CancellationToken cancellationToken)
2 ответа
Вы можете использовать параметр HttpConfiguration в функции CreateResponse следующим образом
HttpConfiguration config = new HttpConfiguration();
config.Formatters.JsonFormatter.SerializerSettings.ContractResolver = new CamelCasePropertyNamesContractResolver();
config.Formatters.JsonFormatter.UseDataContractJsonSerializer = false;
var response = req.CreateResponse(HttpStatusCode.OK, data, config);
Вы собираетесь добавить ниже, используя заявления
using Newtonsoft.Json.Serialization;
using System.Web.Http;
Вы также можете использовать JsonObjectAttribute от Newtonsoft, если вы не возвращаете анонимные классы, чтобы настроить стратегию именования, которую использует Newtonsoft Json. Преимущество этого заключается в том, что он работает как для сериализации, так и для десериализации.
Пример класса:
using Newtonsoft.Json;
using Newtonsoft.Json.Serialization;
[JsonObject(NamingStrategyType = typeof(CamelCaseNamingStrategy))]
public class FeedItems {
public string Name { get; set; } = string.Empty;
public int Quantity { get; set; } = 0;
public string OtherProperty { get; set; } = string.Empty;
}
Затем в вашем HTTP-триггере или любом другом, который использует Newtonsoft для сериализации (то есть не будет работать с сериализатором Microsoft DataContract):
FeedItems feedItems = new feedItems {
Name = "Something",
Quantity = 5,
OtherProperty = "This only exists to show a property with two capitals"
};
req.CreateResponse(HttpStatusCode.OK, feedItems);
Класс может использоваться одинаково хорошо для сериализации и десерализации объектов, как полезные нагрузки Azure Service Bus внутри объекта BrokeredMessage. Меньшая нагрузка, чем у XML (есть максимальные ограничения на размер сообщения), и удобство чтения при использовании Service Bus Explorer для решения проблем, а не двоичного.
Добавьте атрибут JsonPropertyAttribute к свойствам и включите Json.NET через #r "Newtonsoft.Json" в верхней части файла.
#r "Newtonsoft.Json"
using Newtonsoft.Json;
И украсить свойства
[JsonProperty(PropertyName = "name" )]
public string Name { get; set; }
[JsonProperty(PropertyName = "otherProp" )]
public string OtherProp { get; set; }