Warning: Illegal string offset 'download' in /www/wwwroot/www.oilcn.net.cn/wp-content/themes/wpzt-hot/template-parts/single/single-pc.php on line 4

可生成html静态网页的asp企业网站源码(asp网页网站源码使用)

17次
2021-06-21


可生成html静态网页的asp企业网站源码(asp网页网站源码使用) (https://www.oilcn.net.cn/) 网站运营 第1张

在一些还要频繁更新页面数据的网站中,一般访问量不是巨大的都直接公布的是带后台代码,每次访问都是有数据库交互的。但是即便访问量降低了,那么这种服务器花费弄成本就该考虑过来了,像一些文章,后台编辑后,文章内容存入数据库,如果1000人访问,如果还是每天取数据库,那这1000次的io访问就变得比较大了,一个好的方式就是,文章确定以后,做成静态页面,而这个做的方式由程序来做,就是数组递归整个网站,将网站内容都访问一遍,然后生成某些页面的静态文本页面,在将这种页面公布可生成html静态网页的asp企业网站源码,这样对浏览者而言可生成html静态网页的asp企业网站源码,他看见的还是同一个地址,同一份文章,只是这份是静态的而言。这样就提高了网站的效率节省了资源;

可生成html静态网页的asp企业网站源码(asp网页网站源码使用) (https://www.oilcn.net.cn/) 网站运营 第2张

下面附上一份C#递归网站内容,然后生成内容页面代码;

可生成html静态网页的asp企业网站源码(asp网页网站源码使用) (https://www.oilcn.net.cn/) 网站运营 第3张

private ArrayList htmlCreatedList = new ArrayList();
        /// 
        /// 递归实现页面静态化功能
        /// 
        /// 要访问的页面链接地址
        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);
            }
        }
        /// 
        /// 通过HttpWebRequest页面链接的html代码
        /// 
        /// 页面链接地址
        /// 页面链接对应的html代码
        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;
        }
        ///
        ///正则表达式匹配出html代码中的超链接
        ///
        ///要找出超链接的html代码
        ///
        private IEnumerable GetUrlLinkFromHtmlCode(string htmlCode)
        {
            string strRegex = "href\\s*=\\s*(?:[\"'](?<1>[^\"'.#:]*)[\"'])";
            Regex r = new Regex(strRegex, RegexOptions.IgnoreCase);
            MatchCollection ms = r.Matches(htmlCode);
            IEnumerable listUrl = from Match cc in ms select cc.ToString().Replace("&", "&");
            return listUrl.Distinct();
        }
    }

可生成html静态网页的asp企业网站源码(asp网页网站源码使用) (https://www.oilcn.net.cn/) 网站运营 第4张

给string 扩展了一个方式。

可生成html静态网页的asp企业网站源码(asp网页网站源码使用) (https://www.oilcn.net.cn/) 网站运营 第5张

 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;
        }

END

发表评论