aspnetcore 实现简单的伪静态化功能
更新时间:2019年07月12日 08:48:57 作者:Love it or leave it
这篇文章主要介绍了aspnetcore 实现简单的伪静态化功能,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
Intro
在我的活动室预约项目中,有一个公告模块,类似于新闻发布,个人感觉像新闻这种网页基本就是发布的时候编辑一次之后就再也不会改了,最适合静态化了, 静态化之后用户请求的就是静态文件基本不再需要服务器端查询数据库甚至服务器端渲染,可以一定程度上提升服务器的处理能力以及优化用户体验,而且这种静态化的url对 SEO 比较友好。
由于我的这个项目正在开发中,迁移起来不太方便,所以使用的是伪静态化,看上去是访问的 *.html,实际上并不是 html,而是需要服务器处理的。
GetStarted
配置路由信息,注意顺序,伪静态的路由要在默认路由之前
app.UseMvc(routes =>
{
routes.MapRoute(“Notice”, “/Notice/{path}.html”, new
{
controller = “Home”,
action = “NoticeDetails”
});
routes.MapRoute(name: “areaRoute”,
template: “{area:exists}/{controller=Home}/{action=Index}”);
routes.MapRoute(
name: “default”,
template: “{controller=Home}/{action=Index}”);
});
控制器代码:
/// <summary>
/// 公告详情
/// </summary>
/// <param name=”path”>访问路径</param>
/// <returns></returns>
public async Task<ActionResult> NoticeDetails(string path)
{
if (string.IsNullOrWhiteSpace(path))
{
return RedirectToAction(“Notice”);
}
try
{
var noticeBll = HttpContext.RequestServices.GetService<IBLLNotice>();
var notice = await noticeBll.FetchAsync(n => n.NoticeCustomPath == path.Trim());
if (notice != null)
{
notice.NoticeVisitCount += 1;
await noticeBll.UpdateAsync(notice, x => x.NoticeVisitCount);
return View(notice);
}
else
{
return RedirectToAction(“Notice”);
}
}
catch (Exception ex)
{
Logger.Error(ex);
throw;
}
}
实际效果:
reservation.weihanli.xyz/Notice/test-notice.html
notice details
Q&A
Q:为什么我们要做(伪)静态化?
A:站点下的 *.html 文件有利于网站的 SEO 优化,有利于百度和google爬虫爬你的网站,SEO做的好有利于提高搜索排名【SEO的水也很深、感兴趣的可以自己找资料研究】。
Q:什么是伪静态化?什么是完全静态化?他们的区别是什么?
A:伪静态化是针对完全静态化来说的,(完全)静态化是会实际保存内容到一个 *.html 文件中,而伪静态化则是通过服务器端技术通过匹配 url 符合一定的模式就重新交给指定的程序处理并返回内容。
简单来说,(完全)静态化会有一个实际存在的静态文件,伪静态化则不存在,需要较多服务器端的处理。
Q:伪静态化和完全静态化哪个好?
A:这个问题更好的问法应该是这样的:“什么时候适合用伪静态化?什么时候适合用完全静态化?”,一个事物既然存在就必然有它存在的道理,存在即合理,如果没有存在的意义必将死去。
完全静态化一般会根据一个模板生成一个实际存在的 *.html 文件,完全静态化不需要太多的服务器端处理,客户端请求这个文件时因为是一个静态文件服务器会直接将文件内容返回给客户端,不需要额外的服务器处理。
完全静态化会减少服务器的压力。
伪静态化服务器上并没有静态 *.html文件,只是在服务器断使用了Rewrite,将动态URL进行重写,使动态URL表现为静态URL,以满足网页URL静态需求但网页依然为动态调用的,,是需要很多服务器端处理的,比如url的模式匹配,从数据库中查询数据。
总结:虽然完全静态化URL的网页有打开速度快的优点,但是网站内容巨大的话,势必会使网站的体积变大很多,会有很多的静态化文件,网站迁移的话很麻烦,另一方面如果网站内容很多的时候修改模板的话,再次静态化的时候会是一个比较大的工作量。实际使用的话还是需要根据自己实际需要来选取。
Reference
• github.com/WeihanLi/ActivityReservation/blob/dev/ActivityReservation
总结
以上所述是小编给大家介绍的aspnetcore 实现简单的伪静态化 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对华域联盟网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
您可能感兴趣的文章:.NetCore之接口缓存的实现示例.NETCore添加区域Area代码实例解析快速了解如何在.NETCORE中使用Generic-Host建立主机NetCore 3.0文件上传和大文件上传的限制详解.NETCore Docker实现容器化与私有镜像仓库管理Django日志及中间件模块应用案例在 asp.net core 的中间件中返回具体的页面的实现方法Vue Router中应用中间件的方法如何用.NETCore操作RabbitMQ
aspnet
core
伪静态化
相关文章
jdk环境变量配置jdk环境变量配置,可供参考 2012-11-11
浅谈.Net Core后端单元测试的实现这篇文章主要介绍了浅谈.Net Core后端单元测试的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 2021-03-03
ASP.NET获取MS SQL Server安装实例实现思路及代码在演示中,是把找到的实例显示于DropDownList控件中。首先在.aspx拉一个DropDownList控件,感兴趣的朋友可以了解下哦,或许对你有所帮助 2013-01-01
web.config中配置数据库连接的方式Web.config文件是一个XML文本文件,它用来储存 ASP.NET Web 应用程序的配置信息(如最常用的设置ASP.NET Web 应用程序的身份验证方式),它可以出现在应用程序的每一个目录中。本文主要介绍web.config中配置数据库连接的两种方式,一起来看。 2015-10-10
Asp.net mvc在view中用C#代码动态创建元素这篇文章主要给大家介绍了关于Asp.net mvc如何在view中用C#代码动态创建元素的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧 2019-03-03
在Asp.net网页上写读Cookie的两种不同语法介绍asp.net开发时,为了存储一些信息通常是Session与Cookie同时使用,本文将会补充一下Cookie相关的资料,感兴趣的朋友可以了解一下在网页上写读Cookie的实现,希望本文对你有所帮助 2013-01-01
asp.net url传递后地址栏乱码(中文超过两个汉字)asp.net 页面传中文超过两个汉字后面就乱码,编码编好的url是正确的,可传到另一个页面就会出错,在地址栏就已经乱码了,本文介绍详细的解决方法,感兴趣的朋友可以了解下,或许对你学习asp.net有所帮助 2013-02-02
.NET Core读取配置文件方式详细总结这篇文章主要为大家详细总结了.NET Core读取配置文件方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 2018-08-08
*.ashx文件不能访问Session值的解决方法这篇文章主要介绍了*.ashx文件不能访问Session值的解决方法,只需在头部引用一个命名空间即可解决问题,非常实用,需要的朋友可以参考下 2014-09-09
asp.net图片上传生成缩略图的注意事项asp.net图片上传生成缩略图的注意事项… 2007-09-09
最新评论

评论(0)