王朝网络
分享
 
 
 

巧用JavaScript记录网站访问次数

王朝html/css/js·作者佚名  2008-05-20
宽屏版  字体: |||超大  

我们知道Cookie是记录访问你站点的用户的信息,它驻留在用户的硬盘上,如果该用户再次返回你的站点,则该cookie就会被一起发回到你的服务器中,便于你统计和处理重复到访者的信息。在IE4和NS4两个浏览器中,都提供了对Coo

kie的支持,并且允许我们用JavaScript或者VBScript去操作它们。

为了简单了解一下Cookie读写的原理,请看以下例子。

写Cookie:

<

script

>

function

setCookie()

//建立设定Cookie的函数

{

var

the_visits

=

1;

//初始化VISIT,即访问次数为1

var

the_cookie

=

"3Ware=uservisits:"

+

escape(the_visits);

//加入自己的标识符,并用escape函数对Cookie编码

document.cookie

=

the_cookie;//写入Cookie

}

<

/script

>

----

这样,将生成一个字符串3Ware=uservisits:1,就是把一个名为3Ware的Cookie

保存到硬盘里,该Cookie的值就是uservisits:1。当我们读Cookie的时候,只需

寻找名字为3Ware的Cookie,然后用unescape解码,读出访问次数。

读Cookie:

<

script

>

function

readCookie()

{

var

the_cookie

=

document.cookie;

//获得已写的Cookie值

var

broken_cookie

=

the_cookie.split(":");

//找出分隔符

var

the_visits

=

broken_cookie[1];

//读出分隔符后一部分

var

the_visits

=

unescape(the_visits);

//用unescape函数对Cookie解码

document.writeln("Your

visits

is:

"

+

the_visits);

//写出访问次数

}

<

/script

>

这样,将生成一个字符串3Ware=uservisits:1,就是把一个名为3Ware的Cookie

保存到硬盘里,该Cookie的值就是uservisits:1。当我们读Cookie的时候,只需寻找名字为3Ware的Cookie,然后用unescape解码,读出访问次数。

读Cookie:

<

script

>

function

readCookie()

{

var

the_cookie

=

document.cookie;

//获得已写的Cookie值

var

broken_cookie

=

the_cookie.split(":");

//找出分隔符

var

the_visits

=

broken_cookie[1];

//读出分隔符后一部分

var

the_visits

=

unescape(the_visits);

//用unescape函数对Cookie解码

document.writeln("Your

visits

is:

"

+

the_visits);

//写出访问次数

}

<

/script

>

最后在网页中加入“<

script

>setCookie();readCookie();<

/script

>”就

能记住访问的次数了。

但,这个只是基本的原理,实际操作还涉及到Cookie存放的路径,什么时候失效,它的有效作用域在那里,以及检查访问次数是否存在等问题。考虑到以上问题,实际的程序如下:

<

html

>

<

script

Language="JavaScript"

>

function

GookieVal(offset)

//获得Cookie解码后的值

{

var

endstr

=

document.cookie.

indexOf

(";",

offset);

if

(endstr

==

-1)

endstr

=

document.cookie.length;

return

unescape(document.cookie.

substring(offset,

endstr));

}

function

Gookie(name)

//获得Cookie的原始值

{

var

arg

=

name

+

"=";

var

alen

=

arg.length;

var

clen

=

document.cookie.length;

var

i

=

0;

while

(i

<

clen)

{

var

j

=

i

+

alen;

if

(document.cookie.

substring(i,

j)

==

arg)

return

GookieVal

(j);

i

=

document.cookie.indexOf("

",

i)

+

1;

if

(i

==

0)

break;

}

return

null;

}

function

Sookie(name,

value)

//设定Cookie值

{

var

argv

=

Sookie.arguments;

var

argc

=

Sookie.arguments.length;

var

expires

=

(argc

>

2)

?

argv[2]

:

null;

var

path

=

(argc

>

3)

?

argv[3]

:

null;

var

domain

=

(argc

>

4)

?

argv[4]

:

null;

var

secure

=

(argc

>

5)

?

argv[5]

:

false;

document.cookie

=

name

+

"="

+

escape

(value)

+((expires

==

null)

?

""

:

(";

expires="+

expires.toGMTString()))

+((path

==

null)

?

""

:

(";

path="

+

path))

+((domain

==

null)

?

""

:

(";

domain="

+

domain))

+((secure

==

true)

?

";

secure"

:

"");

}

function

Dookie(name)

{

var

exp

=

new

Date();

exp.setTime

(exp.getTime()

-

1);

var

cval

=

Gookie

(name);

document.cookie

=

name

+

"="

+

cval

+

";

expires="+

exp.toGMTString();

}

<

/script

>

<

script

>

var

expdate

=

new

Date();

expdate.setTime(expdate.getTime()

+

(24

*

60

*

60

*

1000

*

365));

if(!(visits

=

Gookie("3wave")))

{

visits

=

1;

Sookie("3wave",

visits,

expdate,

"/",

null,

false);

document.write("这是您第"

+

visits

+

"次光临本站");}

else{

visits++;

Sookie("3wave",

visits,

expdate,

"/",

null,

false);

document.write("您已经第"

+

visits

+

"次光临小站");

}

if(visits<

2)

document.write(",是小站的新手上路,加油哦。")

if(visits

>=2&&visits<

4)

document.write(",是小站的初级站友,不错嘛。")

if(visits

>=4&&visits<

6)

document.write(",是小站的高级站友,很厉害啊!")

if(visits

>=6)

document.write(",是小站的支柱,我实在太感动了!")

<

/script

>

<

/html

>

在判断访问次数所表达的句子上,你可以根据网站的风格,改为有自己个性的话语,相信,如果访问者在你的网站上看到这些话,留给他的印象一定很深刻,这样就可以让你的网站更加吸引别人了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有