Development environment: Visual Studio 2022 Preview, .NET 6 , React 17. Create project
data:image/s3,"s3://crabby-images/5b0a7/5b0a73f6c66ad984ac1da78a3c88c07e1f5ce785" alt=""
data:image/s3,"s3://crabby-images/86ab9/86ab9788842b624cbefffe65ab2f2c96af31039b" alt=""
data:image/s3,"s3://crabby-images/62a99/62a9969e725d70d59aed34d5564831bc4279ebd6" alt=""
data:image/s3,"s3://crabby-images/670b8/670b856947c2daf7313289c44c9931f67776af8d" alt=""
Press F5 to run debug, result
data:image/s3,"s3://crabby-images/dc9ce/dc9ce084da82a33541fcd2cf207ae7b8ce70d82a" alt=""
Write first custom middleware, with the presence of AI for Intelli Sense, AI suggesion works as I expected.
data:image/s3,"s3://crabby-images/46b49/46b498372f60b293452429f76b585fed3f4b6934" alt=""
Write CustomLogger.cs
namespaceReactNET6{publicclassCustomLogger{privatereadonlyRequestDelegate _next;publicCustomLogger(RequestDelegate next){
_next = next ??thrownewArgumentNullException("next");}publicasyncTaskInvoke(HttpContext httpContext){if(httpContext ==null)thrownewArgumentNullException(nameof(httpContext));await_next(httpContext);}}publicstaticclassMiddlewareExtensions{publicstaticIApplicationBuilderUseCustomLogger(thisIApplicationBuilder app){return app.UseMiddleware<CustomLogger>();}}}
Add 2 lines (line 1 and line 11) to file Program.cs
This is feature called “Top-level statements” in C# 9 https://docs.microsoft.com/en-us/dotnet/csharp/whats-new/csharp-9#top-level-statements
data:image/s3,"s3://crabby-images/43729/43729e6d04b970f92f3474aec6ce9ca92fd98114" alt=""
We have Program.cs
with content
usingReactNET6;var builder = WebApplication.CreateBuilder(args);// Add services to the container.
builder.Services.AddControllersWithViews();var app = builder.Build();
app.UseCustomLogger();// Configure the HTTP request pipeline.if(!app.Environment.IsDevelopment()){// 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.MapControllerRoute(name:"default",pattern:"{controller}/{action=Index}/{id?}");
app.MapFallbackToFile("index.html");;
app.Run();
Publish
data:image/s3,"s3://crabby-images/b9783/b97833fac1c2823bab8cd26b7794ebdf7cb7081c" alt=""
data:image/s3,"s3://crabby-images/a5b38/a5b38a6ad568aff3fa313e807dce35cce0f2286d" alt=""
data:image/s3,"s3://crabby-images/0fd94/0fd944a20c804a4bb625046025d1562b99d29620" alt=""
data:image/s3,"s3://crabby-images/df687/df687e31c1fe3b80ab4acbdf9b551db5f00e5909" alt=""
Result after publishing: C:UsersdonhuvysourcereposReactNET6binReleasenet6.0publish
, run file ReactNET6.exe
, go to http://localhost:5000 to see the result.
Nguồn: viblo.asia