admin 管理员组

文章数量: 1184232


2024年2月24日发(作者:学完python后学c语言)

静态化页面实现学习 by widebright 静态化页面是指使用动态页面语言编程,生成*.htm静态页面文件。好像这个技术很流行!看象百度知道,没一个问题都是一个html文件,163新闻评论页面也都是html页面。所以在网上搜索了一下相关的资料。 为什么都喜欢采用静态页面化?听说是有以下有点:1、 提高服务器性能, *.aspx之类的动态页面毕竟是还要经过服务器解析处理的,而静态页面服务器只要返回相应的文件就可以了。怎么说静态面效率也要高一点啦。2、说是安全性高(可能是说不用担心SQL注入这些东西了,静态页面啊,当然没有这个了)。3、容易被搜索引擎收录(好像网页搜索引擎处理静态页面更容易一点,想也是动态页面还要请求啊什么的)。 可能还有其他有点我就不知道了。不过我个人觉得要不要采用静态化网页也还是要考虑一下的,动态网页的性能也没有象想象的那么差,大多数的时候还是能够满足要求的,象微软自己的网页MSDN, 论坛也没有去实现静态页面化。看了一下高手的分析,说是动态的网页便于控制权限,新闻的内容生成系统CMS 采用静态页面化确实可以提高系统性能。要不要采用这项技术还是自己考虑吧。中的实现方法:查找了很多资料,说我看到的一些实现方法。1. url重定向。就是在服务器端采用url重定向,把你对静态页面的请求转到动态页面上去。你访问/ 其实是转到/?id=254去了。 这个其实是假的静态化页面,他根本就没有静态页面的存在。 对URL重写转向的支持,在Apache服务器上由一非缺省模块(mod_rewrite)来完成,而在IIS下也同样有类似的模块,分别是ISAPI REWRITE及IIS REWRITE。无论是在Apache下还是在IIS下,重写转向的语法都基于正则表达式,只有少量的不同。这个IIS重定向ISAPI是要额外安装扩展才有的,有需要的可以自己在网上找一下。 在下面也可以通过实现http handler 或者http module 模块来实现,象有一个.net 平台的Ajax组件也是通过实现http handler 来整合的,关于http handler的实现在我的文件上传组件那篇文章里也有提及,感兴趣的自己学习吧。个人觉得是可以做到url静态请求转换到动态请求页面的这种url映射功能的。 不过这种方法是要稍稍影响性能的,毕竟多了个ISAPI的环节。2、采用xml文件,结合xlst文件。这种方法很多人都知道,因为CSDN论坛就是这么做的。我个人对xml方面的技术不太了解也不感兴趣。想了解这方面资料的自己找去吧,反正是通过xlst文件(模版)自动显示xml文件的内容出来。3.采用Ajax技术,采用这个当然可以做到静态页面了。4.采用html模版替换技术。就是预先写个html模版文件,然后在生成静态页面时进行替换。这种方法实现起来很容易,也是我想到的方法。网上有很多例子,我就不详细说了。比如写象下面一样一个模版 :…………titlecontent

生成静态页面的时候用个 e方法把 title content 等替换成你自己的具体的内容就行了。静态页面的生成可以选择在有数据更新的时候,比如一张帖子又有人回复了,就可以重新生成这张帖子的html文件。当然你这个html模版可以做的更复杂一些了,比如加入css等等啦。静态页面评论功能的实现:这也是一开始不理解的地方,看网易新闻,百度知道,都是html静态页面都还可以回复,发表评论等。这些评论、回复是要保存到数据库里面去的,不是动态页面才能实现的功能吗?我一开始感到很奇怪。综合众人的说法,网页点击技术等可以通过在 include 页面外javascript脚本的时候指定src为一个asp之类的动态网页,在那个动态页面实现计数等功能。评论功能的实现有人说在页面下端加一个iframe来显示。在iframe里加一个动态页面确实可以做到的,不过我觉得好像和直接采用动态页面没多大区别。 还是看看别人是怎么做的吧。我随便打开了个百度知道的页面,查看了一下页面的源代码:

checkcoAndsn(this,'回答');">

我也来回答:

回答即可得2分,回答被采纳则获得悬赏分以及奖励20分。

href="/search/zhidao_#n4">积分规则

回答字数在10000字以内

参考资料:

onKeyDown="ctlSubmit(event);">

如果您的回答是从其他地方引用,请表明出处。

 
可以看到其中的回复的一段如上面所示, 这个段是采用一个form标签框起来的。 好象有几个地方和特殊:比如 form的action属性 ,可能是我以前没做接触网页设计原因吧。我在网上查了一下这个属性,原来表示回复接受数据的网页的。 这样通过点击

