Model-view-controller uygulaması yaratalım :
Configure metodunu şimdi inceleyelim :
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Home/Error"); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); } app.UseHttpsRedirection(); app.UseStaticFiles(); app.UseRouting(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapControllerRoute( name: "default", pattern: "{controller=Home}/{action=Index}/{id?}"); }); }
Şuraya dikkat edelim :
if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); }
burada diyoruz ki eğer Development oratmında isek UseDeveloperExceptionPage ile çıkan hataları görebiliyoruz.
Şimdi HomeController.cs'ye gidelim ve Index metodunda bir hata fırlatıp, davranışa bakalım :
public IActionResult Index() { throw new Exception("Bu bizim hatamız."); return View(); }
uygulamayı çalıştıralım.
Gördüğünüz üzere developer'lara özel hata sayfasını görüldü.
Not: Developer'lara özel olan hata sayfalarını production ortamında göstermek büyük bir güvenlik açığıdır.
Şimdi launchsettings.json dan environment'ımızı Production'a alalım.
Aşağıdaki kodları inceleyelim :
if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Home/Error"); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); }
Artık environment'ımız development modunda olmadığından kod akışı else'in içinde olacaktır. UseExceptionHandler middleware'i ile hata yönetimi yapmaktayız.
Bunları anlaşıldıktan sonra uygulamayı çalıştıralım :
UseExceptionHandler("Home/Error") middleware'i bizi Home içindeki Error sayfamıza yönlendirdi bizi. Yani şuraya :
[ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)] public IActionResult Error() { return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier }); }
Şimdi ise Error üstüne sağ tıklayıp "Go to View" diyelim :
Gördüğünüz üzere bize app.UseExceptionHandler("/Home/Error"); ifadesinin gösterdiği Error.cshtml çıktı:
Bu Error metodunun içinde istediğimiz loglamayı yapabiliriz ve Error.cshtml içerisinde istediğimiz hata mesajını gösteririz.
Bir dahaki yazımda hataları dosya'ya loglamayı göreceğiz.
En iyi dileklerim ile.
Mustafa Samed Yeyin.
Top comments (0)