WordPress代码实现 外链图片 自动本地化

WordPress的许多插件或代码可以在编辑文章时自动将外部图片下载到本地。 最后,我选择了一个名为Easy Copy Paste的插件。

单个操作
之后,您只需单击更新按钮即可编辑文章,以将文章中的外部链接图像下载到本地并替换链接。
但是,逐篇编辑文章不仅麻烦,而且工作量很大。 这是您可以批量下载文章中外部图片的一个小技巧。
批处理操作
该插件的代码不仅可以通过单击常规编辑页面上的更新按钮来触发下载功能,而且还可以在其中的所有文章列表页面中触发下载图像功能。 背景。 原理被理解并且操作很简单Up。
进入WP后台,文章→所有文章,进入文章管理页面,勾选“标题”全选当前页面的所有文章,并选择“编辑”,并点击“应用”按钮。

WordPress代码实现 外链图片 自动本地化-橘子皮

请记住,不要在批处理编辑中更改任何设置,只需单击“更新”。
此过程将触发以检查所有选定的文章并导入外部链接。
默认情况下,每页仅显示20条文章。 如果您有更多文章并且想要一次处理更多文章,则可以打开右上角的“显示选项”,并将“每页的项目数”设置为9999。当然,您需要调整数量 适当的文章取决于您的主机配置。 一次处理过多的文章会立即耗尽主机的资源,并导致停机。

代码版:

也可以直接将下面的代码,添加到当前主题函数模板 functions.php 中:

    function ecp_save_post($post_id, $post) {
    	global $wpdb;
    	if($post->post_status == 'publish') {
    		$p   = '/<img.*[\s]src=[\"|\'](.*)[\"|\'].*>/iU';
    		$num = preg_match_all($p, $post->post_content, $matches);
    		if ($num) {
    			$wp_upload_dir = wp_upload_dir();
    			set_time_limit(0);
    			$ch = curl_init();
    			curl_setopt($ch, CURLOPT_HEADER, false);
    			curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    			curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    			curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
    			curl_setopt($ch, CURLOPT_MAXREDIRS,20);
    			curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
     
    			$ecp_options = $_SERVER['HTTP_HOST'];
    			foreach ($matches[1] as $src) {
    				if (isset($src) && strpos($src, $ecp_options) === false) {
    					$file_info = wp_check_filetype(basename($src), null);
    					if ($file_info['ext'] == false) {
    						date_default_timezone_set('PRC');
    						$file_name = date('YmdHis-').dechex(mt_rand(100000, 999999)).'.tmp';
    					} else {
    						$file_name = dechex(mt_rand(100000, 999999)) . '-' . basename($src);
    					}
    					curl_setopt($ch, CURLOPT_URL, $src);
    					$file_path = $wp_upload_dir['path'] . '/' . $file_name;
    					$img = fopen($file_path, 'wb');
    					curl_setopt($ch, CURLOPT_FILE, $img);
    					$img_data  = curl_exec($ch);
    					fclose($img);
     
    					if (file_exists($file_path) && filesize($file_path) > 0) {
    						$t   = curl_getinfo($ch, CURLINFO_CONTENT_TYPE);
    						$arr = explode('/', $t);
    						if (pathinfo($file_path, PATHINFO_EXTENSION) == 'tmp') {
    							$file_path = ecp_handle_ext($file_path, $arr[1], $wp_upload_dir['path'], $file_name, 'tmp');
    						} elseif (pathinfo($file_path, PATHINFO_EXTENSION) == 'webp') {
    							$file_path = ecp_handle_ext($file_path, $arr[1], $wp_upload_dir['path'], $file_name, 'webp');
    						}
    						$post->post_content  = str_replace($src, $wp_upload_dir['url'] . '/' . basename($file_path), $post->post_content);
    						$attachment = ecp_get_attachment_post(basename($file_path), $wp_upload_dir['url'] . '/' . basename($file_path));
    						$attach_id = wp_insert_attachment($attachment, ltrim($wp_upload_dir['subdir'] . '/' . basename($file_path), '/'), 0);
    						$attach_data = wp_generate_attachment_metadata($attach_id, $file_path);
    						$ss = wp_update_attachment_metadata($attach_id, $attach_data);
    					}
    				}
    			}
    			curl_close($ch);
    			$wpdb->update( $wpdb->posts, array('post_content' => $post->post_content), array('ID' => $post->ID));
    		}
    	}
    }
     
    function ecp_handle_ext($file, $type, $file_dir, $file_name, $ext) {
    	switch ($ext) {
    		case 'tmp':
    			if (rename($file, str_replace('tmp', $type, $file))) {
    				if ('webp' == $type) {
    					return ecp_image_convert('webp', 'jpeg', $file_dir . '/' . str_replace('tmp', $type, $file_name));
    				}
    				return $file_dir . '/' . str_replace('tmp', $type, $file_name);
    			}
    		case 'webp':
    			if ('webp' == $type) {
    				return ecp_image_convert('webp', 'jpeg', $file);
    			} else {
    				if (rename($file, str_replace('webp', $type, $file))) {
    					return $file_dir . '/' . str_replace('webp', $type, $file_name);
    				}
    			}
    		default:
    			return $file;
    	}
    }
     
    function ecp_image_convert($from='webp', $to='jpeg', $image) {
    	$im = imagecreatefromwebp($image);
    	if (imagejpeg($im, str_replace('webp', 'jpeg', $image), 100)) {
    		try {
    			unlink($image);
    		} catch (Exception $e) {
    			$error_msg = sprintf('Error removing local file %s: %s', $image,
    				$e->getMessage());
    			error_log($error_msg);
    		}
    	}
    	imagedestroy($im);
     
    	return str_replace('webp', 'jpeg', $image);
    }
     
    function ecp_get_attachment_post($filename, $url) {
    	$file_info  = wp_check_filetype($filename, null);
    	return array(
    		'guid'           => $url,
    		'post_type'      => 'attachement',
    		'post_mime_type' => $file_info['type'],
    		'post_title'     => preg_replace('/\.[^.]+$/', '', $filename),
    		'post_content'   => '',
    		'post_status'    => 'inherit'
    	);
    }
    add_action('save_post', 'ecp_save_post', 120, 2);

 

