-
Notifications
You must be signed in to change notification settings - Fork 1.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Issue with default Newtonsoft Serializer #1510
Comments
Run into the same issue during migration of project from net 3.1 to 6.0 |
as a workaround Can be revert after the AddOcelot()
|
Hi @WajahatAliAbid ! I hope your problem will be resolved by the linked PR in Development, right? |
@raman-m Thank you. I went through the pull request and it certainly seems to solve the problem. Looking forward to the new release. |
…peline building via the IMvcCoreBuilder interface (#1655) * AddOcelot support custom mvc builder. * Fix SA1503 : The opening and closing braces for a C# statement have been omitted. * Fix SA1135 : A using directive is not qualified. * Add AddDefaultAspNetServices method. Remove anonymous delegate. * Make method names shorter * add unit test for AddOcelotUsingBuilder * Sort Usings * Refactor integration test for the case with AddOcelotUsingBuilder * Update OcelotBuilder.cs * Update gettingstarted.rst Fix target framework as net7.0 * Add "The AddOcelot method" paragraph * Use correct heading levels for subsections * Update configuration.rst Use correct heading levels for (sub)sections * Update configuration.rst Readability improvements * Incapsulate all system services to the AddDefaultAspNetServices method * Add developer's XML-docs for OcelotBuilder and related extensions * Create dependencyinjection.rst * Update dependencyinjection.rst Overview paragraph * Update dependencyinjection.rst "IServiceCollection extensions" paragraph. "The OcelotBuilder class" paragraph. * Update dependencyinjection.rst: Custom Builder paragraph * Add Dependency Injection feature to the index of docs * Update gettingstarted.rst: Add footnotes * Correction of typo in English grammar * Unit tests for AddOcelotUsingBuilder extension * Improve readability of BDDfy scenarios in logs * Update requestaggregation.rst. Add footnotes Mark down corrections * Update tracing.rst: Add footnotes. Markdown text corrections * Update qualityofservice.rst: Add footnotes * Update administration.rst: Add footnotes. Markdown text corrections * Update configuration.rst: Add footnotes. Text corrections * IDE1006 Naming rule violation: These words must begin with upper case characters: should_* --------- Co-authored-by: Raman Maksimchuk <[email protected]>
@WajahatAliAbid |
Expected Behavior
With .net core 3.1 and above, asp.net core projects use System.Text.Json serializer by default. But when we add Ocelot in our DI, asp.net core projects start using Newtonsoft.json. I tried diagnosing this issue and found that Ocelot was adding NewtonsoftJson in the dependency tree which changed the default serializer to NewtonsoftJson instead of the expected System.Text.Json with .net core 3.1 and above projects. For reference: OcelotBuilder
I've an HTTP Client which uses System.Text.Json as the serializer and it is receiving a dynamic JSON object which I expect to be serialized properly when returning as
ActionResult
from Controller. Following is my expected responseActual Behavior
I get the following response instead which is basically serialized by Newtonsoft.Json
Steps to Reproduce the Problem
System.Text.Json.JsonSerializer
Specifications
The text was updated successfully, but these errors were encountered: