0

我正在使用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 禁止响应。

类似于: https ://website.com/?download_file=XXX&order=wc_order_zYAt52a4N3sh1&uid=c76cc30b2b37b32ca4615429b283a74fa483c6501f27aa0c108b912870c71c7a&key=1ebcc129-b89c-4f0674a

如何让钩子使用安全下载路径而不是文件 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;
}
4

2 回答 2

0

问题已经解决了:

  • 在 woocommerce_upload 文件夹中
  • 将 .htaccess 内容替换为:
order deny,allow
deny from all
allow from <your ip or server IP or hosting IP> 
于 2021-04-14T15:51:47.257 回答
0

你在找这个吗?

foreach( $downloads as $download ) {
    $attachments[] = $product->get_file_download_path($download->get_id());
}
于 2021-04-12T20:46:50.277 回答