Dobrze przyjęta odpowiedź bardzo mi pomogła, ale chciałem przekazać HttpStatusCode w moim oprogramowaniu pośrednim, aby zarządzać kodem błędu w czasie wykonywania.
Według tego linku mam pomysł, aby zrobić to samo. Więc połączyłem z tym Andrei Answer. Więc mój końcowy kod jest poniżej:
1. Klasa podstawowa
public class ErrorDetails
{
public int StatusCode { get; set; }
public string Message { get; set; }
public override string ToString()
{
return JsonConvert.SerializeObject(this);
}
}
2. Typ klasy wyjątku niestandardowego
public class HttpStatusCodeException : Exception
{
public HttpStatusCode StatusCode { get; set; }
public string ContentType { get; set; } = @"text/plain";
public HttpStatusCodeException(HttpStatusCode statusCode)
{
this.StatusCode = statusCode;
}
public HttpStatusCodeException(HttpStatusCode statusCode, string message) : base(message)
{
this.StatusCode = statusCode;
}
public HttpStatusCodeException(HttpStatusCode statusCode, Exception inner) : this(statusCode, inner.ToString()) { }
public HttpStatusCodeException(HttpStatusCode statusCode, JObject errorObject) : this(statusCode, errorObject.ToString())
{
this.ContentType = @"application/json";
}
}
3. Oprogramowanie pośrednie wyjątku niestandardowego
public class CustomExceptionMiddleware
{
private readonly RequestDelegate next;
public CustomExceptionMiddleware(RequestDelegate next)
{
this.next = next;
}
public async Task Invoke(HttpContext context /* other dependencies */)
{
try
{
await next(context);
}
catch (HttpStatusCodeException ex)
{
await HandleExceptionAsync(context, ex);
}
catch (Exception exceptionObj)
{
await HandleExceptionAsync(context, exceptionObj);
}
}
private Task HandleExceptionAsync(HttpContext context, HttpStatusCodeException exception)
{
string result = null;
context.Response.ContentType = "application/json";
if (exception is HttpStatusCodeException)
{
result = new ErrorDetails() { Message = exception.Message, StatusCode = (int)exception.StatusCode }.ToString();
context.Response.StatusCode = (int)exception.StatusCode;
}
else
{
result = new ErrorDetails() { Message = "Runtime Error", StatusCode = (int)HttpStatusCode.BadRequest }.ToString();
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
}
return context.Response.WriteAsync(result);
}
private Task HandleExceptionAsync(HttpContext context, Exception exception)
{
string result = new ErrorDetails() { Message = exception.Message, StatusCode = (int)HttpStatusCode.InternalServerError }.ToString();
context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
return context.Response.WriteAsync(result);
}
}
4. Metoda rozszerzenia
public static void ConfigureCustomExceptionMiddleware(this IApplicationBuilder app)
{
app.UseMiddleware<CustomExceptionMiddleware>();
}
5. Skonfiguruj metodę w startup.cs
app.ConfigureCustomExceptionMiddleware();
app.UseMvc();
Teraz moja metoda logowania w kontrolerze konta:
try
{
IRepository<UserMaster> obj = new Repository<UserMaster>(_objHeaderCapture, Constants.Tables.UserMaster);
var Result = obj.Get().AsQueryable().Where(sb => sb.EmailId.ToLower() == objData.UserName.ToLower() && sb.Password == objData.Password.ToEncrypt() && sb.Status == (int)StatusType.Active).FirstOrDefault();
if (Result != null)//User Found
return Result;
else// Not Found
throw new HttpStatusCodeException(HttpStatusCode.NotFound, "Please check username or password");
}
catch (Exception ex)
{
throw ex;
}
Powyżej możesz zobaczyć, czy nie znalazłem użytkownika, a następnie zgłaszając wyjątek HttpStatusCodeException, w którym przekazałem status HttpStatusCode.NotFound i komunikat niestandardowy
W oprogramowaniu pośrednim
catch (HttpStatusCodeException ex)
zostanie wywołany blok, który przekaże kontrolę
private Task HandleExceptionAsync (kontekst HttpContext, wyjątek HttpStatusCodeException)
.
Ale co, jeśli wcześniej wystąpił błąd czasu wykonywania? Do tego użyłem try catch catch, który wyrzuca wyjątek i zostanie złapany w catch (Exception wyjątekObj) i przekaże kontrolę do
Task HandleExceptionAsync (kontekst HttpContext, wyjątek Wyjątek)
metoda.
Użyłem pojedynczej klasy ErrorDetails dla zapewnienia jednolitości.
UseExceptionHandler
oprogramowania pośredniego?