选择显示字体大小

asp实用大全-实战asp(1)

asp计数器设计详解

      active server pager(动态服务器主页,简称asp),通过读写服务器的文件,结合script语言(vbscriptjscript)和html码可以方便地实现页面计数器功能。现流行的asp教材和网络上的asp教程都谈到过asp计数器的设计问题,但是都过于简单,比如没有提到怎样实现计数器脚本和主页面的分离以及图象计数器的实现等。下面就作者为单位制作nt web站点的经验,举实例循序渐进谈谈关于asp计数器的设计,希望能给asp的初学者和对asp web编程有兴趣的网友一些启发。

              (一)简单的计数器
  asp内含五个内置的"active server components"(activex服务器组件),即database access component(数据库访问组件)、file access component(文件访问组件)、ad rotator component(广告轮播器组件)、brower capabilities component(浏览器信息组件)、content linking component(内容链接组件)。我们下面要设计的计数器,就是通过其中的file access component(文件访问组件)来读写服务器文件来实现。算法思路是:在服务器端用一个文本(ascii)文件存放计数数值,每当页面被访问时就从文件中读出数值,显示给用户,并且使数值加1,把增加后的数值写回到文件。

  写入数据到一个服务器计数文件的asp语句和说明如下:
counfile=server.mappath("用来存放计数器值的文件名")
  server服务器访问方法mappath(path)是将存放计数器值的文件所在的路径   转换成物理路径
set fileobject=server.createobject("scripting.filesystemobject")
  使用方法createobject定义对象filesystemobject
set outstream=server.createtextfile(fileobject,true,false)
  使用对象filesystemobject提供方法createtextfile产生文本文件,其中参   数"true"表示覆盖原来的文件,"false"表示文件为ascii类型
outstream.writeline "要写入的数据"
  outstream.writeline为往文件写入一行数据
  从一个服务器文件读取数据的asp语法如下:
counfile=server.mappath("用来存放计数器值的文件名")
set fileobject=server.createobject("scripting.filesystemobject")
set instream=server.opentextfile(fileobject,1,false,false)
  使用对象filesystemobject提供方法opentextfile产生文本文?
其中参数"true"表示覆盖原来的文件,"false"表示文件为ascii类型
"要读取的数据"=instream.readline
其中instream.readline为从文件中读取的一行数据

  下面是一个用asp实现页面计数器功能的计数器例子(simplecounter.asp),我在代码中详细注释了语句。你可以把以下代码粘贴到你需要计数的页面代码中。当然,你的服务器必须支持asp,且你已经在主页所在的目录下创建了一个内容为0的文本文件simplecounter.txt。

简单的asp计数器simplecounter.asp代码及注释:
$#@60;%
countfile=server.mappath("simplecounter.txt")
文件aspconter.txt是用来储存数字的文本文件,初始内容一般是0
set fileobject=server.createobject("scripting.filesystemobject")
set out=fileobject.opentextfile(countfile,1,false,false)
counter=out.readline
读取计数器文件中的值
out.close
关闭文件
set fileobject=server.createobject("scripting.filesystemobject")
set out=fileobject.createtextfile(countfile,true,false)
application.lock
方法application.lock禁止别的用户更改计数器的值
counter= counter + 1
计数器的值增加1
out.writeline(counter)
把新的计数器值写入文件
application.unlock
使用方法application.unlock后,允许别的用户更改计数器的值
response.write("您是第")
response.write("$#@60;font color=red$#@62;")
response.write(counter)
把计数器的值传送到浏览器,以红(red)色显示给用户
response.write("$#@60;/font$#@62;")
response.write("位访问者")
out.close
关闭文件
%$#@62;
             (二)与页面分离的计数器
  实际应用中,主页面与计数器程序是分离的,既只要在需要计数的页面中加入一句引用代码就可以实现页面计数。我们在网上经常申请使用的免费计数器就是这样,不过它们一般是cgi做的。这里,我们只要稍微修改一下前面我们用asp做的简单计数器,然后在页面加入一句javascript语句引用它,就实现了与页面分离的计数器功能。这样,无论是作为主页面的计数器还是为某个特定页面的计数,都很方便了。显然,你需要简单更改一下存放计数器值的文件名和计数器asp源代码文件名就可以实现多个计数器。
