HTML页面生成ASPX页面
这个功能是在DTcms Demo网站里面扣出来的一个小功能,他的Demo网站里面可以在HTML写好所有的代码,然后生成一下ASPX页面,就可以访问了。具体的流程下篇文章来分析。这篇文章主要是讲HTML如何生成ASPX页面。
原理:
我们先读取HTML页面,然后拼接字符串(组成ASPX页面的结构的字符串),然后创建ASPX页面把字符串利用File操作写进ASPX页面。
例如:
我们要生成的ASPX页面的结构大致如下(截图是最简单的,没有涉及数据的交互,只是静态字符串)

静态页面:

生成ASPX页面代码如下
//需要生成ASPX页面的静态页面
string templetFullPath = HttpContext.Current.Server.MapPath("/Html/Test.html");
//读取静态文件
using (StreamReader objReader = new StreamReader(templetFullPath, Encoding.UTF8))
{
StringBuilder textOutput = new StringBuilder();
textOutput.Append(objReader.ReadToEnd()); //把文件读取到StringBuilder中 string oldStr = textOutput.ToString();
string newStr = "";
newStr = oldStr;
//重点
//替换特殊标记
newStr = newStr.Replace("\r\n","\\r\\n");
newStr = newStr.Replace("\"", "\\\"");
//我们把 </script> 整个写到 tempplateBulder 里面无法正确显示,需要拆分开, 写到两个Append()里面
newStr = newStr.Replace("</script>", "</\");\r\n\ttemplateBuilder.Append(\"script>");
StringBuilder sbStr = new StringBuilder();
//添加页面头部 Inherits 这个属性的值必须对应正确
sbStr.AppendFormat("<%@ Page Language =\"C#\" AutoEventWireup=\"true\" Inherits=\"{0}\" ValidateRequest=\"false\" %>\r\n", "DTcmsTest.Test");
//命名空间 根据页面需求自己添加 用到一些的命名空间,也可以在对应的*.cs文件里面引用
sbStr.Append("<%@ Import namespace=\"System.Text\" %>\r\n");
//添加可以写后台代码的脚本
sbStr.Append("<script runat =\"server\">\r\nprotected override void OnInit(EventArgs e)\r\n");
sbStr.Append("{ \r\n\r base.OnInit(e);\r\n\t"); //基本上就这段代码是动态的,其他的都是一样的
//利用StringBuilder输出页面 先把HTML全部读取到StringBuilder里面然后在输出
sbStr.AppendFormat("StringBuilder templateBuilder = new StringBuilder({0});\r\n\t",textOutput.Capacity);
sbStr.AppendFormat("templateBuilder.Append(\"{0}\");\r\n\t", newStr); sbStr.Append("Response.Write(templateBuilder.ToString());\r\n }\r\n");
sbStr.Append("</script>\r\n");
string pageDir = HttpContext.Current.Server.MapPath("/HTML");
string outputPath = pageDir + "\\Test.aspx"; //生成文件的物理路径
//如果物理路径不存在则创建
if (!Directory.Exists(pageDir))
{
Directory.CreateDirectory(pageDir);
}
//重点
//保存写入文件
File.WriteAllText(outputPath, sbStr.ToString(), Encoding.UTF8); context.RewritePath("/HTML/Test.aspx");
生成ASPX页面的字符串注意点:
我们是利用File创建一个ASPX页面,然后进入写入数据的,它会识别一些特殊的标记。
列如:
我们写了一些带特殊符号的字符串,利用File写入文件


我们需要在后台代码中输出一开始获取的HTML页面数据,不能破坏,所以才需要替换

如果我们需要写后台代码,我们新建一个*.cs文件,名字跟ASPX页面一样,然后让类继承 Page就可以了。

这里说的只是原理,没有涉及到数据交互。
HTML页面生成ASPX页面的更多相关文章
- HTML控件ID和NAME属性及在CS页面获得.ASPX页面中HTML控件的值
<转载>来自网络 一.ID是在客户端脚本里用!NAME是用于获取提交表单的某表单域信息,在form里面,如果不指定Name的话,就不会发送到服务器端,所以有name属性的控件,必须指定na ...
- hexo 静态页面生成后页面打不开的问题
我这里的原因是4000端口被占用了 *** hexo入门指南教程: 官方文档 用Hexo 3 搭建github blog 做一款hexo主题(进阶) 坑 1 要安装node和git 2 别忘了安装he ...
- aspx页面调用发送邮件验证码(结合前两篇)
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default3.aspx.cs ...
- aspx页面图片用作html中img的url
背景:如果无法直接访问保存图片的服务器,我们可以先制作一个aspx页面用来接受服务器发送过来的图片,然后html页面请求aspx页面.对图片服务器起一定的缓冲保护作用,预防对黑客攻击造成危害. 注意: ...
- [转]把动态页面.aspx 生成静态页面.html
本文转自:http://blog.csdn.net/csb5201314/article/details/5391688 如果要把主页Index.aspx 生成静态页面 Index.html后输出会提 ...
- 关于aspx 页面生成html 源码顶部空行不得不说的事儿
原文引用自 http://www.360doc.com/content/12/0910/21/10504424_235418578.shtml 使用.aspx生成的页面一般都会有一个或多个空行,当然这 ...
- .NET生成静态页面并分页
因为公司的产品用asp开发, 前一段时间用asp写了一个生成静态页面并分页的程序,但缘于对.net的热爱,写了这个.net下的生成静态页面并分页的程序. 主要的原理就是替换模板里的特殊字符. 1.静态 ...
- .net 生成 静态页面
.net 生成 静态页面 <!--Main.Aspx--> <%@ page language="C#" %> <%@ import namespac ...
- ASP.NET ashx实现无刷新页面生成验证码
现在大部分网站登陆时都会要求输入验证码,在网上也看了一些范例,现在总结一下如何实现无刷新页面生成验证码. 效果图: 实现方式: 前台: <div> <span>Identify ...
随机推荐
- jmeter-集合点---学习笔记
集合点: 简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点,每到输入用户名和密码登录时,所有的虚拟 ...
- hadoop 常用hdfs命令
- line-height 150%和1.5的区别
好惨啊,九点多了没事做还不能下班,坑爹的测试啊~~~ 刚才拿这个问题调戏了下部门一位资深前端开发,结果发现,他居然不会,呵呵~~~ 这里就说下吧 html: <div class="p ...
- STlink及烧写工具:
一 STLINK可以随时在STLINK与jlink之间切换:方法:https://www.segger.com/products/debug-probes/j-link/models/other-j- ...
- Spring boot-(3) Spring Boot特性1
本节将深入Spring Boot的细节,可以学到你想使用的或定制的Spring Boot的主要特性. 1. SpringApplication SpringApplication类为引导一个Sprin ...
- oracle用分隔符分割字段,并转为多行
作用:当判断是否满足条件,而条件字段又是用","分割的时候. 如果数据库中一个字段插入数据,并且以","分割.有点像行转列 4804510101,4946645 ...
- IntelliJ IDEA实时模板变量
返回由当前方法返回的值的类型IntelliJ IDEA 实时模板中的模板变量允许用户输入.扩展模板后,变量将作为输入字段显示在编辑器中. IntelliJ IDEA 声明实时模板变量 模板中的变量以下 ...
- html+css杂记
overflow可设置超出后隐藏 子元素撑开父级元素:①父级元素宽度不固定,②父级元素设置为inline-block或者添加float: html中的中文在浏览器打开为乱码(已经写了<meta ...
- flexbox预习
创建一个flexbox: .flex-container{ display:flex; } flex-direction: column;//将flex排成一列 flex-direction: co ...
- 绘图之Canvas学习
一 Canvas的用法 博客:http://blog.taorenjia.com/?p=237 1.drawCircle(float cx, float cy, float radius, ...