為了獲取遠端文件,編寫了下面的一個小函數,基本各方面都考慮了,大家看看吧:
function getpic($url,$dir,$name){
//獲取url文件,然后存放到dir目錄中,以name為文件名。
//如果缺省文件名,則保留原文件名。
$tmp=split("/",$url);
$fname=$tmp[count($tmp)-1];//獲取文件名
if(empty($name)) {
$name=$fname;//設定好文件名
}else{//判斷是否更改了文件的擴展名,如果更改的話,則改為文件本身的擴展名。
$tmp1=split("/.",$fname);
$tmp2=split("/.",$name);
if(strcmp($tmp1[1],$tmp2[1])!=0) $name=$tmp2[0].".".$tmp1[1];
}
if(strstr($dir,"//")){//說明是windows環境下的目錄
if(substr($dir,-2)=="//") $file=$dir.$name;else $file=$dir."//".$name;
}else{
if(substr($dir,"/")){//說明是linux環境下的目錄
if(substr($dir,-1)=="/") $file=$dir.$name;else $file=$dir."/".$fname;
}
else{ //給了一個非法的目錄,函數退出
echo "error directory!";
return ;
}
}
if(!(file_exists("$dir") && is_dir("$dir"))) {//如果目錄不存在,則創建目錄
mkdir($dir,0777);
}
if(file_exists($file)) return;//如果文件存在,則放棄操作
$fpo=fopen($file,"wb");
if(!$fpo){
echo "sorry,create file:$file failure!check your right!";
return ;
}
$num=0;
do{
$num++;
$fpi=fopen($url,"r");
if(!$fpi) echo "open remote file falure...retry!/r/n";
}while(!$fpi && $num<3); //文件最多嘗試打開三次,超過則退出。
if(!fpi){
echo "the network is buzy or bad url!";
return ;
}else echo "open file ok!now transfer....";
while(!feof($fpi)){
$cont=fread($fpi,128);
fwrite($fpo,$cont,128);
}
fclose($fpi);
fclose($fpo);
echo "success!";
}