c# 网站生成静态页面
在一些需要经常更新页面数据的网站中,一般访问量不是很大的都直接发布的是带后台代码,每次访问都是有数据库交互的。但是一旦访问量增加了,那么这些服务器开销变成本就要考虑进来了,像一些文章,后台编辑后,文章内容存入数据库,如果1000人访问,如果还是每次取数据库,那这1000次的io访问就显得比较大了,一个好的方法就是,文章确定之后,做成静态页面,而这个做的方法由程序来做,就是递归遍历整个网站,将网站内容都访问一遍,然后生成这些页面的静态文本页面,在将这些页面发布,这样对浏览者而言,他看到的还是同一个地址,同一份文章,只是这份是静态的而言。这样就提升了网站的效率节约了资源;
下面附上一份C#遍历网站内容,然后生成内容页面代码;
- private ArrayList htmlCreatedList = new ArrayList();
- /// <summary>
- /// 递归实现页面静态化功能
- /// </summary>
- /// <param name="urlString">要访问的页面链接地址</param>
- public void SaveHtmlCode(string urlString)
- {
- if (htmlCreatedList.Contains(urlString))
- {
- return;
- }
- string htmlCode = GetHtmlCodeFromUrl(urlString);
- string htmlPath = urlString.ToPhysicalPath();
- string direcHtmlPath = Path.GetDirectoryName(htmlPath);
- if (!Directory.Exists(direcHtmlPath))
- {
- Directory.CreateDirectory(direcHtmlPath);
- }
- File.WriteAllText(htmlPath, htmlCode);
- htmlCreatedList.Add(urlString);
- var urlList = GetUrlLinkFromHtmlCode(htmlCode);
- string urlTemp = string.Empty;
- foreach (string url in urlList)
- {
- urlTemp = url;
- urlTemp = Regex.Replace(urlTemp, "href\\s*=\\s*", "");
- urlTemp = urlTemp.Replace("\"", "");
- urlTemp = urlTemp.Replace("\\", "/");
- urlTemp = WebConfigInfo.UrlPrefix + urlTemp;
- SaveHtmlCode(urlTemp);
- }
- }
- /// <summary>
- /// 通过HttpWebRequest页面链接的html代码
- /// </summary>
- /// <param name="urlString">页面链接地址</param>
- /// <returns>页面链接对应的html代码</returns>
- private string GetHtmlCodeFromUrl(string urlString)
- {
- HttpWebRequest hwRequest = (HttpWebRequest)WebRequest.Create(urlString);
- hwRequest.UserAgent = "User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; .NET CLR 1.0.3705";
- hwRequest.Accept = "*/*";
- hwRequest.KeepAlive = true;
- hwRequest.Headers.Add("Accept-Language", "zh-cn,en-us;q=0.5");
- HttpWebResponse hwResponse = (HttpWebResponse)hwRequest.GetResponse();
- Stream streamResponse = hwResponse.GetResponseStream();
- StreamReader readerOfStream = new StreamReader(streamResponse, System.Text.Encoding.GetEncoding("utf-8"));
- string strHtml = readerOfStream.ReadToEnd();
- readerOfStream.Close();
- streamResponse.Close();
- hwResponse.Close();
- return strHtml;
- }
- ///<summary>
- ///正则表达式匹配出html代码中的超链接
- ///</summary>
- ///<param name="htmlCode">要找出超链接的html代码</param>
- ///<returns></returns>
- private IEnumerable<string> GetUrlLinkFromHtmlCode(string htmlCode)
- {
- string strRegex = "href\\s*=\\s*(?:[\"'](?<1>[^\"'.#:]*)[\"'])";
- Regex r = new Regex(strRegex, RegexOptions.IgnoreCase);
- MatchCollection ms = r.Matches(htmlCode);
- IEnumerable<string> listUrl = from Match cc in ms select cc.ToString().Replace("&", "&");
- return listUrl.Distinct();
- }
- }
给string 扩展了一个方法。
- public static string ToPhysicalPath(this string urlString)
- {
- System.Uri uri = new System.Uri(urlString);
- string htmlPath = string.Format("{0}\\Html\\{1}\\", System.Web.HttpContext.Current.Request.PhysicalApplicationPath, uri.AbsolutePath);
- string[] querys = uri.Query.Split(new char[] { '?', '&', '=' }, StringSplitOptions.RemoveEmptyEntries);
- htmlPath += string.Join(string.Empty, querys);
- htmlPath += querys.Length.Equals(0) ? "Index.html" : ".html";
- htmlPath = htmlPath.Replace("/", "\\");
- htmlPath = htmlPath.Replace("\\\\", "\\");
- return htmlPath;
- }
c# 网站生成静态页面的更多相关文章
- 浅谈php生成静态页面
一.引 言 在速度上,静态页面要比动态页面的比方php快很多,这是毫无疑问的,但是由于静态页面的灵活性较差,如果不借助数据库或其他的设备保存相关信息的话,整体的管理上比较繁琐,比方修改编辑.比方阅读权 ...
- .net 生成 静态页面
.net 生成 静态页面 <!--Main.Aspx--> <%@ page language="C#" %> <%@ import namespac ...
- C#根据网址生成静态页面
HoverTree开源项目中HoverTreeWeb.HVTPanel的Index.aspx文件 是后台管理的首页. 包含生成留言板首页,以及显示用户名,退出等功能. 根据网址生成页面的方法: boo ...
- 比较详细PHP生成静态页面教程
一,PHP脚本与动态页面. PHP脚本是一种服务器端脚本程序,可通过嵌入等方法与HTML文件混合, 也可以类,函数封装等形式,以模板的方式对用户请求进行处理.无论以何种方式,它的基本原理是这样的.由客 ...
- [转]把动态页面.aspx 生成静态页面.html
本文转自:http://blog.csdn.net/csb5201314/article/details/5391688 如果要把主页Index.aspx 生成静态页面 Index.html后输出会提 ...
- PHP生成静态页面的方法
在PHP网站开发中为了网站推广和SEO等需要,需要对网站进行全站或局部静态化处理,PHP生成静态HTML页面有多种方法,比如利用PHP模板.缓存 等实现页面静态化,今天就以PHP实例教程形 ...
- .NET生成静态页面例子
主要做法如下: 1.创建网站,并创建一个模板页,template.htm 2.添加一个web窗体Default.aspx 3.在网站下新建文件夹htm,设置该文件夹的属性,确保该文件夹具有可写权限 详 ...
- 三种C#.net生成静态页面的方法
ASP.NET生成静态页面方法主要有三种 第一种方法:向服务器的动态页面发送请求,获取页面的html代码.这种方法缺点显而易见:速度慢.另外如果请求的动态页面有验证控件的话,返回的html页面却无 ...
- Java项目生成静态页面
第一次做项目需要生成静态页面,网上很多大牛对将网页生成静态页面有很多异议.说一下我的看法. 不外乎有以下因素: 1.从页面加载时间来看:静态页面不需要与数据库建立连接,尤其是访问数据量较大的页面,这种 ...
随机推荐
- Servlet字符编码过滤器
在Java Web程序开发中,由于Web容器内部使用编码格式并不支持中文字符集,所以,处理浏览器请求中的中文数据就会出现乱码的现象.由于Web容器使用了ISO-8859-1的编码格式,所以在Web应用 ...
- go语言基础之init函数的介绍
1.init函数的介绍 示例: 文件夹目录如下: 源代码: vi main.go //程序入口 package main //必须 import ( "calc" " ...
- [leetcode]Sum Root to Leaf Numbers @ Python
原题地址:http://oj.leetcode.com/problems/sum-root-to-leaf-numbers/ 题意: Given a binary tree containing di ...
- vue组件级路由钩子函数介绍,及实际应用
正如其名,vue-router 提供的导航钩子主要用来拦截导航,让它完成跳转或取消. 有多种方式可以在路由导航发生时执行钩子:全局的.单个路由独享的.或者组件级的. 一.全局钩子 你可以使用 rout ...
- Android -- SlidingMenu
实现原理 在一个Activity的布局中需要有两部分,一个是菜单(menu)的布局,一个是内容(content)的布局.两个布局横向排列,菜单布局在左,内容布局在右.初始化的时候将菜单布局向左偏移,以 ...
- kafka基本原理概述——patition与replication分配
kafka一直在大数据中承受着数据的压力也扮演着对数据维护转换的角色,下面重点介绍kafka大致组成及其partition副本的分配原则: 文章参考:http://www.linkedkeeper.c ...
- qt creator修改程序编码(解决中文乱码问题)的方法
qt creator修改程序编码(解决中文乱码问题)的方法 qt creator修改程序编码的功能有几处. 1.edit - select encoding 选择载入(显示)编码和储存编码,其中GB2 ...
- BNU Concentric Rings
http://www.bnuoj.com/bnuoj/problem_show.php?pid=16030 Concentric Rings There are several different ...
- COM如何区分套间线程(apartment thread)和自由线程(free thread)
- Java的泛型中,通配符可以设置上限和下限
上限:<? extends T> ?是T和T的子类 下限:<? super T> ?是T和T的父类 怎么看待这个上限和下限呢 首先应该想 其实对于Java来说 <? ex ...