gpt4 book ai didi

.net Core 3 [JsonIgnore] 在请求单个资源时不起作用

转载 作者:行者123 更新时间:2023-12-03 13:43:32 25 4
gpt4 key购买 nike

在我的 .net Core 3.0 Api 中,[JsonIgnore] 属性不能正常工作。我正在使用 System.Text.Json
而不是旧的 Newtonsoft.Json
当我使用返回对象列表的资源时,例如:

/api/Object/

对象序列化如下:
  [
{
"id": 1,
"date": "2020-02-12T08:45:51.502",
"userId": 1,
"tags": [
{
"name": "string"
}
]
}
]

但是当我请求一个结果时
/api/Object/{id}

完整的对象像这样被序列化:
    {
"user": {
"hasAccess": false,
"id": 1,
"userName": "***",
"normalizedUserName": "***",
"email": "***",
"normalizedEmail": "***",
"emailConfirmed": true,
"passwordHash": "***",
"concurrencyStamp": "***",
"phoneNumberConfirmed": false,
"twoFactorEnabled": false,
"lockoutEnabled": true,
"accessFailedCount": 0
},
"lazyLoader": {},
"id": 1,
"date": "2020-02-12T08:45:51.502",
"userId": 1,
"tags": [
{
"name": "string"
}
]
}

具有 JsonIgnore 属性的类如下所示:
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Text.Json.Serialization;
public class Object
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
public DateTime Date { get; set; }
[ForeignKey("User")]
public int UserId { get; set; }
[JsonIgnore]
public virtual User User { get; set; }
}

这是我的 WebApi Controller 类:
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Models;
using Services;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

[Route("api/object")]
[ApiController]
[Authorize(Roles = Roles.ACCESS_GRANTED)]
public class ObjectController : AbstractController
{
private readonly ObjectService objectService;

public ObjectController(IDataService<Object> service, ExtendedUserManager manager) : base(manager)
{
objectService = (ObjectService)service;
}

// GET: api/Object
[HttpGet]
public IActionResult Get()
{
List<Object> object = objectService.GetAll();
return Ok(object);
}




// GET: api/Object/5
[HttpGet("{id}", Name = "GetObject")]
public IActionResult Get(int id)
{
Object object = objectService.Get(id);

if (object == null)
{
return NotFound(string.Format("Object with Id {0} could not be found", id));
}

return Ok(object);
}
}

我的 csproj 文件:
    <Project Sdk="Microsoft.NET.Sdk.Web">

<PropertyGroup>
<TargetFramework>netcoreapp3.1</TargetFramework>
<TypeScriptCompileBlocked>true</TypeScriptCompileBlocked>
<TypeScriptToolsVersion>Latest</TypeScriptToolsVersion>
<IsPackable>false</IsPackable>
<SpaRoot>ClientApp\</SpaRoot>
<DefaultItemExcludes>$(DefaultItemExcludes);$(SpaRoot)node_modules\**</DefaultItemExcludes>

<!-- Set this to true if you enable server-side prerendering -->
<BuildServerSideRenderer>false</BuildServerSideRenderer>
<RootNamespace>Project</RootNamespace>
<Configurations>Debug;Release;</Configurations>
</PropertyGroup>

<ItemGroup>
<PackageReference Include="AutoMapper.Extensions.Microsoft.DependencyInjection" Version="7.0.0" />
<PackageReference Include="log4net" Version="2.0.8" />
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="3.1.1" />
<PackageReference Include="Microsoft.AspNetCore.Identity.EntityFrameworkCore" Version="3.1.1" />
<PackageReference Include="Microsoft.AspNetCore.SpaServices.Extensions" Version="3.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="3.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Proxies" Version="3.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Sqlite" Version="3.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="3.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="3.1.1">
<PrivateAssets>all</PrivateAssets>
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
</PackageReference>
<PackageReference Include="Microsoft.Extensions.Logging.Debug" Version="3.1.1" />
<PackageReference Include="Microsoft.Extensions.Logging.Log4Net.AspNetCore" Version="3.0.3" />
<PackageReference Include="Microsoft.VisualStudio.Web.CodeGeneration.Design" Version="3.1.1" />
<PackageReference Include="SendGrid" Version="9.12.6" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="5.0.0" />
<PackageReference Include="System.IdentityModel.Tokens.Jwt" Version="5.6.0" />
</ItemGroup>

