以下代碼是錯誤處理中間件的一部分,其目標是即使拋出錯誤也為客戶端提供一致的格式。Accept當標頭設置為時,我嘗試將響應序列化為 XML?application/xml,否則返回 JSON。if (context.Request.Headers["Accept"] == "application/xml"){? ? context.Response.ContentType = "application/xml";? ? using (var stringwriter = new StringWriter())? ? {? ? ? ? var serializer = new XmlSerializer(response.GetType());? ? ? ? serializer.Serialize(stringwriter, response);? ? ? ? await context.Response.WriteAsync(stringwriter.ToString());? ? }}else {? ? context.Response.ContentType = "application/json";? ? var json = JsonConvert.SerializeObject(response);? ? await context.Response.WriteAsync(json);}該else塊按預期工作。如果我在聲明的行上設置斷點XmlSerializer,執行就會停止。如果我在下一行設置斷點,則永遠不會命中斷點;響應已發送給客戶端。我的中間件配置如下:public void Configure(IApplicationBuilder app, IHostingEnvironment env)? ? {? ? ? ? app.UseStatusCodePagesWithReExecute("/error/{0}");? ? ? ? app.UseExceptionHandler("/error/500");? ? ? ? app.UseHsts();? ? ? ? app.UseMiddleware<ErrorWrappingMiddleware>();? ? ? ? app.UseMvc();? ? }context.Response.WriteAsync(stringwriter.ToString());為什么在塊中調用之前就將響應返回給客戶端if?
1 回答

慕田峪9158850
TA貢獻1794條經驗 獲得超8個贊
我發現了問題所在,這是一個愚蠢的錯誤。
為了測試 500 個錯誤,我特意向數據庫中沒有相應列的模型添加了一個屬性。這會拋出SqlException
一個無效的列名。然而,我錯過了第二個例外,它告訴我問題到底是什么:
ApiResponse cannot be serialized because it does not have a parameterless constructor.
這發生在對 的調用中serializer.Serialize(stringwriter, response)
。我引用的示例創建了一個ApiResponse
類(response
我嘗試序列化)。然而,在我學習的示例中,此類沒有無參數構造函數,第二個異常停止了執行,但由于我忘記打開開發模式并且我試圖拋出異常,所以我沒有注意到第二個異常。
- 1 回答
- 0 關注
- 122 瀏覽
添加回答
舉報
0/150
提交
取消