.NET 6 中将 ASP.NET Core 注册成 Windows Service

前言

使用 Visual Studio 中的 Worker Service项目模板:

c84f884336a8238a162e18057bb4f6a1.png

我们很容易创建出 Windows Service:

IHost host = Host.CreateDefaultBuilder(args)
    .UseWindowsService()
    .ConfigureServices(services =>
    {
        services.AddHostedService<Worker>();
    })
    .Build();

await host.RunAsync();

需要引用 NuGet 包Microsoft.Extensions.Hosting.WindowsServices

但是,当我们想把 ASP.NET Core 应用注册成 Windows Service 时,却碰到了一些麻烦。

Demo

创建 ASP.NET Core 应用,然后把 Worker Service 中的代码复制过来:

var builder = WebApplication.CreateBuilder(args);

builder.Host.UseWindowsService()
.ConfigureServices(services =>
{
    services.AddHostedService<Worker>();
});

var app = builder.Build();

app.MapGet("/", () => "Hello MyIO!");

app.Run();

需要注意的是:与 Worker Service 不同,在 ASP.NET Core 应用中,需要通过builder.Host拿到IHostBuilder的实例。

使用sc create注册 Windows Service 成功。

但是在启动时,却提示 1053 错误:

1effc9d0493750ce1b15d297622291e9.png

通过事件查看器,我们发现导致错误的原因是当前工作目录是C:\WINDOWS\system32而不是我们的 ASP.NET Core 应用所在目录:

ab6c1ced0dfe71325d3044a837965a65.png

解决方案

1. 修改工作目录

虽然在 Windows Service 属性窗口中不能设置工作目录,但是我们可以在启动时修改当前工作目录:

Directory.SetCurrentDirectory(AppContext.BaseDirectory);

var builder = WebApplication.CreateBuilder(args);

2. 设置 ContentRootPath

既然是ContentRootPath不正确导致的错误,那我们就按照错误提示使用 WebApplicationOptions 设置正确的ContentRootPath即可:

var builder = WebApplication.CreateBuilder(new WebApplicationOptions
{
    ContentRootPath = AppContext.BaseDirectory,
    Args = args
});

结论

通过 2 种解决方案,我们都可以成功将 ASP.NET Core 应用注册成 Windows Service 并运行。

添加微信号【MyIO666】,邀你加入技术交流群

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ASP.NET Core是一个跨平台的开源框架,用于构建现代化的云端应用程序。JWT(JSON Web Token)是一种用于身份验证和信息传递的开放标准(RFC 7519),通常用于前后端分离的应用中进行用户身份验证和授权。 在ASP.NET Core中,我们可以使用JWT来进行用户的登录校验。首先,我们需要在服务器端生JWT,并在用户登录功后将JWT返回给客户端。客户端在之后的每次请求中都需要在请求头中携带JWT。服务器端收到请求后会从JWT中解析出用户信息并校验用户身份。 为了实现JWT登录校验,我们需要在ASP.NET Core应用中添加JWT认证中间件,并配置JWT的签名密钥、过期时间等参数。在用户登录功后,我们可以使用JWT生器来创建并返回JWT token。在客户端发送请求时,我们可以使用JWT验证器来验证JWT token,并根据验证结果进行相应的操作。 除了在服务器端进行JWT登录校验之外,我们还需要在客户端进行JWT的存储和管理。一般来说,客户端可以将JWT保存在本地存储,例如LocalStorage或SessionStorage中,并在每次请求中将JWT添加到请求头中。在一些安全性要求较高的场景中,客户端还可以使用HTTPOnly Cookie来保存JWT。 总之,ASP.NET Core提供了丰富的工具和中间件来简化JWT登录校验的实现,并且可以很好地与前后端分离的架构进行集,让开发者可以便捷地实现用户身份验证和授权功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值