admin 管理员组

文章数量: 1086019


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编码格式另存为的文本文件。再在浏览器中打开,终于又显示正常了。又是个弱弱的问题,我怎么就这么笨^_^ 不过还算好我也知道静态页面化是怎么做的了。


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

更多相关文章

Windows设置HTML,windows怎么添加静态路由

2月前

windows添加静态路由的方法&#xff1a;1、按下【winx】组合键&#xff0c;选择并打开命令提示符&#xff1b;2、执行【route -p add 10.10.10.0 nask 255.255.255

jQuery判断当前页面是APP内打开还是浏览器打开

2月前

一、代码如下&#xff1a; function check_useragent(){var browser{versions: function() {var unavigator.userAgent, appnavig

Vue3 - 实现路由 “新开一页“ 进行页面跳转功能,Router 路由跳转时在新窗口打开页面(网站跳转页面时浏览器新开页签打开网页,支持在页面、纯 jsts 文件中使用,详细示例代码教程)

2月前

前言 网上这方面教程很少,本文提供多种解决方案,适用于任何场景。 本文 实现了在 vue3 项目开发中,当页面跳转时浏览器打开新窗口(新页签)跳转,Router 路由跳转并新开一页教程, 无论您是在普通页面、纯 jsts 文件中,都可以

android用支付宝打开指定链接,手机浏览器唤起支付宝并打开指定页面

2月前

原文链接&#xff1a;https:blog.csdnsun5769675articledetails89634633 支付宝的红包功能让一批人先富了起来&#xff0c;很多大大小小的网站都嵌入了领红包的脚本一点

电脑浏览器页面跑到最左侧,无法移动

2月前

1.问题描述 今天用电脑的时候&#xff0c;不知道点了哪个地方&#xff0c;浏览器页面就跑到了屏幕的最左侧&#xff0c;怎么操作页面都不显示。 2.解决方案 ①wintab键 在弹出的页面中选择咱们的浏览

浏览器上禁止用户用调试方式打开页面

1月前

今天分享一个有趣的东西&#xff0c;我们浏览器可以通过F12或者鼠标右键的形式打开html页面&#xff0c;然后就可以看到页面的的信息&#xff0c;如dom结构&#xff0c;加载文件、请求信息等。那有

微信中打开页面提示已停止访问无法跳转到外部浏览器怎么办

1月前

在我们使用微信营销的时候&#xff0c;很容易碰到推广连接在微信内无法打开或无法下载app的情况。 首先说一下推广域名在微信内无法打开的问题&#xff0c;这是因为微信将您的域名拦截导致&#xff0c;所以在微信内打

Win11商店无法加载页面怎么办 Win11应用商店打不开怎么办

1月前

很多用户都升级了Win11系统&#xff0c;升级了系统就想要下载一些新的软件来丰富自己的系统。但是升级了Win11系统之后就无法加载应用商店的界面了&#xff0c;打不开微软的应用商店该怎么办呢?小编给大家带来了一个解决办

windows系统cmake生成c++动态库无lib文件解决方法 &amp;&amp; bat文件批处理cmd命令

1月前

作为cmake初学者&#xff0c;在windows系统下使用cmake生成c动态库时出现了下图所示问题&#xff0c;是关于lib文件的。找了一圈&#xff0c;也没发现生成有lib文件。 在google上查&am

html页面判断是否是微信浏览器打开,JS判断是否在微信浏览器中打开

1月前

在开发微信项目时&#xff0c;有需要用到判断是否在微信浏览器中访问&#xff0c;比如&#xff0c;限制非微信访问。 主要有三种方法 一、var ua  navigator.userAgent.toLowerCa

爬虫Selenium+Chrome 控制浏览器,打开百度网页,输入搜索关键词,点击回车,截取搜索页面

1月前

输入关键词&#xff0c;百度搜索内容&#xff0c;生成搜索结果页面照片from selenium import webdriverfrom time import sleepfrom selenium.webdri

在html中页面不全,网页显示不全,教您网页显示不全怎么办

1月前

当我们在电脑系统中使用IE浏览器浏览网页时&#xff0c;偶尔会出现是否只查看安全内容的提示&#xff0c;甚至有可能会出现页面显示不全的情况。一般遇到这种情况会选择继续查看网页内容&#xff0c;怎么去处理&

python打开浏览器不显示浏览器页面_python+selenium 浏览器无界面模式运行

27天前

方法一: from selenium.webdriver import Chrome, ChromeOptions opt = ChromeOptions() # 创建Chrome参数对象 opt.headless = True # 把Ch

浏览器一打开就跳转到啊指定页面

27天前

浏览器一打开就跳转到到指定页面 我明明在设置中设置的百度&#xff0c;如图可是每次打开都是顶一个导航页&#xff0c;气死人&#xff0c;结果看这里&#xff1a;流氓软件把启动的打开地址改了&

Window 10 系统EDGE浏览器使用IE模式加载页面

27天前

1、在EDGE浏览器地址输入页面&#xff0c;直接打开页面 2、在浏览器右上角三个点&#xff0c;点击展开&#xff0c;点击使用IE模式下重新加载 3、在弹出的提示框中&#xff0c;勾选下次再IE模式

vue动态修改浏览器标签页名称

27天前

在mian.js添加以下代码 import router from ".router";router.beforeEach((to, from, next) > {console.log(to, from, n

在C++ Builder中打开浏览器加载页面

27天前

今天在开发项目的时候&#xff0c;要求实现根据数据查询出来的一个IP地址&#xff0c;并返回到前台使用浏览器打开。这个东东本身很简单哈。在C Builder 中有对应的API函数&#xff0c;下面我们一起来讲讲

通过js就可以判断当前页面是在什么浏览器打开的

27天前

<!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title><title> <h

gitlab开启了双因子认证,一次码和手机动态码都失效了怎么办

27天前

背景&#xff1a; 我是gitlab的管理员&#xff0c;我们系统开启了双因子认证&#xff0c;登录必须输入密码和一个动态码&#xff0c;经常有的同事会存在10次性码没有保存或者失效、手机上的动态码也

ipynb文件过大导致jupyter notebook打不开,页面卡怎么办

27天前

这种情况一般是因为print的内容太多&#xff0c;jupyter页面无法显示。因此&#xff0c;将ipynb文件导出来&#xff0c;用其他软件打开&#xff0c;删除block里面pint的结果&am

发表评论

全部评论 0
暂无评论