第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

1 / 80
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功