ホームページ > バックエンド開発 > PHPチュートリアル > PHPでリモート画像をローカライズする方法

PHPでリモート画像をローカライズする方法

墨辰丷
リリース: 2023-03-30 15:30:01
オリジナル
3765 人が閲覧しました

この記事では主に PHP でリモート画像をローカライズする方法を紹介します。興味のある方はぜひ参考にしてください。

コードは次のとおりです:

<?php 
//站点根目录 
$cfg_basedir = dirname(__FILE__); 
//停建目录属性 
$cfg_dir_purview =&#39;0755&#39;; 
 /*Get请求远程内容函数*/ 
 $cookie_file = dirname(__FILE__).&#39;/cookie.txt&#39;; //COOKIE存放地址 
  function pget($url,$ref=false,$head=false){ 
  $curl = curl_init(); // 启动一个CURL会话 
  curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址       
  curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查 
  curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); // 从证书中检查SSL加密算法是否存在 
  curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER[&#39;HTTP_USER_AGENT&#39;]); // 模拟用户使用的浏览器 
  curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转 
  if($ref){ curl_setopt($curl, CURLOPT_REFERER, $ref);//带来的Referer 
  }else{ 
  curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer 
  } 
  curl_setopt($curl, CURLOPT_HTTPGET, 1); // 发送一个常规的Post请求 
  curl_setopt($curl, CURLOPT_COOKIEJAR, $GLOBALS[&#39;cookie_file&#39;]); // 存放Cookie信息的文件名称 
  curl_setopt($curl, CURLOPT_COOKIEFILE,$GLOBALS [&#39;cookie_file&#39;]); // 读取上面所储存的Cookie信息 
  curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环 
  curl_setopt($curl, CURLOPT_HEADER, 0); // 显示返回的Header区域内容 
  curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回 
  $tmpInfo = curl_exec($curl); // 执行操作 
  if (curl_errno($curl)) { 
 echo &#39;Errno&#39;.curl_error($curl); 
  } 
   if($head){ $data[&#39;head&#39;]=curl_getinfo($curl);} 
  curl_close($curl); // 关键CURL会话 
  $data[&#39;data&#39;]=$tmpInfo; 
  return $data; // 返回数据 
} 
 
 
/** 
 * 创建所有目录 
 * 
 * @param   string $truepath 真实地址 
 * @param   string $mmode  模式 
 * @return  bool 
 */ 
if ( ! function_exists(&#39;MkdirAll&#39;)) 
{ 
  function MkdirAll($truepath) 
  { global $cfg_dir_purview; 
      if(!file_exists($truepath)) 
      { 
        mkdir($truepath, $cfg_dir_purview); 
        chmod($truepath, $cfg_dir_purview); 
        return true; 
      } 
      else 
      { 
        return true; 
      } 
  } 
} 
  /** 
 * 获得文章body里的外部资源 
 * 
 * @access  public 
 * @param   string $body 文档内容 
 * @return  string 
 */ 
function GetCurContent($body) 
{ 
  global $cfg_multi_site,$cfg_basehost,$cfg_basedir,$cfg_image_dir,$arcID,$cuserLogin,$dsql; 
  $cfg_uploaddir = &#39;/c&#39;; 
  $basehost = "http://".$_SERVER["HTTP_HOST"]; 
     
  $img_array = array(); 
  preg_match_all("/src=[\"|&#39;|\s]{0,}(http:\/\/([^>]*)\.(gif|jpg|png))/isU",$body,$img_array); 
   
  $img_array = array_unique($img_array[1]); 
  $imgUrl = $cfg_uploaddir.&#39;/&#39;.date("ymd", time()); 
  $imgPath = $cfg_basedir.$imgUrl; 
  if(!is_dir($imgPath.&#39;/&#39;)) 
  { 
    MkdirAll($imgPath, $GLOBALS[&#39;cfg_dir_purview&#39;]); 
    CloseFtp(); 
  } 
  $milliSecond = date(&#39;His&#39;,time()); 
  foreach($img_array as $key=>$value) 
  {  
    if(preg_match("#".$basehost."#i", $value)) 
    { 
      continue; 
    } 
    if(preg_match("#".$basehost."#i", $value)) 
    { 
      continue; 
    } 
    if(!preg_match("#^http:\/\/#i", $value)) 
    { 
      continue; 
    } 
    
    $http=pget($value,&#39;$value&#39;,true); 
    $itype=($http[&#39;head&#39;][&#39;content_type&#39;]); 
    if(!preg_match("#\.(jpg|gif|png)#i", $itype)) 
    { 
      if($itype==&#39;image/gif&#39;) 
      { 
        $itype = ".gif"; 
      } 
      else if($itype==&#39;image/png&#39;) 
      { 
        $itype = ".png"; 
      } 
      else 
      { 
        $itype = &#39;.jpg&#39;; 
      } 
    } 
    $milliSecondN = rand(1000,9999).rand(1000,9999); 
    $value = trim($value); 
    $rndFileName = $imgPath.&#39;/&#39;.$milliSecondN.&#39;-&#39;.$key.$itype; 
    $fileurl = $imgUrl.&#39;/&#39;.$milliSecondN.&#39;-&#39;.$key.$itype; 
 
    $tp = fopen($rndFileName, &#39;wb&#39;); 
    fwrite($tp, $http[&#39;data&#39;]); 
    fclose($tp); 
     
    if(file_exists($cfg_basedir.$fileurl)) 
    { 
      $info = &#39;&#39;; 
      $imginfos = GetImageSize($rndFileName, $info); 
      $fsize = filesize($rndFileName); 
      $body = str_replace($value, $fileurl, $body); 
  
    } 
  } 
  return $body; 
} 
 
//调用方式 
echo GetCurContent($body);
ログイン後にコピー

概要: 上記はこの記事の全内容です。お役に立てば幸いです。みんなの勉強。

関連する推奨事項:

PHP エラー処理関数 register_shutdown_function の使用方法

PHP は preg_split とexplode を使用します分割を実現するには コンテンツをテキストエリアに保存するメソッド

ファイルのロックおよびロック解除メソッドの PHP 実装

以上がPHPでリモート画像をローカライズする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
php
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート