用server.transfer隐藏网页真实地址
作者:rainoxu 来源:小鹤与独角兽 发布时间:2007-12-04 13:02:00
经常在网站上看到诸如www.abc.com/?news或者www.abc.com/?id=123这样的网址,一开始觉得很神秘,其实现在看多了,用得多了,也觉得没那以多深奥的技术,就是用一些最简单的方法就能实现,以asp为例,用好server.transfer这个方法就可以实现以上的功能了。
假设地址是www.abc.com/?news,如何显示我们需要的news.asp呢?首先要先明白,不论什么服务器,都会有一个缺省页,比如你把index.html或者index.htm上传到主页空间,输入网址,默认总是会转到index页面上,主机默认index.html(index.htm)为缺省页,当然,index.asp也是一样的,不过当这几个页面同时出现时,先显示哪一个,就看服务器的设定了。现在我们在目录下新建一个index.asp,假设访问的路径是www.abc.com/,那么对于这个地址我们也是可以用www.abc.com/index.asp来访问的,而前者就把index.asp给隐藏了。
现在我们来实现用www.abc.com/?news来指向news.asp,打开index.asp,编辑它的源文件,如下:
<%
dim targetPage
targetPage=request.querystring()
if targetPage<>"" then
server.transfer(targetPage+".asp")
end if
%>
这里用的是request.querystring()来接收字符,因为我们的请求字符串是?news,而并不是像传统的类似于变量名对应变量值的形式,所以我们用request.querystring()的方法来取得“?”后面的所有字符。这里我们得到了字符串“news”。接下来判断一下,如果不是空串就将它转化成new.asp,并用server.transfer转向,这里,之所以用server.transfer,你会发现,页面转向了,但浏览器地址栏却没有变,不会因为转向而变成了www.abc.com/new.asp,就是基于server.transfer这个原理,才能实现隐藏访问页面的目的。
不过样的形式太简单,还是很容易让人猜到真实地址,那就再深入一步吧,做一个地址映射表,原理也不难,建立一个数组,将你要转向的地址名写进去,然后通过www.abc.com/?arrayID的形式来访问,其中arrayID是地址对应的数组下标。就举个例子来说吧:
<%
dim targetPage,urlTable(4)
targetPage=request.querystring()
urlTable(1)="news.asp"
urlTable(2)="list.asp"
urlTable(3)="homepage.asp"
urlTable(4)="login.asp
server.transfer(urlTable(targetPage))
%>
如果我们要访问news.asp,则可以用www.abc.com/?1,这样的地址映射在地址信息中不容易让人猜到文件的命名方法,自然是保密性高了不少,不过这种方法对于过多地址转向,数组的体积就会增长,也不是一种很好的方法,在维护时也不是很容易。
相比之下,第一种方法在网上使用的似乎也挺普遍的,第二种,也有使用,另外,对于地址信息的编码,以及在index.asp中对转向功能进一步强化,引入各种加密机制,也是能够达到隐藏真实页面的目的。而作为我,只是抛砖引玉,就介绍这些最简单的东西,如果要使用到实际,自然是需要添砖加瓦的。


猜你喜欢
- 写在前面当然这里说的百分百可能有点夸张,但其实想象一下,游戏里面的某个窗口的字符就是那种样子,不会变化的。而且识别的字符可能也不需要太多。中
- 这篇文章主要介绍了Python Django 简单分页的实现代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习
- 今天在学习vue的过程中,发现一个有趣的现象。在某一组件下的某一数据通过点击事件被动态修改的时候,对应view中的数据同步的进行了修改,没错
- ClickHouse是近年来备受关注的开源列式数据库(DBMS),主要用于数据联机分析(OLAP)领域,于2016年开源。目前国内社区火热,
- 本文实例讲述了python实现爬取千万淘宝商品的方法。分享给大家供大家参考。具体实现方法如下:import timeimport level
- 一. 布隆过滤器简介布隆过滤器可以用于检索一个元素是否在一个集合中。它的优点是空间效率和查询时间都比一般的算法要好的多,缺点是有一定的误识别
- 原因:list 获得的数据为空: 显示值为 [ ]不同的判断--- is None----not两者结果不一样分析:总之:not 判断的是内
- 带你了解CGO编程大学时最开始学的语言莫过于C/C++,C/C++经过几十年的发展,已经积累了庞大的软件资产,它们很多久经考验而且性能已经足
- 今天小编利用美丽的汤来为大家演示一下如何实现京东商品信息的精准匹配~~HTML文件其实就是由一组尖括号构成的标签组织起来的,每一对尖括号形式
- 介绍目前它是Python数值计算中最为重要的基础包,将numpy的数组的对象作为数据交互的通用语,一般我们要充分理解好矩阵计算的原理,这需要
- 利用可视化探索图表1.数据可视化与探索图数据可视化是指用图形或表格的方式来呈现数据。图表能够清楚地呈现数据性质, 以及数据间或属性间的关系,
- Mysql可以通过运算符来对表中数据进行运算,比如通过出生日期求年龄等运算符包括四类,分别是:算数运算符、比较运算符、逻辑运算符和位运算符算
- 最近研究验证码识别,需要生成大量验证码,最方便的是使用captcha库来生成验证码,网上代码仅仅使用默认设置,但是它还有很多参数可以设定,于
- 设计思路本文整理归纳以往的工作中用到的东西,现汇总成基础测试框架提供分享。框架采用python3 + selenium3 + PO + ya
- 在asp中利用excel的一个方法是将excel文件作为一个数据库进行链接,然后的操作和对access数据库操作类似.但是这个方法不是总能有
- 1 基本信息- 模块主页:[github]- 类型:#第三方库2 安装方法pip install pythonping3 一般使用from
- 最近写了两个管理后台的前端页面,其中有一个管理后台,左侧菜单导航和右侧内容页是两个iframe,需求是,点击上面的主导航时,左侧iframe
- 1:安装xlsx和file-savernpm install file-saver xlsx --save2:创建localEx
- 周一 至 周日 时间格式化转化(Y --- 年 M --- 月 D--- 天)
- 什么是MD5?MD5信息摘要算法(英语:MD5 Message-Digest Agorithm),一种被广泛使用的密码散列函数,可以产生出一