type="submit" value="提交回答" class="bnsrh"> 这个按钮提交form页面的时候,这个form的数据就发送到action指定的地址去,由action指定的地址处理数据。明显可以再这里指定个动态网页然后再那个页面上进行处理,完成品评论/回复的提交功能。 至于 form标签中的那个method属性却是表示数据提交的方式。method为post的时候,数据是通过http来传送,数据传过去也可以在数据这里得到,如果method为get的时候,数据是编码后提交到url请求那里,在地址栏中显示出来,在接受页面可以通过得到这些数据。再查看了163网页的新闻评论那里,就更加清楚了,他那里action指向的就是一个jsp文件,静态页面提交的评论数据都是在jsp动态页面上处理的了。

action="/reply/" onSubmit="return reply_checksubmit();">

我的灌水记录
匿名发表

name="frmsubmit" type="submit" value="提 交" class="s1" />还可以看到的是百度知道中还有这样的代码:这些数据可能是在生成静态页面的时候插进去的,这些hidden 控件的value可以用来在接受回复的时候区分帖子ID等,比如19229897这个就是因为 他对应的静态页面是。

我还发现一个现象那就是163新闻评论的页面,其实也只是第一个页面是静态的而已,如果一个评论有多页的话,后面的页面也都是jsp动态页面了。这也是应该注意的一个地方吧! 静态页面化应用在象新闻啊这些一发布上去就不会变化的页面比较好一点。如果你的内容是不断更新很快的,你也采用这种技术,那么就要不断的重写静态html页面,那样IO操作对服务器性能影响也就很大。所以象索引页这样更新频繁的页面是不能实现静态化的,象百度知道的主页,如果采用静态页面化的话,那么没当有个人发一个提问,就要重写一下html页面,可能就回很慢了。高手的说法是采用缓存来提高性能,象CSDN开发人员说还说什么双缓存技术啊等等。缓冲页面、数据应该在提高性能方面起很大作用的吧,有时间要学一学。 好了不说了,说得越多越显得我没有水平^_^

写了个实现,验证一下form 的action属性的功能是否象我想的一样可以做静态页面的评论功能的实现的(其实我之前又再找了下资料,确实是这样子用的,有人也说到了做法,是我自己太差了,连这么一个普通的属性都不懂)。----------------页面 代码-------------------------

------------------------------------------------------------动态接受页面代码----------------------------<%@ Page language="c#" Codebehind="" AutoEventWireup="false"

Inherits="m1" %> WebForm1

---------------------------------------------------------------------动态接受页面代码----------------

using System;using tions;using entModel;using ;using g;using ;using nState;using ;using trols;using ntrols;namespace dddddd{ ///

/// Summary description for WebForm1. /// public class WebForm1 : { private void Page_Load(object sender, rgs e) { // Put user code to initialize the page here string content = ["content"]; if (content != ) {

("content="); (content);

} else { ("出现错误"); }

}#region Web Form Designer generated codeoverride protected void OnInit(EventArgs e){

// // CODEGEN: This call is required by the Web Form Designer. // InitializeComponent(); (e); }

///

/// Required method for Designer support - do not modify /// the contents of this method with the code editor. /// private void InitializeComponent() {

+= new andler(_Load); } #endregion }}---------------------------------------------------------动态页面也就是接受到静态页面的数据之后直接输入而已,实际应用中,可能要作些数据库保存记录,然后根据模板重写 html文件更新静态页面,然后还可以重定向到这个页面上去。需要注意的是,如果在中form method指定为get的话,那么在动态网页这边只能使用

["content"]来获取数据了, 这时 ["content"]等不到数据了,不过如果method指定为post的话,应为传上来就是form变量,所以["content"]和["content"]都可以得到数据。不明白就查一下 method还有、的区别了。不过我做的时候还发现上面的代码出现回复提交中文的时候出现乱码的情况。明显是编码问题,在 标签之间加上charset=utf-8">一句指定网页编码。变成下面这样,在提交中文就不会乱码了。-------------------------------------------------

--------------------------------------------------------------------------------------------------------------------<%@ Page language="c#" Codebehind="" AutoEventWireup="false"

Inherits="m1" %> WebForm1

-------------------------------------------------------------------不过这回页面中文直接就显示乱码了。我用记事本打开按uft-8编码格式另存为的文本文件。再在浏览器中打开,终于又显示正常了。又是个弱弱的问题,我怎么就这么笨^_^ 不过还算好我也知道静态页面化是怎么做的了。


本文标签: 页面 静态 采用 动态

更多相关文章

最新棕色羽毛鼠标图标下载与动静态应用实战

4月前

本文还有配套的精品资源&#xff0c;点击获取简介&#xff1a;在IT领域&#xff0c;用户界面&#xff08;UI&#xff09;设计对用户体验至关重要。本文围绕“最新棕色羽毛鼠标下载&

电脑动态IP改成静态IP无法上网

4月前

1&#xff0c;电脑原本动态IP&#xff0c;在cmd里ipconfig以后得到 192.168.100.32. 通过ping命令 192.168.100.1-255 任何一个网段都ping不通&#xff0c;导

jmeter压测学习48- BadBoy录制web网站登录页面脚本

4月前

前言web网站的登录通常会发多个请求&#xff0c;对于初学者不确定填写哪些请求的可以使用 BadBoy 录制在页面上的操作&#xff0c;自动记录操作后的请求。录制完成后可以导出 jmeter 脚本&#xff0

