attachment_url_to_postid()
Намагається отримати ID вкладення (картинки з медіатеки) за вказаною URL-адресою вкладення.
Щоб отримати ID запису/сторінки, а не вкладення, використовуйте аналогічну функцію url_to_postid() .
Хуки з функції
Повертає
int
. ID запису (вкладення) або 0, якщо не вдається знайти прикріплений файл.
Використання
$ attachment_id = attachment_url_to_postid ($ url);
-
$url
(рядок) (обов’язковий) URL вкладення, з якого потрібно отримати ID.
Потрібно передавати URL на оригінальну картинку. URL на мініатюру не працюватиме. Тобто. http://example.com/wp-content/uploads/2016/11/pic.jpg спрацює, а http://example.com/wp-content/uploads/2016/11/pic-300×189.jpg немає.
Приклади
#1 Демонстрація роботи
Тут в одному прикладі показані всі варіанти і те, що функція поверне. В останньому прикладі показано як отримати ID вкладення якщо передається посилання на мініатюру: там регулярно вирізується розмір мініатюри
$url = 'http://example.com/id_6643/proverka.html/prvoerka-vhodyashhih-dannyh'; $ attachment_id = attachment_url_to_postid ($ url); // 0 $url = 'http://example.com/wp-content/uploads/2016/01/Prvoerka.jpg'; $ attachment_id = attachment_url_to_postid ($ url); // 7704 $url = 'http://example.com/wp-content/uploads/2016/01/Prvoerka-80x80.jpg'; $ attachment_id = attachment_url_to_postid ($ url); // 0 // видалимо розмір мініатюри (-80x80) з URL $url = preg_replace('~-[0-9]+x[0-9]+(?=..{2,6})~', '', $url ); $ attachment_id = attachment_url_to_postid ($ url); // 7704
#2 Своя функція для отримання ID вкладення через URL
/** * Gets attachment ID by URL. * * @param string $url File URI в будь-якому форматі. Even `image.jpg`. * * @return int Attachment id або 0. * * @version 1.2 * @author Kama (wp-kama.ru) */ function kama_attachment_url_to_post_id( $url = '' ){ Global $wpdb; $url = filter_var( $url, FILTER_VALIDATE_URL ); if ( $url === false ) { return 0; } $ name = basename ($ url); // ім'я файлу // Видалимо розмір мініатюри (-80x80) $name = preg_replace( '~-(?:d+xd+|scaled|rotated)~', '', $name ); // видалимо розширення $name = preg_replace( '~.[^.]+$~', '', $name ); // $name = sanitize_file_name($name); $post_name = sanitize_title($name); // Фільтруємо по індексному полю post_name $sql = $wpdb->prepare( "SELECT ID, guid FROM $wpdb->posts WHERE post_name LIKE %s AND post_title = %s AND post_type = 'attachment'", $wpdb->esc_like( $post_name ) .'%', $name ); $attaches = $wpdb->get_results( $sql ); if( ! $attaches ){ return 0; } $ attachment_id = reset ($ attaches) -> ID; // знайдено кілька, визначимо яку точно брати if( count( $attaches ) > 1 ){ $url_path = parse_url($url, PHP_URL_PATH); foreach( $attaches as $attach ){ if( false !== strpos( $attach->guid, $url_path ) ){ $attachment_id = $attach->ID; break; } } } return (int) apply_filters( 'kama_attachment_url_to_post_id', $attachment_id, $url ); }
// Приклади виклику функції $id = attachment_url_to_post_id( 'http://test-wp.ru/wp-content/uploads/2017/02/Lighthouse.jpg' ); $id = attachment_url_to_post_id( 'wp-content/uploads/2017/02/Lighthouse.jpg' ); $id = attachment_url_to_post_id( 'oads/2017/02/Lighthouse.jpg' );
нотатки
- Global. wpdb. $wpdb WordPress database abstraction object.
список змін
З версії 4.0.0 | Введено. |