PHP 버전의 코드는 비교적 간단합니다.
코드를 복사하세요. 코드는 다음과 같습니다.
$p=$ _GET['p'];
$pics=file($p)
for($i=0;$i< count($pics);$i )
{
echo $ Pictures[$i];
}
?>
코드 복사 코드는 다음과 같습니다.
<%
Dim url, body, myCache
url = Request.QueryString("url ")
myCache = 새 캐시 설정
myCache.name = "picindex"&url
If myCache.valid Then
body = myCache.value
Else
body = GetWebData(url)
myCache.add body,dateadd("d",1,now )
End If
If Err.Number = 0 Then
Response.CharSet = "UTF-8"
응답. ContentType = "application/octet-stream"
Response.BinaryWrite body
Response.Flush
Else
Wscript.Echo Err.Description
End if
'데이터 가져오기
공개 함수 GetWebData(ByVal strUrl)
Dim curlpath
curlpath = Mid (strUrl,1,Instr(8,strUrl,"/"))
Dim 검색
Set Retrieval = Server.CreateObject("Microsoft .XMLHTTP")
검색
포함.Open "Get" , strUrl, False,"",""
.setRequestHeader "Referer", curpath
.Send
GetWebData =.ResponseBody
End With
Set Retrieval = Nothing
End Function
'cache class
class Cache
private obj 'cache content
privateexpirTime'Expiration time
privateexpirationTimeName'Expiration 시간 애플리케이션 이름
비공개 캐시 이름 '캐시 콘텐츠 애플리케이션 이름
비공개 경로 'url
비공개 하위 class_initialize()
path=request.servervariables("url")
path=left(path, instrRev(path,"/"))
end sub
private sub class_terminate()
end sub
public property get blEmpty
' isempty
if isempty(obj) then
blEmpty=true
else
blEmpty=false
end if
end 속성
공용 속성이 유효해짐
' 사용 가능(만료)
if isempty(obj) 또는 isDate(expireTime)가 아닌 경우
valid=false
elseif CDate(expireTime)<지금은
valid=false
else
valid=true
end if
end 속성
공용 속성 let name(str)
'캐시 이름 설정
cacheName=str & path
obj=application(cacheName)
expireTimeName=str & "expires" & path
expireTime =application(expireTimeName)
끝 속성
공용 속성 letexpires(tm)
'만료 시간 재설정
expireTime=tm
application.lock
application(expireTimeName)=expireTime
application.unlock
end 속성
공개 하위 추가(var,expire)
'할당
isempty(var)이거나 isDate(expire)가 아닌 경우
sub 종료
end if
obj=var
expireTime=expire
application.lock
application(cacheName)=obj
application(expireTimeName)=expireTime
application.unlock
end sub
공용 속성 값 가져오기
' 값
isempty(obj)이거나 isDate(expireTime)가 아닌 경우
value=null
elseif CDate(expireTime)
else
value=obj
end if
end 속성
public sub makeEmpty()
'애플리케이션 릴리스
application.lock
application(cacheName)=empty
application(expireTimeName)=empty
application.unlock
obj=empty
expireTime=empty
end sub
public function equal(var2)
' 비교
if typename(obj )<>typename(var2) then
equal =false
elseif typename(obj)="Object" then
obj가 var2이면
equal=true
else
equal=false
end if
elseif typename( obj)="Variant()" then
if Join(obj,"^")=join(var2,"^") then
equal= true
else
equal=false
end if
else
if obj=var2 then
equal=true
else
equal=false
end if
end if
end function
end class
%>