Поверните URL-адрес в файл Attachment /Post ID

Можно ли каким-либо образом получить URL-адрес изображения и найти вложение или почтовый идентификатор этого изображения в базе данных?

Вот ситуация:

Я нахожусь в цикле, просматривая все теги «img», которые окружены тегами «a» в моем сообщении. если атрибут src тега 'img' не соответствует атрибуту href внешнего тега 'a', тогда я хочу заменить тег 'img'. При этом, если «img», который должен быть удален, находится в галерее, я хочу удалить этот пост, а затем поставьте замену «img» на его место. Я попытался использовать такую ​​функцию:

function find_image_post_id($url) {
  global $wpdb;
  $postid = $wpdb->get_var($wpdb->prepare("SELECT DISTINCT ID FROM $wpdb->posts WHERE guid='$url'"));
  if ($postid) {
    return $postid;
  }
  return false;
}

Это, по-видимому, не так, потому что руководство по иронии судьбы не является глобально уникальным. Я (ранее в том же скрипте) загрузил файл с тем же именем (почему? Потому что это было более высокое разрешение, и я пытаюсь заменить версии с низким разрешением одного и того же изображения), и хотя Wordpress сохранит изображение с другим именем в в директории, guid были установлены одинаковые. (возможно, ошибка).

Есть ли другой способ, который я могу использовать?

28 голосов | спросил Ankur 10 Jam1000000amMon, 10 Jan 2011 08:43:54 +030011 2011, 08:43:54

5 ответов


27

Массовая улучшенная функция, разработанная для плагина, тяжелого изображения:

if ( ! function_exists( 'get_attachment_id' ) ) {
    /**
     * Get the Attachment ID for a given image URL.
     *
     * @link   http://wordpress.stackexchange.com/a/7094
     *
     * @param  string $url
     *
     * @return boolean|integer
     */
    function get_attachment_id( $url ) {

        $dir = wp_upload_dir();

        // baseurl never has a trailing slash
        if ( false === strpos( $url, $dir['baseurl'] . '/' ) ) {
            // URL points to a place outside of upload directory
            return false;
        }

        $file  = basename( $url );
        $query = array(
            'post_type'  => 'attachment',
            'fields'     => 'ids',
            'meta_query' => array(
                array(
                    'key'     => '_wp_attached_file',
                    'value'   => $file,
                    'compare' => 'LIKE',
                ),
            )
        );

        // query attachments
        $ids = get_posts( $query );

        if ( ! empty( $ids ) ) {

            foreach ( $ids as $id ) {

                // first entry of returned array is the URL
                if ( $url === array_shift( wp_get_attachment_image_src( $id, 'full' ) ) )
                    return $id;
            }
        }

        $query['meta_query'][0]['key'] = '_wp_attachment_metadata';

        // query attachments again
        $ids = get_posts( $query );

        if ( empty( $ids) )
            return false;

        foreach ( $ids as $id ) {

            $meta = wp_get_attachment_metadata( $id );

            foreach ( $meta['sizes'] as $size => $values ) {

                if ( $values['file'] === $file && $url === array_shift( wp_get_attachment_image_src( $id, $size ) ) )
                    return $id;
            }
        }

        return false;
    }
}
ответил Rarst 17 Jam1000000amMon, 17 Jan 2011 10:13:18 +030011 2011, 10:13:18
13

Все эти сложные функции могут быть сведены к одной простой функции:

attachment_url_to_postid ()

Вам нужно всего лишь проанализировать URL-адрес изображения, чтобы получить идентификатор вложения:

$attachment_id = attachment_url_to_postid( $image_url );
echo $attachment_id;

Это все, что вам нужно.

ответил Ego Ipse 1 72015vEurope/Moscow11bEurope/MoscowSun, 01 Nov 2015 09:58:45 +0300 2015, 09:58:45
3

Я изменил код Rarst, чтобы вы могли сопоставлять только имя файла, а не полный путь. Это полезно, если вы собираетесь удалять изображение, если оно не существует. В настоящее время это работает только в том случае, если имена файлов уникальны, но я добавлю хэш-чек позже, чтобы помочь с изображениями с одинаковым именем файла.

function get_attachment_id( $url, $ignore_path = false ) {

if ( ! $ignore_path ) {

    $dir = wp_upload_dir();
    $dir = trailingslashit($dir['baseurl']);

    if( false === strpos( $url, $dir ) )
        return false;
}

$file = basename($url);

$query = array(
    'post_type' => 'attachment',
    'fields' => 'ids',
    'meta_query' => array(
        array(
            'key'     => '_wp_attached_file',
            'value'   => $file,
            'compare' => 'LIKE',
        )
    )
);

$ids = get_posts( $query );

foreach( $ids as $id ) {
    $match = array_shift( wp_get_attachment_image_src($id, 'full') );
    if( $url == $match || ( $ignore_path && strstr( $match, $file ) ) )
        return $id;
}

$query['meta_query'][0]['key'] = '_wp_attachment_metadata';
$ids = get_posts( $query );

foreach( $ids as $id ) {

    $meta = wp_get_attachment_metadata($id);

    foreach( $meta['sizes'] as $size => $values ) {
        if( $values['file'] == $file && ( $ignore_path || $url == array_shift( wp_get_attachment_image_src($id, $size) ) ) )
            return $id;
    }
}

return false;
}
ответил Luke Gedeon 25 PMpWed, 25 Apr 2012 20:59:13 +040059Wednesday 2012, 20:59:13
2

Хорошо, я нашел ответ, который никто не имеет в сети. Я искал несколько дней. Сохраняйте мои данные, только если ваша тема или плагин использует WP_Customize_Image_Control(), если вы используете WP_Customize_Media_Control(), код get_theme_mod() верните идентификатор, а не URL.

Для моего решения я использовал более новую версию WP_Customize_Image_Control()

Много сообщений на форумах имеют get_attachment_id(), который больше не работает. Я использовал attachment_url_to_postid()

Вот как я смог это сделать. Надеюсь, это поможет кому-то там.

// This is getting the image / url
$feature1 = get_theme_mod('feature_image_1');

// This is getting the post id
$feature1_id = attachment_url_to_postid($feature1);

// This is getting the alt text from the image that is set in the media area
$image1_alt = get_post_meta( $feature1_id, '_wp_attachment_image_alt', true );

Разметка

<a href="<?php echo $feature1_url; ?>"><img class="img-responsive center-block" src="<?php echo $feature1; ?>" alt="<?php echo $image1_alt; ?>"></a>
ответил DevTurtle 29 AMpSat, 29 Apr 2017 05:26:18 +030026Saturday 2017, 05:26:18
0

Вот альтернативное решение:

$image_url = get_field('main_image'); // in case of custom field usage
$image_id = attachment_url_to_postid($image_url);

// retrieve the thumbnail size of our image
$image_thumb = wp_get_attachment_image_src($image_id, 'thumbnail');

Поскольку WP 4.0 ввели функцию attachment_url_to_postid(), которая ведет себя аналогично вашему find_image_post_id()

Пожалуйста, просмотрите этот URL для справки.

ответил Lefan 21 MarpmWed, 21 Mar 2018 13:46:43 +03002018-03-21T13:46:43+03:0001 2018, 13:46:43

Похожие вопросы

Популярные теги

security × 330linux × 316macos × 2827 × 268performance × 244command-line × 241sql-server × 235joomla-3.x × 222java × 189c++ × 186windows × 180cisco × 168bash × 158c# × 142gmail × 139arduino-uno × 139javascript × 134ssh × 133seo × 132mysql × 132