当前页:网页制作 >>>关于Request.ServerVariables
关于Request.ServerVariables
责任编辑:黄舒奇  发表时间:2007-09-20  最后修改时间2016-05-25

Request.ServerVariables("HTTP_REFERER")
用来获取(从哪个页面转到当前页面的) & 路径
常用来转到某一网址
response.redirect Request.ServerVariables("HTTP_REFERER")
用来判断是不是从某个网址链接过来的也一错,可以防址盗链
下面判断是不是从主面进来,
server_vv=len(Request.ServerVariables("SERVER_NAME"))'取得WWW名,不好说大概就是这个意思
server_v1=left(Cstr(Request.ServerVariables("HTTP_REFERER")),server_vv)'取得本页路径的主HTTP
server_v2=left(Cstr("http://"&Request.ServerVariables("SERVER_NAME")),server_vv)取得带HTTP名
if server_v1<>server_v2 and server_v1<>"" and server_v2<>"" then
response.write("<script>alert('错误:禁止从站点外部提交数据!.')</script>")
response.end

再来一个简单的防盗程序
sServerName = LCase(Request.ServerVariables("SERVER_NAME"))
sReferrerpage = LCase(Request.ServerVariables("HTTP_REFERER"))
'//盗链检测
If InStr(sReferrerPage,sServerName)<1 then
Response.Redirect("/Error.asp?IllegalLink")
End If
InStr 函数 返回某字符串在另一字符串中第一次出现的位置。
上面的也就是说,如果没有主机这个名字值小于1(怎么是数字值呢)
就转到错误页面

Request.ServerVariables的所有值!

ALL_HTTP=HTTP_ACCEPT:image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */* HTTP_ACCEPT_LANGUAGE:zh-cn HTTP_CONNECTION:Keep-Alive HTTP_HOST:localhost:88 HTTP_USER_AGENT:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322) HTTP_COOKIE:ASPSESSIONIDSQBTBADS=HDDLKAKAAJDKPHHBNBBAACLH HTTP_ACCEPT_ENCODING:gzip, deflate
ALL_RAW=Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */* Accept-Language: zh-cn Connection: Keep-Alive Host: localhost:88 User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322) Cookie: ASPSESSIONIDSQBTBADS=HDDLKAKAAJDKPHHBNBBAACLH Accept-Encoding: gzip, deflate
APPL_MD_PATH=/LM/W3SVC/1/Root/xml
APPL_PHYSICAL_PATH=C:\Documents and Settings\khaspc\桌面\olcr_1\1\
AUTH_PASSWORD=
AUTH_TYPE=
AUTH_USER=
CERT_COOKIE=
CERT_FLAGS=
CERT_ISSUER=
CERT_KEYSIZE=
CERT_SECRETKEYSIZE=
CERT_SERIALNUMBER=
CERT_SERVER_ISSUER=
CERT_SERVER_SUBJECT=
CERT_SUBJECT=
CONTENT_LENGTH=0
CONTENT_TYPE=
GATEWAY_INTERFACE=CGI/1.1
HTTPS=off
HTTPS_KEYSIZE=
HTTPS_SECRETKEYSIZE=
HTTPS_SERVER_ISSUER=
HTTPS_SERVER_SUBJECT=
INSTANCE_ID=1
INSTANCE_META_PATH=/LM/W3SVC/1
LOCAL_ADDR=127.0.0.1
LOGON_USER=
PATH_INFO=/xml/request.s.asp
PATH_TRANSLATED=C:\Documents and Settings\khaspc\桌面\olcr_1\1\request.s.asp
QUERY_STRING=
REMOTE_ADDR=127.0.0.1
REMOTE_HOST=127.0.0.1
REMOTE_USER=
REQUEST_METHOD=GET
SCRIPT_NAME=/xml/request.s.asp
SERVER_NAME=localhost
SERVER_PORT=88
SERVER_PORT_SECURE=0
SERVER_PROTOCOL=HTTP/1.1
SERVER_SOFTWARE=Microsoft-IIS/5.1
URL=/xml/request.s.asp
HTTP_ACCEPT=image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*
HTTP_ACCEPT_LANGUAGE=zh-cn
HTTP_CONNECTION=Keep-Alive
HTTP_HOST=localhost:88
HTTP_USER_AGENT=Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)
HTTP_COOKIE=ASPSESSIONIDSQBTBADS=HDDLKAKAAJDKPHHBNBBAACLH
HTTP_ACCEPT_ENCODING=gzip, deflate

每个类都创造了有自己的名字空间,指方法和变量可以知道彼此的存在,可以使用.public类不但可以被同一程序包中的其它类使用,别的程序包中的类也可以使用; 变量和方法的修饰字public、protected、private:
public:任何其他类、对象只要可以看到这个类的话,那么它就可以存取变量的数据,或使用方法。
class ABC{
public int pub_i=5;
public void show)(){
System.out.println("pub_i"+pub_i);
}
class Demo{
public static void main(String args[]){
ABC abc=new ABC();
System.out.println("abc.pub_i"+abc.pub_i);
abc.pub_i=10;
abc.show();
}
}
protected变量和方法:
如果一个类中变量或方法有修饰字protected,同一类、同一包可以使用。不同包的类要使用,必须是该类的子类,可以存取变量或调用。
public class ABC{
protected int pro_i=5;
protected void show(){
System.out.println("pro_i=" +pro_i);}
}
同包的类:
class DEF{
public static void main(String args[]){
ABC abc=new ABC();
System.out.println("abc.pro_i="+abc.pro_i);
abc.pub_i=10;
abc.show();
}
}
不同包但是是子类:
import mytest.pack.ABC;
class DEF extends ABC{
public static void main(String agrs[]){
DEF def=new DEF();
System.out.println(def.i);
def.i=10;
def.show();}
}
private不允许任何其他类存取和调用;
当子类中的变量名与父类的相同,原来的变量被遮盖。
方法的覆盖(overriding)和重载(overloading)。子孙类中定义的方法和祖先类中某个方法同名、同参数行,则祖先类中的该方法被覆盖;方法的重载是指一个对象的多态性,即多个方法用相同的名称,但参数行不同。
final:
final在方法之前,防止该方法被覆盖;
final在类之前,标是该类不能被继承;
final在变量之前,定义一个常量。
static:
在变量或方法之前,表明它们是属于类的;
静态变量在各实例间共享,如果是public静态变量,则其它类可以不通过实例化访问它们;
静态方法称为类的方法,因此不用实例化即可调用(面向过程)
一个对象的方法可以访问对象的数据成员,尽管不属于方法的局部变量;一个类的方法只能访问自己的局部变量。
例:不正确的引用
class StaticError{
String mystring="hello";
public static void main(String args[]){
System.out.println(mystring);}
}
错误信息:can’t make a static reference to nonstatic variable.
为什么不正确?只有对象的方法可以访问对象的变量。
解决的办法:
1) 将变量改称类变量
class StaticError{
static String mystring="hello";
public static void main(String args[]){
System.out.println(mystring);}
}
2) 先创建一个类的实例
class NoStaticError{
public static void main(String args[]){
String mystring="hello";
System.out.println(mystring);}
}
}