本教程将使用Visual Studio 2013手把手教你实现webform动态页面的伪静态。本教程配套的C#源码工程可通过我的github下载。地址:https://github.com/shellcheng/ReWirteWebform

本文地址:WebForm伪静态实现及ISAPI_REWRITE介绍

本教程由技术爱好者成笑笑(博客:http://www.chengxiaoxiao.com/)写作完成。如有转载,请声明出处。

本教程内容:

  • 伪静态介绍、作用

  • 用代码实现简单的伪静态

  • ISAPI_REWRITE组件的介绍及使用

1.伪静态介绍、作用

1.1伪静态介绍、作用

1.1.1为什么要伪静态

在搜索引擎优化领域,静态页面的权重是大于动态页面的权重的。例如index.aspx会大于index.aspx?id=1的权重。通常情况下,动态页面中?后面的参数是读取数据库内容显示在前台页面上的。

很显然如果id不同所展现的数据也是不同的。但搜索引擎会把所有的页面例如:index.aspx?id=1、index.aspx?id=2等所有的动态页面,认定为同一个页面index.aspx。为了增强搜索引擎的友好度,提高收录,我们需要实现把动态内容静态化。

1.1.2实现网页静态化

我们很明显可以实现读取数据库内容根据模版生成对应id的静态页面。但是像淘宝京东等数以万计的商品之下,所占用的存储是海量的,需要大量的硬盘存储来存储这些静态网页。这是很理想的状况,但是现实是无法做得到的。

所以伪静态闪亮登场~~~

1.1.3什么是伪静态?

伪静态就是我们把以前的动态参数放入url中通过后台逻辑,显示对应的数据。说白了就是,把我们以前的index.aspx?id=1的地址改为index-1.aspx页面(具体的伪静态的规则自己可以随便写的,在这里只是举例子),把动态参数去掉。我们在后台写相应的代码实现读取数据显示。

2.用代码实现简单的伪静态(WebFrom版本)

2.1目标:

访问:index-1.aspx。显示index.aspx?id=1的数据

2.2实现过程:

2.2.1:通过Visual Studio 2013新建一个web空项目。

2.2.2新建aspx页面,并在后台页面添加以下代码。

后台处理id参数,查询传递到前台界面。

前台页面显示数据:

至此我们访问index.aspx?id=1显示如下:

2.2.3添加新项Global.asax。

我们主要是重写aspx页面生命周期的Application_BeginRequest方法,获取用户访问的地址,根据正则进行匹配。交由原页面进行处理。

至此我们访问index-1.aspx可以正确显示

3.ISAPI_REWRITE组件的介绍及使用

组件下载地址:https://github.com/shellcheng/ReWirteWebform

使用步骤:

打开IIS---添加ISAPI筛选器-----64位机器需要添加32位和64位版本两个筛选器。

在目录下添加文件名为.htaccess的文件:

写入以下内容。RewirteRule后面的则是伪静态的规则。

微信号:net4k8k(做(4k+8k)+月薪的程序员)

微信名称:net知识分享

介绍:主要以发布和分享.Net和安卓文章为主,争做全栈开发工程师,爱学习,爱挑战,爱编程。

打造C#入门教程。总结自己已经习得的技术体系。分享到网络。为中国的软件复兴贡献自己的一份力。

如有不恰当之处,还请指正。

作者:成笑笑

职业:应届毕业生,找工作中。

本人联系方式:cxx@chengxiaoxiao.com

我的自媒体:

GitHub:https://github.com/shellcheng

My CnBlogs:http://www.cnblogs.com/happpytoo/

今日头条:http://toutiao.com/m5443584213/

一点资讯:http://www.yidianzixun.com/home?page=channel&id=m21753

新浪微博:http://weibo.com/5706473282/

搜狐公众平台:http://mp.i.sohu.com/profile?xpt=NUJENDc2NjZENTIyMjlBRjk4QkIzRDczNTVFMUVFODBAcXEuc29odS5jb20=

C#实现动态网站伪静态,使seo更友好的更多相关文章

  1. 《Linux就该这么学》培训笔记_ch20使用LNMP架构部署动态网站环境

    <Linux就该这么学>培训笔记_ch20使用LNMP架构部署动态网站环境 文章最后会post上书本的笔记照片. 文章主要内容: 源码包程序 LNMP动态网站架构 配置Mysql服务 配置 ...

  2. 编译LNMP部署动态网站环境

    LNMP动态网站部署架构是由一套 Linux+Nginx+MySQL+PHP 组成的动态网站系统解决方案. 以下配置环境为:Linux=RHEL7 --> Nginx=1.13 --> M ...

  3. 网站URL如何SEO优化

    前言 本文讲解网站的URL如何进行SEO优化,并在自己的WordPress博客echeverra中优化URL. 起因 对于SEO我了解的并不多,只知道SEO做的好,那么各大搜索网站搜索你网站相关内容时 ...

  4. 使用JSP开发动态网站基础

    1. 什么是动态网页? 动态网页是指在服务器端运行的程序或者网页,它们会随不同客户.不同时间,返回不同的网页. 注意:在静态网页中插入flash ,虽然flash是在动的,但是并不是说这个网页就是动态 ...

  5. JSP动态网站环境搭建应用中的详细步骤(Tomcat和Apache/IIS的整合)

    链接地址:http://www.cnblogs.com/dartagnan/archive/2011/03/25/2003426.html JSP动态网站环境搭建应用中的详细步骤(Tomcat和Apa ...

  6. Linux中什么是动态网站环境及如何部署

    当谈论起网站时,我们可能听说过静态和动态这两个词,但却不知道它们的含义,或者从字面意思了解一些却不知道它们的区别. 这一切可以追溯到网站和网络应用程序,Web应用程序是一个网站,但很多网站不是Web应 ...

  7. nginx详解反向代理、负载均衡、LNMP架构上线动态网站(week4_day1_part1)-技术流ken

    nginx介绍 Nginx是俄罗斯人编写的十分轻量级的HTTP服务器,Nginx,它的发音为“engine X”,是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/POP3/SMTP 代理 ...

  8. 简单 PHP + MySQL 数据库动态网站制作 -- 摘抄

    在这篇文章中,我尽量用最浅显易懂的语言来说明使用 PHP, MySQL 制作一个动态网站的基本技术.阅读本文需要简单的 HTML 基础知识和(任一编程语言的)编程基础知识(例如变量.值.循环.语句块的 ...

  9. [Python之路] 使用装饰器给Web框架添加路由功能(静态、动态、伪静态URL)

    一.观察以下代码 以下来自 Python实现简易HTTP服务器与MINI WEB框架(利用WSGI实现服务器与框架解耦) 中的mini_frame最后版本的代码: import time def in ...

随机推荐

  1. PCB 敷铜间距规则(转)

    第一优先规则: First Object = InPolygon, Second Object = All 第二优先规则:First Object = All, Second Object = All ...

  2. Android 4.0设计规范 优先导读 十大改变

    在拜读和翻译了 Android design 设计指导后,对比 Android 4.0 与 Android2.3 及之前版本的 app 设计指导,总结了 Android 4.0 设计的 10 大改变: ...

  3. statspack系列2

    Analysing Statspack 2       命中率陷阱 原文:http://jonathanlewis.wordpress.com/2006/12/27/analysing-statspa ...

  4. WordPress Videowall插件‘page_id’参数跨站脚本漏洞

    漏洞名称: WordPress Videowall插件‘page_id’参数跨站脚本漏洞 CNNVD编号: CNNVD-201310-502 发布时间: 2013-10-23 更新时间: 2013-1 ...

  5. Jersey+Spring+Maven(转)

    spring和maven的搭建参考相关文档.本文只介绍与jersey有关配置. 一.jersey在maven中的依赖包 <!-- jersey --> <dependency> ...

  6. c++ lambda返回类型自动推导的一些需要注意的地方

    一句话,lambda返回类型自动推导走的是auto,而不是decltype,注意. class ObjectA { public: ObjectA() { val_ = ++g; } ObjectA( ...

  7. HDU-2561 第二小整数

    http://acm.hdu.edu.cn/showproblem.php?pid=2561 第二小整数 Time Limit: 3000/1000 MS (Java/Others)    Memor ...

  8. 获取和设置select和checkbox的值

    if ($("input[name = 'recpower']").prop("checked") == true) //获取checkbox值 { data. ...

  9. CSS浏览器兼容性----Hack

    CSS Hack大致有3种表现形式,CSS类内部Hack.选择器Hack以及HTML头部引用(if IE)Hack,CSS Hack主要针对IE浏览器.类内部Hack:比如 IE6能识别下划线&quo ...

  10. JavaScript高级程序设计29.pdf

    insertAdjacentHTML方法 插入标记最后一个新增的方式是insertAdjacentHTML()方法,它接收两个参数:插入位置和要插入的HTML文本,第一个参数必须是下列值之一: &qu ...