目前我正在开发一个安装了 RESTier 1.0 NuGet-Package 的项目。我正在使用带有一些 DTO 的自定义模型构建器。为了构建 API,我使用从 ODataController 继承的控制器。查询或发布数据到目前为止没有问题。
当我尝试使用 PATCH 或 PUT 请求更新记录时,不会调用相应的控制器操作,而是得到异常。
- 首先我确实得到了 ChangeSetPreparer is missing exceptions。
- 更改后,我确实得到了空引用异常。
所以为了避免第一次,我添加了一个 ChangeSetInitializer 和一个我在一些 Github-Source 中找到的 SubmitExecutor (我不记得了):
public class ExternalApi : ApiBase
{
public ExternalApi(IServiceProvider serviceProvider) : base(serviceProvider)
{
}
public static new IServiceCollection ConfigureApi(Type apiType, IServiceCollection services)
{
return ApiBase.ConfigureApi(apiType, services)
.AddService<IModelBuilder, CustomModelBuilder>()
.AddService<IChangeSetInitializer, ChangeSetInitializer>()
.AddService<ISubmitExecutor, SubmitExecutor>();
}
private class ChangeSetInitializer : IChangeSetInitializer
{
public Task InitializeAsync(SubmitContext context, CancellationToken cancellationToken)
{
context.ChangeSet = new ChangeSet();
return Task.FromResult<object>(null);
}
}
private class SubmitExecutor : ISubmitExecutor
{
public Task<SubmitResult> ExecuteSubmitAsync(SubmitContext context, CancellationToken cancellationToken)
{
return Task.FromResult(new SubmitResult(context.ChangeSet));
}
}
}
添加这些之后,第一个问题似乎得到了解决,但是我得到了以下堆栈跟踪的空引用异常:
bei Microsoft.Restier.Publishers.OData.RestierController.CreateResult(Type resultType, Object result) bei Microsoft.Restier.Publishers.OData.RestierController.CreateUpdatedODataResult(Object entity) bei Microsoft.Restier.Publishers.OData.RestierController.d__3f.MoveNext( ) --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task 任务) 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) 在 Microsoft .Restier.Publishers.OData.RestierController.d__20.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) bei System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) bei System.Threading.Tasks.TaskHelpersExtensions.d__3`1.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- bei System.Runtime .CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务)在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务)在 System.Web.Http.Controllers.ApiControllerActionInvoker.d__0.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, A dem die Ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务)在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务)在 System.Web.Http.Controllers 之后。ActionFilterResult.d__2.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification (Task task) bei System.Web.Http.Controllers.ExceptionFilterResult.d__0.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- bei System.Web.Http.Controllers.ExceptionFilterResult。 d__0.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) 在 System.Runtime.CompilerServices.TaskAwaiter。HandleNonSuccessAndDebuggerNotification(Task task) bei System.Web.Http.Dispatcher.HttpControllerDispatcher.d__1.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- bei System.Web.Http.Dispatcher.HttpControllerDispatcher .d__1.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务)在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务task) bei System.Web.Http.HttpServer.d__0.MoveNext()HttpControllerDispatcher.d__1.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification (任务任务) bei System.Web.Http.HttpServer.d__0.MoveNext()HttpControllerDispatcher.d__1.MoveNext() --- Ende der Stapelüberwachung vom vorhergehenden Ort, an dem die Ausnahme ausgelöst wurde --- 在 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification (任务任务) bei System.Web.Http.HttpServer.d__0.MoveNext()
这些是我使用的动作签名的示例:
[EnableQuery]
public IQueryable<StoreDTO> Get()
[EnableQuery]
public SingleResult<StoreDTO> Get([FromODataUri] int key)
public async Task<IHttpActionResult> Post(StoreDTO store)
public async Task<IHttpActionResult> Put([FromODataUri] int key, StoreDTO store)
public async Task<IHttpActionResult> Patch([FromODataUri] int key, Delta<StoreDTO> store)
我尝试了与 DTO 匹配的各种 JSON 对象,但即使在调用 Put 或 Patch 之前,我仍然会收到空引用异常。