PHP Включить не включает - Woocommerce
Короче говоря, я получаю php, чтобы доказать мне, что файл существует и доступен для чтения, но сценарий просто перестает работать после нажатия на оператор include.
Также в этом вопросе вы увидите, что я использую абсолютный путь.
Некоторые примечательные вещи, которые я пробовал в решении этой проблемы:
- замените include на require и require_once
- замените $ include var жестко закодированной строкой
- замените жестко закодированную строку в недопустимом месте, используя require.
В каждом из этих случаев происходит одно и то же: ни один сценарий не выполняется за исключением оператора include или require и не выдается никаких ошибок.
Я работаю над системой Woocommerce (которая, вероятно, является побочной и не имеет значения, но, возможно, полезной), и она ведет себя довольно странно. Мой код выглядит следующим образом, я вставил кучу var_dumps, чтобы продемонстрировать мою проблему:
/**
* Output the cart shortcode.
*/
public static function output() {
var_dump("Hello");
// Constants
if ( ! defined( 'WOOCOMMERCE_CART' ) ) {
define( 'WOOCOMMERCE_CART', true );
}
var_dump("After Constants");
// Update Shipping
if ( ! empty( $_POST['calc_shipping'] ) && wp_verify_nonce( $_POST['_wpnonce'], 'woocommerce-cart' ) ) {
self::calculate_shipping();
}
var_dump("After Shipping Calc");
// Check cart items are valid
do_action( 'woocommerce_check_cart_items' );
var_dump("After cart items check");
// Calc totals
WC()->cart->calculate_totals();
var_dump("After Calc Totals");
var_dump(WC()->cart->get_cart());
var_dump(sizeof( WC()->cart->get_cart() ));
if ( 0 === sizeof( WC()->cart->get_cart() ) ) {
var_dump("Size = 0 , Empty");
wc_get_template( 'cart/cart-empty.php' );
} else {
var_dump("Size != 0 , Not Empty");
wc_get_template( 'cart/cart.php' );
}
}
Вызывается функция wc_get_template():
/**
* Get other templates (e.g. product attributes) passing attributes and including the file.
*
* @access public
* @param string $template_name
* @param array $args (default: array())
* @param string $template_path (default: '')
* @param string $default_path (default: '')
* @return void
*/
function wc_get_template( $template_name, $args = array(), $template_path = '', $default_path = '' ) {
var_dump("wc_get_template fired. Template name = " . $template_name);
if ( $args && is_array( $args ) ) {
extract( $args );
}
$located = wc_locate_template( $template_name, $template_path, $default_path );
var_dump($located);
if ( ! file_exists( $located ) ) {
_doing_it_wrong( __FUNCTION__, sprintf( '<code>%s</code> does not exist.', $located ), '2.1' );
return;
}
var_dump(file_exists( $located ), "File exists");
var_dump(file_get_contents($located));
// Allow 3rd party plugin filter template file from their plugin
$located = apply_filters( 'wc_get_template', $located, $template_name, $args, $template_path, $default_path );
do_action( 'woocommerce_before_template_part', $template_name, $template_path, $located, $args );
var_dump("After do_action function");
include $located;
var_dump("After the file is included");
do_action( 'woocommerce_after_template_part', $template_name, $template_path, $located, $args );
}
Выход:
string 'Hello' (length=5)
string 'After Constants' (length=15)
string 'After Shipping Calc' (length=19)
string 'After cart items check' (length=22)
string 'After Calc Totals' (length=17)
array (size=2)
'e82c4b19b8151ddc25d4d93baf7b908f' =>
array (size=10)
'product_id' => int 2468
'variation_id' => string '' (length=0)
'variation' =>
array (size=0)
empty
'quantity' => int 1
'line_total' => float 27.06
'line_tax' => float 5.412
'line_subtotal' => float 27.06
'line_subtotal_tax' => float 5.412
'line_tax_data' =>
array (size=2)
'total' =>
array (size=1)
...
'subtotal' =>
array (size=1)
...
'data' =>
object(WC_Product_Simple)[101]
public 'id' => int 2468
public 'post' =>
object(WP_Post)[103]
...
public 'product_type' => string 'simple' (length=6)
protected 'dimensions' => string '' (length=0)
protected 'shipping_class' => string '' (length=0)
protected 'shipping_class_id' => int 0
public 'price' => string '27.06' (length=5)
public 'manage_stock' => string 'no' (length=2)
public 'stock_status' => string 'instock' (length=7)
public 'tax_status' => string 'taxable' (length=7)
public 'virtual' => string 'no' (length=2)
'1843e35d41ccf6e63273495ba42df3c1' =>
array (size=10)
'product_id' => int 2463
'variation_id' => string '' (length=0)
'variation' =>
array (size=0)
empty
'quantity' => int 1
'line_total' => float 29.7
'line_tax' => float 5.94
'line_subtotal' => float 29.7
'line_subtotal_tax' => float 5.94
'line_tax_data' =>
array (size=2)
'total' =>
array (size=1)
...
'subtotal' =>
array (size=1)
...
'data' =>
object(WC_Product_Simple)[69]
public 'id' => int 2463
public 'post' =>
object(WP_Post)[67]
...
public 'product_type' => string 'simple' (length=6)
protected 'dimensions' => string '' (length=0)
protected 'shipping_class' => string '' (length=0)
protected 'shipping_class_id' => int 0
public 'price' => string '29.70' (length=5)
public 'manage_stock' => string 'no' (length=2)
public 'stock_status' => string 'instock' (length=7)
public 'virtual' => string 'no' (length=2)
public 'tax_status' => string 'taxable' (length=7)
int 2
string 'Size != 0 , Not Empty' (length=21)
string 'wc_get_template fired. Template name = cart/cart.php' (length=52)
string '/var/www/public/natural-choice/wp-content/themes/theme524401/woocommerce/cart/cart.php' (length=86)
boolean true
string 'File exists' (length=11)
string '<?php
/**
* Cart Page
*
* @author WooThemes
* @package WooCommerce/Templates
* @version 2.3.8
*/
var_dump("Fired");
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly
}
wc_print_notices();
do_action( 'woocommerce_before_cart' ); ?>
<form action="<?php echo esc_url( WC()->cart->get_cart_url() ); ?>" method="post">
<?php do_action( 'woocommerce_before_cart_table' ); ?>
<table class="shop_table cart" cellspacing="0">
<thead>
<tr>
<th class="product-remove"> </th>
<t'... (length=6908)
string 'After do_action function' (length=24)
Вы также заметите, что я отредактировал файл, который я пытаюсь включить, чтобы он запустил еще один файл var_dump и напечатал "Fired". Но этого ожидаемого результата не бывает.
В чем может быть причина этой проблемы?
2 ответа
Вы должны быть в состоянии отладить такого рода проблемы, просматривая журналы отладки. Они могут быть деактивированы в вашей установке.
Вы можете попробовать добавить эти две строки в начало файла PHP, чтобы включить их. Это должно помочь вам определить проблему.
error_reporting(E_ALL);
ini_set("display_errors", 1);
Ах, радости работы с WordPress. Оказывается, причина для включения и необходимости просто остановить выполнение скрипта в том, что неизвестные мне плагины сторонних производителей деактивировали и подавляли все ошибки.
После предложения @jason-pate ( PHP Включить не включает в себя - Woocommerce) я понял причину этой проблемы.
include и required давали ошибки, которые они просто не отображали, и просто не прекращали сценарий без причины, вручную активируя ошибки, что подчеркивало наличие синтаксических проблем в шаблоне, на который ссылались.