問題描述
我知道有從遠端 URL 獲取影像並在本地儲存的外掛。我只是想知道是否可能不將影像儲存在媒體庫中,但將其用作精選影像?
最佳解決方案
是的,這是可能的,很簡單。
這是我建議的工作流程
-
在某個地方放置一個 UI 來插入特徵影像的 URL 。可能最好的選擇是使用
'admin_post_thumbnail_html'過濾器鉤 -
使用
'save_post'動作掛鉤來儲存 URL(在安全性和驗證程式之後) 在自定義後期元 -
使用
'post_thumbnail_html'過濾器鉤子輸出正確的<img>標記,覆蓋預設值,如果需要特徵影像的帖子具有外部特徵影像的後期元素
要工作,此工作流程需要使用 get_the_post_thumnbail()或 the_post_thumbnail()功能在模板中顯示特徵影像。
此外,當我們設定外部 URL 的後設資料時,我們必須確保'_thumbnail_id'元值具有 non-empty 值,否則 has_post_thumbnail()將只返回只有外部特徵影像的帖子。
事實上,透過我們的工作流程,一個職位有可能同時具有標準的本地特徵影像和一組,在這種情況下,將使用外部功能。
為了實現我們的工作流程,我們需要一個函式來驗證用作外部特徵影像的 URL,因為我們必須確保它是一個有效的影像 URL 。
有不同的方法來做這個任務; 這裡我使用一個非常簡單的方式,只看網址,而不下載影像。這僅適用於靜態影像 URL,並且不會驗證影像是否真實存在,但速度很快。如果需要 (here 是一些幫助),將其修改為更高階的東西。
function url_is_image( $url ) {
if ( ! filter_var( $url, FILTER_VALIDATE_URL ) ) {
return FALSE;
}
$ext = array( 'jpeg', 'jpg', 'gif', 'png' );
$info = (array) pathinfo( parse_url( $url, PHP_URL_PATH ) );
return isset( $info['extension'] )
&& in_array( strtolower( $info['extension'] ), $ext, TRUE );
}
挺容易。現在我們來新增上面工作流中描述的 3 個鉤子:
add_filter( 'admin_post_thumbnail_html', 'thumbnail_url_field' );
add_action( 'save_post', 'thumbnail_url_field_save', 10, 2 );
add_filter( 'post_thumbnail_html', 'thumbnail_external_replace', 10, PHP_INT_MAX );
和相關功能。首先輸出管理員中的欄位:
function thumbnail_url_field( $html ) {
global $post;
$value = get_post_meta( $post->ID, '_thumbnail_ext_url', TRUE ) ? : "";
$nonce = wp_create_nonce( 'thumbnail_ext_url_' . $post->ID . get_current_blog_id() );
$html .= '<input type="hidden" name="thumbnail_ext_url_nonce" value="'
. esc_attr( $nonce ) . '">';
$html .= '<div><p>' . __('Or', 'txtdomain') . '</p>';
$html .= '<p>' . __( 'Enter the url for external image', 'txtdomain' ) . '</p>';
$html .= '<p><input type="url" name="thumbnail_ext_url" value="' . $value . '"></p>';
if ( ! empty($value) && url_is_image( $value ) ) {
$html .= '<p><img style="max-width:150px;height:auto;" src="'
. esc_url($value) . '"></p>';
$html .= '<p>' . __( 'Leave url blank to remove.', 'txtdomain' ) . '</p>';
}
$html .= '</div>';
return $html;
}
請注意,我使用'txtdomain'作為文字域,但您應該使用正確的註冊文字域。
這是輸出如何看起來空:
這是新增影像 URL 並儲存/更新帖子後的樣子:
所以現在我們的管理介面完成了,我們來寫儲存例程:
function thumbnail_url_field_save( $pid, $post ) {
$cap = $post->post_type === 'page' ? 'edit_page' : 'edit_post';
if (
! current_user_can( $cap, $pid )
|| ! post_type_supports( $post->post_type, 'thumbnail' )
|| defined( 'DOING_AUTOSAVE' )
) {
return;
}
$action = 'thumbnail_ext_url_' . $pid . get_current_blog_id();
$nonce = filter_input( INPUT_POST, 'thumbnail_ext_url_nonce', FILTER_SANITIZE_STRING );
$url = filter_input( INPUT_POST, 'thumbnail_ext_url', FILTER_VALIDATE_URL );
if (
empty( $nonce )
|| ! wp_verify_nonce( $nonce, $action )
|| ( ! empty( $url ) && ! url_is_image( $url ) )
) {
return;
}
if ( ! empty( $url ) ) {
update_post_meta( $pid, '_thumbnail_ext_url', esc_url($url) );
if ( ! get_post_meta( $pid, '_thumbnail_id', TRUE ) ) {
update_post_meta( $pid, '_thumbnail_id', 'by_url' );
}
} elseif ( get_post_meta( $pid, '_thumbnail_ext_url', TRUE ) ) {
delete_post_meta( $pid, '_thumbnail_ext_url' );
if ( get_post_meta( $pid, '_thumbnail_id', TRUE ) === 'by_url' ) {
delete_post_meta( $pid, '_thumbnail_id' );
}
}
}
該功能經過一些安全檢查,檢視釋出的 URL,如果沒有,請將其儲存在'_thumbnail_ext_url'後期元。如果 URL 為空,後設資料已儲存,則會被刪除,從而可以透過清空外部 URL 欄位來清除後設資料。
當我們的外部影像網址設定在元中時,最後要做的是輸出特色影像標記:
function thumbnail_external_replace( $html, $post_id ) {
$url = get_post_meta( $post_id, '_thumbnail_ext_url', TRUE );
if ( empty( $url ) || ! url_is_image( $url ) ) {
return $html;
}
$alt = get_post_field( 'post_title', $post_id ) . ' ' . __( 'thumbnail', 'txtdomain' );
$attr = array( 'alt' => $alt );
$attr = apply_filters( 'wp_get_attachment_image_attributes', $attr, NULL );
$attr = array_map( 'esc_attr', $attr );
$html = sprintf( '<img src="%s"', esc_url($url) );
foreach ( $attr as $name => $value ) {
$html .= " $name=" . '"' . $value . '"';
}
$html .= ' />';
return $html;
}
我們完了。
剩下什麼
在特色影像輸出中,我沒有使用 width 或 height 屬性,也不使用 WordPress 通常新增的類,如'attachment-$size'。這是因為嗅探影像的大小需要額外的工作,這將減慢頁面載入速度,特別是如果您在頁面中有多個特色影像。
如果您需要這些屬性,可以使用我的程式碼向 wp_get_attachment_image_attributes'過濾器新增回撥 (它是一個 standard WordPress hook),也可以改變我的程式碼來嗅探影像大小並輸出相關的屬性和類。
外掛 Gist
在這裡釋出的所有程式碼,除了新增適當的文字域初始化之外,可以作為 Gist here 中的 full-working 外掛。那裡的程式碼使用了一個名稱空間,所以它需要 PHP 5.3+。
說明
當然,您應該確保您擁有使用許可和授權的許可權,並將您的站點中的影像與外部影像進行熱連結。
參考文獻
注:本文內容整合自 Google/Baidu/Bing 輔助翻譯的英文資料結果。如果您對結果不滿意,可以加入我們改善翻譯效果:薇曉朵技術論壇。

