我为Wordpress(我的目标是创建)设计了一个插件,它基本上将使用媒体的相同功能 - 库(图像上传/查看/设置描述等)。
有没有办法“复制”媒体库,然后根据需要使用它/修改它?
背景 我想为不同的客户(网站的所有者上传)对这些照片进行分类。我相信内置媒体库应该用于特定于站点的照片(如徽标,产品照片等)。我不希望将内置的“媒体库”与特定的客户照片混合在一起。
指南 也许有更好的方法。 (在每个客户的媒体类别中创建类别更好吗?)如果有,请告诉我。我正在寻找指导方针 - 而不是解决方案。
答案 0 :(得分:1)
理论上,您可以复制整个媒体库。
媒体库(在管理面板中)基本上是一种帖子类型存档。有问题的帖子类型为附件。
通过定义自定义帖子类型,您可以添加复制附件功能所需的所有操作,显示和功能挂钩。
如果您想通过使用分层或非分类分类对附件进行分类,则可以为附件发布类型注册自定义分类。
两种方式都是半复杂的,也许是不必要的。你会非常友好地更详细地描述你的使用场景,所以我可以帮助你更好。
答案 1 :(得分:1)
解决方案1: 首先查询帖子,然后为每个帖子使用类似这样的代码:
$images = get_children( array(
'post_parent' => get_the_ID(),
'post_type' => 'attachment',
'post_mime_type' => 'image',
'numberposts' => -1
) );
foreach ( (array) $images as $image ) {
print wp_get_attachment_url( $image->ID );
}
我不喜欢这个解决方案,因为它会生成许多SQL查询。
解决方案2: 编写自己的SQL查询,一次选择所有图像。看起来应该是这样的:
// change this to your custom post type, attachment in your case.
$post_type = 'attachment';
global $wpdb;
$where = get_posts_by_author_sql( $post_type );
$query = "SELECT * FROM $wpdb->posts p where p.post_type = 'attachment' AND (p.post_mime_type LIKE 'image/%') AND (p.post_status = 'inherit') AND p.post_parent IN (SELECT $wpdb->posts.ID FROM $wpdb->posts {$where} ) ORDER BY p.post_date DESC";
$results = $wpdb->get_results( $query );
if ( $results ) {
foreach ( (array) $results as $image ) {
print wp_get_attachment_url( $image->ID );
}
}
我构建该插件的方式是创建一个自定义的帖子类型,类似于媒体上传类型,然后根据需要修改它(例如添加一个类别)。
我喜欢这个插件的想法,所以让我知道你完成了,祝你好运。
编辑:如果您确实想要将所有图像文件复制到另一个目录,您可以使用以下方法执行此操作:
$source = wp_upload_dir(); // get WordPress upload directory
$dest= "wp-content/My-new-Directory"; // where you would like to copy
mkdir($dest, 0755);
foreach (
$iterator = new \RecursiveIteratorIterator(
new \RecursiveDirectoryIterator($source, \RecursiveDirectoryIterator::SKIP_DOTS),
\RecursiveIteratorIterator::SELF_FIRST) as $item
) {
if ($item->isDir()) {
mkdir($dest . DIRECTORY_SEPARATOR . $iterator->getSubPathName());
} else {
copy($item, $dest . DIRECTORY_SEPARATOR . $iterator->getSubPathName());
}
}