我正在使用woocommerce_email_attachments
专用挂钩将项目可下载文件附加到 WooCommerce 客户完成的订单电子邮件通知。我的问题是我被禁止 403,因为钩子直接从文件 URL 中获取文件,来自 Woocommerce_uploads:
https://website.com/wp-content/uploads/woocommerce_uploads/2021/02/document-for-client-deqwt5.docx
有了这个,我得到了 403 禁止。但是,如果我从 woocommerce_uploads 中删除 .htaccess 文件,一切正常。
我怀疑如果我可以使钩子使用与用户相同的下载路径,我将不会得到 403 禁止响应。
如何让钩子使用安全下载路径而不是文件 URL?
这是我正在使用的钩子,来自另一个答案:
add_filter( 'woocommerce_email_attachments', 'attach_downloadable_files_to_customer_completed_email', 10, 3 );
function attach_downloadable_files_to_customer_completed_email( $attachments, $email_id, $order ) {
if( isset( $email_id ) && $email_id === 'customer_completed_order' ){
// Loop through order items
foreach( $order->get_items() as $item ) {
$product = $item->get_product(); // The product Object
if ( $product->is_downloadable() && ( $downloads = $product->get_downloads() ) ) {
// Loop through product downloads
foreach( $downloads as $download ) {
$attachments[] = $download->get_file();
}
}
}
}
return $attachments;
}