独立项目承载网页及Razor文件
Razor Page Library 是ASP.NET Core 2.1引入的新类库项目,属于新特性之一,用于创建通用页面公用类库。也就意味着可以将多个Web项目中通用的Web页面提取出来,封装成RPL
,以方便技术管理,也可以代码重用。在启动项目中堆大量的代码,个人认为从技术管理角度是不正确的。这时候就遇到了一个问题,如何能把wwwroot
项目输出到网站的根目录中。
var path = env.ContentRootPath.Remove(env.ContentRootPath.LastIndexOf($"{start project name}", StringComparison.Ordinal));
var provider = new PhysicalFileProvider(Path.Combine(path, $"{RCL project name}/wwwroot"));
app.UseStaticFiles(new StaticFileOptions
{
FileProvider = provider,
RequestPath = ""
});
app.UseStaticFiles();
注意:UseStaticFiles
使用了两次,暂时没有细想是为什么,算是Hack的方法吧,看起来不丑,也实现了想要的功能。
显示程序运行日志,是否使用SignalR(websocket)比较合适
- WebSocket提供了全双工通信渠道,允许服务器主动向客户端推送数据,而无需客户端不断地发起请求。这对于实时性要求较高的应用场景,如日志监控,尤为适合。
- 使用WebSocket,相比传统的轮询(polling)机制更加高效且实时性更好,因为轮询需要客户端定期向服务器发送请求来检查是否有新日志,这会增加不必要的网络负载和延迟。
- 具体到Razor Server或与Razor视图相关的Web应用中,可以在后端使用支持WebSocket的库(如ASP.NET Core中的SignalR)来处理实时通信逻辑。SignalR是一个很好的选择,因为它抽象化了WebSocket、Server-Sent Events(SSE)和其他实时通信技术的细节。
- 在服务器端:
- 安装并配置SignalR到Web项目中。
- 创建一个Hub类来处理日志的推送逻辑。这个Hub将作为客户端与服务器之间通信的中心点。
- 监听日志事件或周期性检查日志文件,当有新日志时,通过调用Hub的方法将日志消息推送给连接的客户端。
- 在客户端(Web页面):
- 在Razor页面中引用SignalR客户端库。
- 编写JavaScript代码来建立与服务器Hub的连接,并定义处理接收到日志消息的回调函数。
- 使用这些回调函数动态地将日志消息追加到Web页面上。
- 在服务器端: