当前所在位置: 首页>>百科全书

无插件实现wordpress远程图片自动本地化

发布时间:2025-10-19 15:30:02 本站作者 【 字体: 】 浏览:6 次

找资料时在其他人的博客看到一篇远程图片自动本地化的代码,分享给大家,将代码写入主题的functions.php文件或者是functions.php的引入文件中即可,以后每当在wordpress发布文章时如果文章中含有外链图片就会自动本地化了,无需任何设置操作非常方便。

代码如下:

add_filter('content_save_pre', 'auto_save_image');
function auto_save_image($content) {
 $upload_path = '';
 $upload_url_path = get_bloginfo('url');
 
 //上传目录
 if (($var = get_option('upload_path')) !=''){
 $upload_path = $var;
 } else {
 $upload_path = 'wp-content/uploads';
 }
 if(get_option('uploads_use_yeArmonth_folders')) {
 $upload_path .= '/'.date("Y",time()).'/'.date("m",time());
 }
 
 //文件地址
 if(($var = get_option('upload_url_path')) != '') {
 $upload_url_path = $var;
 } else {
 $upload_url_path = bloginfo('url');
 }
 if(get_option('uploads_use_yearmonth_folders')) {
 $upload_url_path .= '/'.date("Y",time()).'/'.date("m",time());
 }
 
 require_once ("../wp-includes/class-snoopy.php");
 $snoopy_Auto_Save_Image = new Snoopy;
 
 $img = array();
 
 //以文章的标题作为图片的标题
 if ( !empty( $_REQUEST['post_title'] ) )
 $post_title = wp_specialchars( stripslashes( $_REQUEST['post_title'] ));
 $text = stripslashes($content);
 if (get_magic_quotes_gpc()) $text = stripslashes($text);
 preg_match_all("/ src=("|'){0,}(http://(.+?))("|'|s)/is",$text,$img);
 $img = array_unique(dhtmlspecialchars($img[2]));
 foreach ($img as $key => $value){
 set_time_limit(180); //每个图片最长允许下载时间,秒
 if(str_replace(get_bloginfo('url'),"",$value)==$value&&str_replace(get_bloginfo('home'),"",$value)==$value){
 //判断是否是本地图片,如果不是,则保存到服务器
 $fileext = substr(strrchr($value,'.'),1);
 $fileext = strtolower($fileext);
 if($fileext==""||strlen($fileext)>4)
 $fileext = "jpg";
 $savefiletype = array('jpg','gif','png','bmp');
 if (in_array($fileext, $savefiletype)){
 if($snoopy_Auto_Save_Image->fetch($value)){
 $get_file = $snoopy_Auto_Save_Image->results;
 }else{
 echo "error fetching file: ".$snoopy_Auto_Save_Image->error."<br>";
 echo "error url: ".$value;
 die();
 }
 $filetime = time();
 $filepath = "/".$upload_path;//图片保存的路径目录
 !is_dir("..".$filepath) ? mkdirs("..".$filepath) : null;
 //$filename = date("His",$filetime).random(3);
 $filename = substr($value,strrpos($value,'/'),strrpos($value,'.')-strrpos($value,'/'));
 
 //$e = '../'.$filepath.$filename.'.'.$fileext;
 //if(!is_file($e)) {
 // copy(htmlspecialchars_decode($value),$e);
 //}
 $fp = @fopen("..".$filepath.$filename.".".$fileext,"w");
 @fwrite($fp,$get_file);
 fclose($fp);
 
 
 
 $wp_filetype = wp_check_filetype( $filename.".".$fileext, false );
 $type = $wp_filetype['type'];
 $post_id = (int)$_POST@['temp_ID2'];
 $title = $post_title;
 $url = $upload_url_path.$filename.".".$fileext;
 $file = $_SERVER['DOCUMENT_ROOT'].$filepath.$filename.".".$fileext;
 
 //添加数据库记录
 $attachment = array(
 'post_type' => 'attachment',
 'post_mime_type' => $type,
 'guid' => $url,
 'post_parent' => $post_id,
 'post_title' => $title,
 'post_content' => '',
 );
 $id = wp_insert_attachment($attachment, $file, $post_parent);
 $text = str_replace($value,'/wp-content/uploads/'.$url,$text); //替换文章里面的图片地址
 }
 }
 }
 $content = AddSlashes($text);
 remove_filter('content_save_pre', 'auto_save_image');
 return $content;
}
 
function mkdirs($dir)
{
 if(!is_dir($dir))
 {
 mkdirs(dirname($dir));
 mkdir($dir);
 }
 return ;
}
function dhtmlspecialchars($string) {
 if(is_array($string)) {
 foreach($string as $key => $val) {
 $string[$key] = dhtmlspecialchars($val);
 }
 }else{
 $string = str_replace('&', '&', $string);
 $string = str_replace('"', '"', $string);
 $string = str_replace('<', '<', $string);
 $string = str_replace('>', '>', $string);
 $string = preg_replace('/&(#d;)/', '&1', $string);
 }
 return $string;
}


上一篇:WordPress 评论中嵌入图片

下一篇:解决WordPress设置错误的url网站不能访问的问题

广告位-300PX*250PX
最新发布
office2010密钥,office2010激活密钥,office2010永久密钥激活码最新分享

office2010密钥,office2010激活密钥,office2010永久密钥激活码最新分享

office2010密钥,office2010激活密钥,office2010永久密钥激活码最新分享
不少用户在求2018最新Microsoft Office 2010产品密钥,office2010密钥有两种,office2010永久密钥和免费版office密钥,office2010激活码最新的已发布很快就失效了,只有kms客户端免费版office激活密钥是永久有效的。下面小编为大家整理分享office2010最新密钥序列号,不区分32位和64位。说明:office2010零售版密钥和kms密钥...
office365激活密钥,小编分享2025最新office365激活码

office365激活密钥,小编分享2025最新office365激活码

office365激活密钥,小编分享2025最新office365激活码
office365是微软办公套件office的年度服务,那么最近有用户想要office365激活码,过通整理,下面小编把2018年最新office365激活码和激活电脑上office365软件的方法分享给大家。2018年 office365激活码大全:RCBQN-J4MK8-VV3XJ-BPPYB-TXVT77TPNM-PMWKF-WVHKV-G869H-9BQ6XDMXHM-GNMM3-MYHHK-6TVT2-XTKKKG9N...
office2018产品密钥,小编告诉你office2018怎么激活

office2018产品密钥,小编告诉你office2018怎么激活

office2018产品密钥,小编告诉你office2018怎么激活
office2018是微软公司即将发布的一款全新的办公自动化软件,可以说各个行业都必备的;office2018全新版本功能全面升级,具有强大的数据处理、数据计算、图形编辑、演示文稿的制作和文档排版等功能,那么哪里有office2018产品密钥?下面,小编给大家带来了office2018产品密钥。office2018是微软公司开发的一款基于Windows操作...
怎么激活office2019最新版?office 2019激活秘钥+激活工具推荐

怎么激活office2019最新版?office 2019激活秘钥+激活工具推荐

怎么激活office2019最新版?office 2019激活秘钥+激活工具推荐
最新激活密钥GRBR4-J4N3M-KTX9C-JM4PJ-J8HPT (小编使用的是此激活密钥)NJHVR-FK6XR-M97MB-P8CXD-FM4PJNXVJY-X9T8G-Y6RWG-8VQ7V-PWHPTW8W6K-3N7KK-PXB9H-8TD8W-BWTH9N9J9Q-Q7MMP-XDDM6-63KKP-76FPM9DP6T-9AGWG-KWV33-9MPC8-JDCVF7G2HE-JR8KL-ABB9D-Y7789-GLNFLU2PWU-H7D9H-69T3B-JEYC2-3R2NGR8R8P-MTT6F-KLRPM-J7CAB-PJM8CA4...