关闭浏览器时实现用户登出(关闭页面时不登出)——全网最有用

4月前

1、 登录时设置cookie标志位try {const resultawait login({account: values.mobile,password: shajs(sha1).update(values.password).d

Comprehensive Rust Clippy:静态分析与代码质量提升

4月前

Comprehensive Rust Clippy&#xff1a;静态分析与代码质量提升 【免费下载链接】comprehensive-rust 这是谷歌Android团队采用的Rust语言课程&#xff0c;它为你提供了快速

动态爬虫之手机版QQ空间登录

4月前

准备: 1、intellij idea 2、python 3、selenium 4、phantomJs 1、分析Qzone Html页面 打开手机版qzone https:mobile.qzone.qq 动态爬虫之手机版QQ空间登

浏览器打开新的页面时自动打开控制台

4月前

需求打开浏览器新tab时自动打开控制台&#xff0c;捕捉初次的网络请求解决在浏览器图标属性中加入以下代码&#xff0c;再次打开浏览器--auto-open-devtools-for-tabs

从静态到智能:Web技术的演进与未来展望

4月前

大家好&#xff0c;今天想和大家深度拆解我们每天高频接触&#xff0c;却鲜少深究的「Web 世界」。从最初仅能承载文字与图片的静态页面&#xff0c;到如今集沉浸式交互、智能服务、全端适配于一体的复杂应用生态&a

解决safari浏览器打开页面会报错` Invalid Date`问题

3月前

使用<nz-date-picker nzShowTime nzFormat"yyyy-MM-dd HH:mm:ss" formControlName"startDate"><nz

由于启动计算机时出现了页面配置问题,我经历了从困惑到解决的完整过程

3月前

.code-box {background-color: #f4f4f4;border: 1px solid #ddd;padding: 10px;position: relative;overflow: auto;margi

微软原版Windows系统:打造你的专属高效工作空间!

2月前

1、进入微软官网 微软官网地址:,点击导航栏上的 Windows按钮:2、进入WINDOWS支持页面 进入 windows页面后,拉倒页面的最底下,点击

打造完美桌面体验——选择微软官方正版Windows系统无后顾之忧!

2月前

1、进入微软官网 微软官网地址:,点击导航栏上的 Windows按钮:2、进入WINDOWS支持页面 进入 windows页面后,拉倒页面的最底下,点击

Windows 10新手必学:ISO镜像安装术,掌握技术,无需工具也能畅享操作

2月前

不用工具直接从微软官网下载Win10正式版ISO镜像的技巧 发表于2018年12月25日 23:21:24由MS酋长 我们在重装Win10系统时需要用到ISO镜像,并且微软官网也有专门的“”页面,但问题是,你打开

Win10、7 都有 IP 冲突?一文教你彻底解决方法!

2月前

1. 重启路由器: - 首先,最简单的解决方法是重启您的路由器或网络设备。这样可以刷新DHCP服务器的租用列表,并重新分配IP地址给连接的设备。 2. 手动设置静态IP地址: - 如果重启路由器后问题依然存在,

Flash世界里的连通性:当B页面挂掉,如何通知A页面?

2月前

本题是 html 页面通信题,可以拆分成:A 页面打开 B 页面,A、B 页面通信方式? B 页面正常关闭,如何通知 A 页面? B 页面意外崩溃,又该如何通知 A 页面?A 页面打开

淘宝宝贝购物交流的暗语:快速掌握旺旺协议,畅聊无忧

2月前

一、概述 淘宝旺旺是一个即时通讯软件,集成了即时的文字、语音、视频沟通、以及交易提醒、快捷通道、最新商讯等功能,是网上交易必备的工具。淘宝网是阿里巴巴旗下网站,也是中国电子商务诚信联盟发起网站。 淘宝旺旺采用TCP通讯

一文掌握:如何利用Adobe Flash Player制作令人惊艳的图片轮播效果

2月前

activity_main.xml <?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android=&qu

Dive into LinkSys: Easy-to-Follow Instructions for Setting Up Your Router

2月前

其原理大概是:相当于把192.168.1.1当外网,然后再它上获取(静态或者动态)一个IP(如192.168.1.104),再在该IP上建立自己的局域网(192.168.2.1),然后笔记本电脑都在这个192.168.2.1的局域网

Win10文件夹图标怎么改回原样?简便方法大公开

1月前

Win10文件夹图标恢复默认图标的简单方法在Windows 10操作系统中,用户拥有高度的自定义权限,包括对文件夹图标的修改。许多用户为了个性化自己的电脑,会将文件夹图标改为自己喜欢的图案或图标。然而,随着时间的推移,有

掌握Android上的FFmpeg:快速获取MP4文件的截图

1月前

1. 编译ffmepg的库文件: .configure --prefix=homelinuxstudy03.ffmpegarm-reduce-out --enable-static --disable-shared --enab

发表评论

全部评论 0
暂无评论