<ItemGroup>
<!-- Don't publish the SPA source files, but do show them in the project files list -->
<Content Remove="$(SpaRoot)**" />
<None Remove="$(SpaRoot)**" />
<None Include="$(SpaRoot)**" Exclude="$(SpaRoot)node_modules\**" />
</ItemGroup>

<Target Name="Restore">
<MSBuild Projects="$.\open-success.sln" Targets="Restore" />
</Target>

<Target Name="DebugEnsureNodeEnv" BeforeTargets="Build" Condition=" '$(Configuration)' == 'Debug' And !Exists('$(SpaRoot)node_modules') ">
<!-- Ensure Node.js is installed -->
<Exec Command="node --version" ContinueOnError="true">
<Output TaskParameter="ExitCode" PropertyName="ErrorCode" />
</Exec>
<Error Condition="'$(ErrorCode)' != '0'" Text="Node.js is required to build and run this project. To continue, please install Node.js from https://nodejs.org/, and then restart your command prompt or IDE." />
<Message Importance="high" Text="Restoring dependencies using 'npm'. This may take several minutes..." />
<Exec WorkingDirectory="$(SpaRoot)" Command="npm install" />
</Target>

<Target Name="PublishRunWebpack" AfterTargets="ComputeFilesToPublish">
<!-- As part of publishing, ensure the JS resources are freshly built in production mode -->
<Exec WorkingDirectory="$(SpaRoot)" Command="npm install" />


<!-- Include the newly-built files in the publish output -->
<ItemGroup>
<DistFiles Include="$(SpaRoot)dist\**; $(SpaRoot)dist-server\**" />
<DistFiles Include="$(SpaRoot)node_modules\**" Condition="'$(BuildServerSideRenderer)' == 'true'" />
<ResolvedFileToPublish Include="@(DistFiles->'%(FullPath)')" Exclude="@(ResolvedFileToPublish)">
<RelativePath>%(DistFiles.Identity)</RelativePath>
<CopyToPublishDirectory>PreserveNewest</CopyToPublishDirectory>
<ExcludeFromSingleFile>true</ExcludeFromSingleFile>
</ResolvedFileToPublish>
</ItemGroup>
</Target>

</Project>

还有我的启动:
 public class Startup
{
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}

public IConfiguration Configuration { get; }

// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{


services.AddCors();


services.AddControllers();



}

// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
app.UseCors(builder => builder.AllowAnyHeader().AllowAnyOrigin().WithMethods("*"));


app.UseDeveloperExceptionPage();



app.UseHttpsRedirection();


app.UseRouting();

app.UseAuthorization();

app.UseEndpoints(endpoints =>
{
endpoints.MapControllerRoute(
name: "default",
pattern: "{controller}/{action=Index}/{id?}");
});


}
}

我错过了什么还是这是一个错误?

更新:

我注意到另一个奇怪的行为,当我返回一个新创建的对象而不是数据库中的对象时,一切正常。
 [HttpGet("{id}", Name = "GetObject")]
public IActionResult Get(int id)
{
// Object object= objectService.Get(id);
Object object= new Object ();
object.User = new User();

if (object== null)
{
return NotFound(string.Format("object with Id {0} could not be found", id));
}

return Ok(object);
}

最佳答案

你需要:

using Newtonsoft.Json;

代替:
using System.Text.Json.Serialization;

nuget 包是 Microsoft.AspNetCore.Mvc.NewtonsoftJson .它不再包含在 .net 核心中。

关于.net Core 3 [JsonIgnore] 在请求单个资源时不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60184661/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com