与页面分离的计数器txtcounter.asp代码:
$#@60;%
countfile=server.mappath("txtcounter.txt")
set fileobject=server.createobject("scripting.filesystemobject")
set out=fileobject.opentextfile(countfile,1,false,false)
counter=out.readline
out.close
set fileobject=server.createobject("scripting.filesystemobject")
set out=fileobject.createtextfile(countfile,true,false)
application.lock
counter= counter + 1
out.writeline(counter)
application.unlock
response.write"document.write("&counter&")"
为了在页面正确显示计数器的值,调用vbscript函数document.write
out.close
%$#@62;
在要计数的页面加入如下的代码:
$#@60;p$#@62;
您是第
$#@60;font color=red$#@62;
$#@60;script language="javascript" src="http://202.101.209.75/asptemp/counter/txtcounter.asp"$#@62;
//引用时注意asp计数器所在的服务器及目录路径。
$#@60;/script$#@62;
$#@60;/font$#@62;
位来客
$#@60;/p$#@62;

            (三)与页面分离的图象计数器
  人们的追求是永无止境的,也许你需要一个更有个性的图形数字计数器,而不是简单的文本数字计数器。没问题,现在我们就来看看用asp是怎样来实现图形计数器功能的。要实现图形计数器,关键点在于如何实现把计数器文件中的数据值转变为对应的图象表示。因为十进制数有0,1,2,3,4,5,6,7,8,9共十个不同的数数字,我们需要有十个对应的图象,且图象的文件名字要与显示的数字对应起来,比如0对应的数字图象的文件名字就是0.gif,1对应的就是1.gif,...(图象自己可以用photoshop等工具制作,或者从网络上下载)。这里我们要用到vbscript函数len(string varname)、mid(string,start[,length])。由len(counter)可得到计数器值的位数,由mid(counter,i,1)可以得到计数器值的第i位上的数字,我们可利用这个值来调用相应的数字图象。用for循环语句,我们不难得出计数器值各个位上的数字并转化成对应的数字图象,这样,我们就能实现文本数值到图象数字的转变。下面就是一个用asp编写的图象计数器实例,因为大部分代码前面都分析过,所以代码中只注释了部分语句。

  与页面分离的图象计数器imgcounter.asp代码:
$#@60;% @language="vbscript"%$#@62;
$#@60;%
dim images(20)
定义一数组,用来存放显示每一位数字图象的语句
countfile=server.mappath("imgcounter.txt")
set fileobject=server.createobject("scripting.filesystemobject")
set out=fileobject.opentextfile(countfile,1,false,false)
counter=out.readline
out.close
set fileobject=server.createobject("scripting.filesystemobject")
set out=fileobject.createtextfile(countfile,true,false)
application.lock
counter= counter + 1
out.writeline(counter)
application.unlock
countlen=len(counter)
得到计数器值的位数
for i=1 to countlen
images(i)="$#@60;img src="&"http://202.101.209.75/asptemp/counter/images/"&"/" & mid(counter,i,1) & ".gif$#@62;$#@60;/img$#@62;"
由循环语句得到各个位上数值对应图象的显示代码(html),并把它存在数组中
具体使用时请注意图象的实际服务器及目录路径
response.write"document.write("&images(i)&");"
调用函数document.write输出显示数字图象的html代码
next
out.close
%$#@62;

在要计数的页面加入如下的代码:
$#@60;p$#@62;
您是第
$#@60;script language="javascript" src="http://202.101.209.75/asptemp/counter/imgcounter.asp"$#@62;
//引用时注意asp计数器所在的服务器及目录路径。
$#@60;/script$#@62;
位来客
$#@60;/p$#@62;
附注:以上asp计数器均在windows nt server 4.0(中文) / iis3.0 下测试通过。以下任何一种环境都可执行asp
一、windows nt server 4.0 / iis3.0以上
二、windows nt workstation 4.0 / microsoft peer web service3.0以上
三、windows 95/98 / microsoft personal web server 1.0a以上


 


关键字 本文所属关键字

相关 与本文相关文章

分类 所有文章关键字导航

源码编程相关

Java   Asp   PHP   .Net   XML   C/C++   CGI   VB   Jsp   J2ee   J2se   J2me   EJB   Servlet   Tomcat   Resin   Struts   Weblogic   Eclipse   ANT   GUI   JMS   Web servise   IDEA   Webphere   Hibernate   Spring   Jboss   Applet   Swing   Socket   Javamail   Perl   Ajax   P2P   安全   模式   框架   测试   开源   游戏

SQL数据库相关

My-SQL   Ms-SQL   Access   DB2   Oracle   Sybase   SQLserver   索引   存储过程   加密   数据库   分页   视图  

手机无线相关

3G   Wap   CDMA   GRPS   GSM   IVR   彩信   短信   无线   增值业务

网页设计制作相关

HTML   CSS   网页配色   网页特效   Javascript   VBscript   Dreamweaver   Frontpage   JS   Web   网站设计

网站建设推广相关

建站经验   网站优化   网站排名   推广   Alexa

操作系统/服务器相关

Windows XP   Windows 2000   Windows 2003   Windows Me   Windows 9.x   Linux   UNIX   注册表   操作系统   服务器   应用服务器

图形图像多媒体相关

Photoshop   Fireworks   Flash   Coreldraw   Illustrator   Freehand   Photoimpact   多媒体   图形图像

标准 网站致力的规范

Valid CSS!

无不良内容,无不良广告,无恶意代码

Valid XHTML 1.0 Transitional

creativecommons