Asp .Net Core Spa (一) - 入门

第一次写文章, 很久之前就想写来着了, 文章哪里不清楚的, 也请多多提出意见。

最近发现用 .net core + spa (single page application) 这个组合的人也变多了, 所以写一套 各种 关于 这个组合的实践方案, 也算是留个记录。

主要针对 .net core 2.1 以后的版本。主要原因是 之前的版本 spa 的实现还是基于 mvc 的pipeline 但是在 .net core 2.1 之后 引入了 UseSpa 这个 中间件后 Spa 已经完成了和mvc的分离 包括 SSR (服务端渲染)。

 

这是第一篇 入门 主要讲解 .net core 的 基础 spa 模版。项目案例用的 React, Angular 和 Vue 也类似, 不过Vue 貌似没有和Cli的整合 API

 

1. 创建项目

新项目 -> .Net Core -> ASP .NET Core Web Application -> React.js (暂时不选 Redux, Redux 很重要 但是几个框架都有自己不同的状态管理)

这里用的 Core 2.2 和 2.1 没什么太大变化

 

2. 项目目录

.Net Core Spa 项目,和NodeJs 项目类似,不过以 .Net Core为服务端。 主要服务 包括 静态文件,API 和 服务器渲染

./ClientApp Spa项目

./ClientApp/public Spa静态资源

./ClientApp/build Spa静态发布文件

 

3. 中间件和设置

主要套路都在这里

1. 定义Spa静态文件根目录,这里的文件 将被注册到Spa静态文件路由

services.AddSpaStaticFiles(configuration =>
{
    configuration.RootPath = "ClientApp/build";
});

,默认是用的是 CientApp/build. 所有在 这个文件夹下的文件 会被直接 映射到 root url 之下

例如: ClientApp/build/react.js 这个文件就会被 映射到 localhost:5000/react.js

 

2. 使用Spa静态文件服务

app.UseSpaStaticFiles();

这个中间件将会启用静态文件映射

 

3. 使用Spa网页

app.UseSpa(spa =>
{
    spa.Options.SourcePath = "ClientApp";
    if (env.IsDevelopment())
    {
        spa.UseReactDevelopmentServer(npmScript: "start");
    }
});

这个就是代替了mvc 渲染 spa的中间件了,在没有服务器渲染的时候,我们定义了默认的SourcePath。

主要利用于跑node指令,和index.html入口无关,默认网页入口是 Spa静态文件根目录/index.html

当然 这里例子用的是 UseReactDevelopmentServer 这个必须配合 create-react-app (react-script)使用, 他会创建一个node event 然后监控 console

当react-script 启动的时候 会自动和 .net core产生proxy, 使你的.net core localhost 可以看见spa的页面,不过编译速度很慢。推荐关闭 使用 webpack-dev-server + api proxy 来提高开发速度

 

5. 修改中间件管道

默认的中间件管道并不是很完美,因为mvc中间件的性质 一旦请求进入了mvc中间件,请求是不会走道后面的中间件的。

这里就要修改中间件顺序啦。。然后利用到我们伟大的 app.Map 和 app.MapWhen

app.UseHttpsRedirection();

app.Map("/api", apiApp => {
    apiApp.UseMvc(routes => routes.MapRoute("default", "{controller}/{action=Index}/{id?}"));
});

app.UseStaticFiles();
app.UseSpaStaticFiles();

我们把中间件改成这样,用Map 来限制 只有 /api 的路由才能进入 mvc中间件,当然用MapWhen也是可以的.

两者主要区别就在:

   1. Map只针对Url,而MapWhen侧可以对整个请求作出判断

   2. Map之后的Url会切除Map到的路由,而MapWhen则不变

我上面这个例子 在Map 检测到 /api 后才会进入mvc, 但是进入mvc的时候 api其实已经被去掉了, 所以controller不再需要强制标明 api/[controller], 只需要 [controller] 即可

 

6. csproj

其实有很多编译或者发布指令是通过项目的.csproj 来实现的

默认的指令有 DebugEnsureNodeEnv 和 PublishRunWebpack 分别是 npm install 和 npm install & run build

 

小结

项目本身其实很简单,也很容易上手,配合mvc 搭建的api 和新一代的前端框架,.net core的性能和发布的简易型,其实是可以尝试的。