作者:小屋
链接:http://www.rumenwu.com/site/1864.html
来源:入门屋
入门屋著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。部分内容复制其他平台,如有侵权请联系删除。

(10)
打赏 支付宝打赏 支付宝打赏 微信打赏 微信打赏
上一篇 2022-04-10 16:58
下一篇 2022-04-24 18:15

相关推荐

  • WordPress七牛云静态文件CDN加速配置教程

    WordPress网站优化加速一直都是广大站长比较关注的问题,今天主要介绍一下基于七牛云的静态文件(比如图片、js、css)CDN加速的设置方法。 CDN还是对象储存? 目前我们接触到的很多客户都是基于第三方插件对接的对象存储服务,这个本身其实也是没什么问题的,不过接触下来发现很多用户经常会遇到插件选择、文件同步、缩略图生成等各种问题,所以我们更推荐的是CD…

    2018-11-02
    2.9K0
  • 政府网站建设网页设计规范

    政府网站要方便公众浏览使用,页面内容要便于复制、保存和打印。要最大限度减少用户额外安装组件、控件或插件;确需使用的,要便于在相关页面获取和安装。应用系统、附件、视频等应有效可用,名称要直观准确。附件、视频等格式应便于常用软件打开,避免用户额外安装软件。避免使用悬浮、闪烁等方式,确需使用悬浮框的必须具备关闭功能。 1.首页不宜过长。在主流计算机配置和当地平均网…

    2020-11-08
    1.8K0
  • 大前端和小前端的区别

    1、小前端指的是Web前端,从浏览器端到web服务器端的所有开发; 2、而大前端就是所有前端的统称,比如Android、iOS、web、Watch等,最接近用户的那一层也就是UI层,然后将其统一起来,就是大前端。大前端最大的特点在于一次开发,同时适用于所有平台,开发者不用为一个APP需要做Android和iOS两种模式而担心。 大前端是web统一的时代,利用…

    2022-02-07
    9710
  • Typecho使用指南 – 主题&插件

    前言 自从买VPS,就一直研究还可以做些什么?于是,我想到自己搭建个博客,上网看看了,感觉Typecho,挺不错的。故写下此篇博客。 准备 Typecho 安装 下载Typecho压缩包,上传服务器wwwroot下,把所有文件解压出来。 进入数据库中,创建一个typecho的数据库。 在浏览器中访问您的域名将自动跳转到安装地址(记得要绑定域名),点击“我准备…

    2018-11-12
    6.5K0
  • WordPress网站HTTPS配置教程 WordPress如何启用HTTPS

    随着HTTPS的不断普及,越来越多的网站开启了HTTPS,给网站加上了小绿锁标识,作为全球知名的建站系统,WordPress对于HTTPS的兼容性是非常好的,几乎不用任何修改,只需要服务器配置好证书即可使用https链接访问。但是经常有用户反馈开启了以后地址栏没有绿色的锁(chrome浏览器),下面简单介绍下配置教程。 以下配置教程是基于已经在服务器配置好S…

    2018-04-15
    2.7K0
  • 使用CSS3实现表格隔行/隔列变色

    废话少说,先看效果,如果不是你想要的,你可以撤了~ 这些都是css控制的,然后我们看下样式: table tr:nth-child(odd){background:#F4F4F4;} table td:nth-child(even){color:#C00;} table tr:nth-child(5){background:#73B1E0;color:#FF…

    2020-11-18
    2.5K0