您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 薪酬管理 > 第4章 asp网络编程
用ASP编程实现网络内容快速查找用ASP编程实现网络内容快速查找来源:未知(读取中...)2005-10-28【字体:大中小】切换为有一天我突发奇想,要是我每到一个网站,那里都能立刻调出我需要看的信息,那岂非美妙得很。接下来我想更深入地考虑这个问题,坐到椅子上拿一支铅笔,却不知道自己写什么。如此一来,我还是得着手对付代码它们。 我的朋友开了一个小型站点,原本是我设计的。这是个检验我想法的好平台。所以我写出代码,上传了文件。真叫人兴奋,程序工作起来煞是圆满,同时也证明我的想法的确不错。 以前看过一些网络使用者倾向报告,其中有一个规律给我印象很深。说是大多数用户如果在三次点击内无法找到自己需要的内容,就会立刻离开该站点。我的代码就可以针对这个问题,保险用户只要点一次鼠标就找到目标。在我的例子里,假设有个用户上了Yahoo,检索关键字为FireplaceAccessories(飞行器材配件)。在给出的结果里,他来到我朋友的站点,将看到你正在搜索FireplaceAccessories等字样的画面。接着他会按照网站上的提示,直接到想要去的页面。你要作的第一步,是在global.asa文件中建立一个初始变量,放置在你的SubSession_onStart()程序中。 SubSession_onStart() Referer=Trim(Request.ServerVariables(HTTP_REFERER)) IfReferer=Then Referer=None EndIf Session(Referer)=Referer EndSub 接着我们来着手看看如何完成程序的主要功能。 因为url经过了编码,所以首先要把来访者主机的指向数据还原成对我们有用的东西。建立一个ASP页面,叫它decode.asp,是我们程序的主干。第一个功能是要对编码过的指向头进行解码。程序有点长,而且很直接,没有什么转弯抹角,如果你嫌麻烦,不如到的网虫进修班上面找到本文,用拷贝/粘贴大法吧。 源代码第二件要作的事情是:从URL头信息里分离出查询部分--这个才是我们需要的。'从指向URL中分离查询字段。 FunctionisProduct(pStr) IfpStrAndlCase(pStr)noneThen '向后搜索字段 temp=inStrRev(pStr,/) '得到目录分离的位置 tempStr=Right(pStr,temp) '得到有关数据长度 temp2=Len(pStr) '得到查询数据行 pStr=Mid(pStr,temp,temp2) '设定返回功能的值 isProduct=pStr Else isProduct= EndIf EndFunction 接着是要确立查找的明确标准。为达到这个目的,建立两个静态空间指?查找指向数据 FunctionFinder(byRefprodList,byValrefList) '模糊查询 refList=lCase(refList) '通过指针循环查找匹配字段 Fori=0TouBound(prodList)-1 IfinStr(refList,lCase(prodList(i,0)))Then '找到匹配 tHolder=tHolder&AreYoulookingFor_ &_ &prodList(i,0)& EndIf '第二次循环 Next '返回结果 Finder=tHolderEndFunction 通过一个inclue,把我们做好的decode.asp放到需要此功能的任何页面,大功告成啦。具体如下:'如果指向头不为空,调出此功能IflCase(Session(Referer))noneORSession(Referer)Then'解析指向数据Response.WritevbCrLf& _&Finder(pArray,URLDecode(isProduct(Session(Referer))))_& &vbCrLf EndIf关注此文的读者还看过:•2009-11-3014:34:46asp调用js代码•2009-11-1010:44:16ASP利用prototype和Google的weatherapi做天气预报•2009-10-2612:40:01asp版域名查询的数据库接口•2009-9-2813:15:20Asp文件操作函数集•2009-9-2417:15:19ASP使用FCKEditor的设置技巧•2007-11-218:25:14用ASP实现IE地址栏参数的判断•2007-11-85:39:29ASP处理XSLT转换XML的实现•2007-11-221:07:31ASP实现不存在的网页就自动发送邮件评论内容:不能超过100字,需审核,请自觉遵守互联网相关政策法规。原文网址:用ASP编写下载网页中所有资源的程序用ASP编写下载网页中所有资源的程序来源:未知(读取中...)2005-10-28【字体:大中小】切换为看过一篇关于下载网页中图片的文章,它只能下载以http头的图片,我做了些改进,可以下载网页中的所有连接资源,并按照网页中的目录结构建立本地目录,存放资源。download.asp?url=你要下载的网页download.asp代码如下:<%Server.ScriptTimeout=9999functionSaveToFile(from,tofile)onerrorresumenextdimgeturl,objStream,imgsgeturl=trim(from)Mybyval=getHTTPstr(geturl)SetobjStream=Server.CreateObject(ADODB.Stream)objStream.Type=1objStream.Openobjstream.writeMybyvalobjstream.SaveToFiletofile,2objstream.Close()setobjstream=nothingiferr.number<>0thenerr.Clearendfunctionfunctiongeturlencodel(byvalurl)'中文文件名转换Dimi,codegeturlencodel=iftrim(Url)=thenexitfunctionfori=1tolen(Url)code=Asc(mid(Url,i,1))ifcode<0Thencode=code+65536Ifcode>255Thengeturlencodel=geturlencodel&%&Left(Hex(Code),2)&%&Right(Hex(Code),2)elsegeturlencodel=geturlencodel&mid(Url,i,1)endifnextendfunctionfunctiongetHTTPPage(url)onerrorresumenextdimhttpsethttp=Server.createobject(Msxml2.XMLHTTP)Http.openGET,url,falseHttp.send()ifHttp.readystate<>4thenexitfunctiongetHTTPPage=bytes2BSTR(Http.responseBody)sethttp=nothingiferr.number<>0thenerr.ClearendfunctionFunctionbytes2BSTR(vIn)dimstrReturndimi,ThisCharCode,NextCharCodestrReturn=Fori=1ToLenB(vIn)ThisCharCode=AscB(MidB(vIn,i,1))IfThisCharCode<&H80ThenstrReturn=strReturn&Chr(ThisCharCode)ElseNextCharCode=AscB(MidB(vIn,i+1,1))strReturn=strReturn&Chr(CLng(ThisCharCode)*&H100+CInt(NextCharCode))i=i+1EndIfNextbytes2BSTR=strReturnEndFunctionfunctiongetFileName(byvalfilename)ifinstr(filename,/)>0thenfileExt_a=split(filename,/)getFileName=lcase(fileExt_a(ubound(fileExt_a)))ifinstr(getFileName,?)>0thengetFileName=left(getFileName,instr(getFileName,?)-1)endifelsegetFileName=filenameendifendfunctionfunctiongetHTTPstr(url)onerrorresumenextdimhttpsethttp=server.createobject(MSXML2.XMLHTTP)Http.openGET,url,falseHttp.send()ifHttp.readystate<>4thenexitfunctiongetHTTPstr=Http.responseBodysethttp=nothingiferr.number<>0thenerr.ClearendfunctionFunctionCreateDIR(ByValLocalPath)'建立目录的程序,如果有多级目录,则一级一级的创建OnErrorResumeNextLocalPath=Replace(LocalPath,\,/)SetFileObject=server.CreateObject(Scripting.FileSystemObject)patharr=Split(LocalPath,/)path_level=UBound(patharr)ForI=0Topath_levelIfI=0Thenpathtmp=patharr(0)&/Elsepathtmp=pathtmp&patharr(I)&/cpath=Left(pathtmp,Len(pathtmp)-1)IfNotFileObject.FolderExists(cpath)ThenFileObject.CreateFoldercpathNextSetFileObject=NothingIfErr.Number<>0ThenCreateDIR=FalseErr.ClearElseCreateDIR=TrueEndIfEndFunctionfunctionGetfileExt(byvalfilename)fileExt_a=split(filename,.)GetfileExt=lcase(fileExt_a(ubound(fileExt_a)))endfunctionfunctiongetvirtual(str,path,urlhead)ifleft(str,7)==strelseifleft(str,1)=/thenstart=instrRev(str,/)ifstart=1thenurl=/elseurl=left(str,start)endifurl=urlhead&urlelseifleft(str,3)=../thenstr1=mid(str,inStrRev(str,../)+2)ar=split(str,../)lv=ubound(ar)+1ar=split(path,/)url=/fori=1to(ubound(ar)-lv)url=url&ar(i)nexturl=url&str1url=urlhead&urlelseu
本文标题:第4章 asp网络编程
链接地址:https://www.777doc.com/doc-5451165 .html