这里有个我一直在更新的Boilerplate项目 https://github.com/JiarongGu/ReactCoreTemplate

 

一篇一篇来吧。。下一篇就说说 SSR的问题

转载于:https://www.cnblogs.com/JiarongGu/p/10431519.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ASP.NET Core 提供了内置的身份验证和授权功能,可以轻松地实现用户的登录和登出功能。 要实现登录功能,首先需要在 ConfigureServices 方法中添加身份验证服务: ```csharp services.AddAuthentication(options => { options.DefaultScheme = CookieAuthenticationDefaults.AuthenticationScheme; options.DefaultChallengeScheme = GoogleDefaults.AuthenticationScheme; }) .AddCookie(options => { options.LoginPath = "/Account/Login/"; options.LogoutPath = "/Account/Logout/"; }) .AddGoogle(options => { options.ClientId = Configuration["Authentication:Google:ClientId"]; options.ClientSecret = Configuration["Authentication:Google:ClientSecret"]; }); ``` 上面的代码中,我们添加了 Cookie 身份验证服务,并指定了登录和登出的路径。同时,我们还添加了 Google 身份验证服务,并设置了 ClientId 和 ClientSecret。 接着,在 Configure 方法中启用身份验证中间件: ```csharp app.UseAuthentication(); ``` 现在,我们可以在 AccountController 中添加 Login 和 Logout 的动作方法: ```csharp public IActionResult Login(string returnUrl = "/") { ViewData["ReturnUrl"] = returnUrl; return View(); } [HttpPost] public async Task<IActionResult> Login(LoginViewModel model, string returnUrl = "/") { if (ModelState.IsValid) { var result = await _signInManager.PasswordSignInAsync(model.Email, model.Password, model.RememberMe, lockoutOnFailure: false); if (result.Succeeded) { _logger.LogInformation("User logged in."); return RedirectToLocal(returnUrl); } if (result.RequiresTwoFactor) { return RedirectToAction(nameof(LoginWith2fa), new { returnUrl, model.RememberMe }); } if (result.IsLockedOut) { _logger.LogWarning("User account locked out."); return RedirectToAction(nameof(Lockout)); } else { ModelState.AddModelError(string.Empty, "Invalid login attempt."); return View(model); } } // If we got this far, something failed, redisplay form return View(model); } [HttpPost] public async Task<IActionResult> Logout() { await _signInManager.SignOutAsync(); _logger.LogInformation("User logged out."); return RedirectToAction(nameof(HomeController.Index), "Home"); } ``` 上面的代码中,我们首先添加了一个 Get 请求的 Login 方法,用于显示登录页面。接着,我们添加了一个 Post 请求的 Login 方法,用于处理用户提交的登录表单。在这个方法中,我们调用了 _signInManager.PasswordSignInAsync 方法进行身份验证,并根据不同的结果进行相应的处理。最后,我们还添加了一个 Logout 方法,用于处理用户的登出请求。 现在,我们只需要在视图中添加相应的表单,就可以实现登录和登出功能了: ```html <form asp-action="Login" asp-route-returnUrl="@ViewData["ReturnUrl"]" method="post"> <div class="form-group"> <label asp-for="Email"></label> <input asp-for="Email" class="form-control" /> <span asp-validation-for="Email" class="text-danger"></span> </div> <div class="form-group"> <label asp-for="Password"></label> <input asp-for="Password" class="form-control" /> <span asp-validation-for="Password" class="text-danger"></span> </div> <div class="form-group"> <div class="checkbox"> <label asp-for="RememberMe"> <input asp-for="RememberMe" /> @Html.DisplayNameFor(m => m.RememberMe) </label> </div> </div> <div class="form-group"> <button type="submit" class="btn btn-primary">Login</button> </div> </form> <a asp-action="Logout" asp-controller="Account">Logout</a> ``` 上面的代码中,我们添加了一个登录表单和一个登出链接,用于演示登录和登出功能。其中,登录表单使用了 asp-for 和 asp-validation-for 标签帮助器,可以自动生成相应的 HTML 元素和验证信息。登出链接使用了 asp-action 和 asp-controller 标签帮助器,可以自动生成相应的 URL。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值