PHP Dotenv вызывает запуск конфигурации WordPress дважды
У меня есть относительно сложный проект laravel, в котором у меня есть установка WordPress для блога на стороне, которая устанавливается вместе с композитором.
В моем wp-config.php
Я использую включение в файл в моем каталоге конфигурации под названием application.php
(для организационных целей). У меня есть разные случаи define('XXX', 'config stuff');
и аналогичные в файле. Когда 'config онастройка' жестко запрограммирована, сайт работает отлично, но недавно я пытаюсь использовать dotenv, установленный композитором, для получения значений из моего.env с помощью getenv()
require_once(LARAVEL_PATH . '/vendor/autoload.php');
$dotenv = new Dotenv\Dotenv(APP_ROOT_DIR);
$dotenv->load();
Когда я var_dump
мой getenv('example_env_constant')
это дает мне правильные значения абсолютно нормально. Поэтому я занялся их настройкой по всему файлу application.php.
Но теперь, когда я загружаю сайт, я получаю большое количество
Notice: Constant XXX_XXXX_XXX already defined in /path/to/application.php on line X
Один на каждого define('XXX', value);
А также
Cannot modify header information
На тестировании я обнаружил, что мой wp-config.php
файл запускается один раз. Но как-то мой application.php
запускается дважды. Первый прогон от моего включенного звонка в wp-config.php
так, как это должно быть. 2-ой запуск, который вызывает ошибки, происходит в течение wp-settings.php
по линии 326
do_action( 'plugins_loaded' );
Я понятия не имею, как это происходит.
Если я удалю код Dotenv из application.php
и вместо этого положить его прямо в мой wp-config.php
поведение точно такое же, с wp-config.php
работает один раз и application.php
работает дважды.
Теперь, если я удалю application.php
и положить весь мой код в wp-config.php
как конфиг wp традиционно делается. Затем я снова получаю ту же самую проблему, и она ссылается на удаленный файл... это, конечно, указывает на проблему с кешем в данный момент, хотя я не думаю, что кеш является причиной первоначальной проблемы. Выполнение очистки кеша с помощью wp cli не работает, так как на самом деле удается получить те же ошибки из application.php
при промывке Не берите в голову, что кэширование вообще отключено в любом случае. Это не проблема кеша браузера здесь, так как новый экземпляр инкогнито хром и жесткое обновление не имеют значения.
Это долгое чтение, так что сожалею об этом, надеюсь, я был достаточно ясен. Я совершенно сбит с толку относительно того, как это происходит, и любая помощь или советы по устранению неполадок это было бы здорово. Возможно, я упустил что-то очень очевидное, так как кажется, что использование dotenv для моей конфигурации wp полностью разрушает все, что я никогда раньше не видел. Худшее приходит к худшему, я вернусь к жесткому кодированию файла wp-config.
Обновить:
Я ошибся при удалении файла application.php, не останавливая связанные ошибки. Это останавливает требуемые ошибки, но вместо этого я получаю другие. Если я просто удаляю содержимое application.php, то у меня нет разницы.
Что-то в основном не так, если у кого-то просто есть какой-либо совет по отладке, это будет высоко ценится
файлы:
public / help-advice / wp-config.php
config / application.php
Установка WordPress находится в публичном доступе / help-advice / wp
wp-файлы, созданные не композитором, находятся в public / help-advice / app или public / help-advice
Вставленный код, если вы не можете использовать pastebin:
Это config.php
<?php
/**
* The base configuration for WordPress
*
* The wp-config.php creation script uses this file during the
* installation. You don't have to use the web site, you can
* copy this file to "wp-config.php" and fill in the values.
*
* This file contains the following configurations:
*
* * MySQL settings
* * Secret keys
* * Database table prefix
* * ABSPATH
*
* @link https://codex.wordpress.org/Editing_wp-config.php
*
* @package WordPress
*/
/*
* Caching
*/
define('WP_CACHE', true);
define('LARAVEL_PATH', dirname(__FILE__) . '/../..'); // Make sure this is pointed to same server
require_once(LARAVEL_PATH . '/vendor/autoload.php');
require_once(LARAVEL_PATH . '/config/application.php');
require_once(ABSPATH . 'wp-settings.php');
Это приложение.php
<?php
//This file pulls in data for WP and is included in the wp-config.php file within help-advice
/*
* Base paths
*/
define('APP_ROOT_DIR', dirname(__DIR__));
// $dotenv = new Dotenv\Dotenv(APP_ROOT_DIR);
// $dotenv->load();
// this one above works but causes this file to run twice causing errors, the one below errors
// if (file_exists(APP_ROOT_DIR . '/.env')) {
// Dotenv\Dotenv::load(APP_ROOT_DIR);
// }
define('APP_PUBLIC_DIR', APP_ROOT_DIR . '/public/help-advice');
define('APP_STORAGE_DIR', APP_ROOT_DIR . '/storage');
define('APP_LOG_DIR', APP_STORAGE_DIR . '/logs');
// ** MySQL settings - You can get this info from your web host ** //
/** The name of the database for WordPress */
define('DB_NAME', 'redacted');
/** MySQL database username */
define('DB_USER', 'redacted');
/** MySQL database password */
define('DB_PASSWORD', 'redacted');
/** MySQL hostname */
define('DB_HOST', '127.0.0.1');
/** Database Charset to use in creating database tables. */
define('DB_CHARSET', 'utf8mb4');
/** The Database Collate type. Don't change this if in doubt. */
define('DB_COLLATE', '');
/**#@+
* Authentication Unique Keys and Salts.
*
* Change these to different unique phrases!
* You can generate these using the {@link https://api.wordpress.org/secret-key/1.1/salt/ WordPress.org secret-key service}
* You can change these at any point in time to invalidate all existing cookies. This will force all users to have to log in again.
*
* @since 2.6.0
*/
define('AUTH_KEY', 'redacted');
define('SECURE_AUTH_KEY', 'redacted');
define('LOGGED_IN_KEY', 'redacted');
define('NONCE_KEY', 'redacted');
define('AUTH_SALT', 'redacted');
define('SECURE_AUTH_SALT', 'redacted');
define('LOGGED_IN_SALT', 'redacted');
define('NONCE_SALT', 'redacted');
/*
* Debugging/errors
*/
define('APP_DEBUG', (boolean) getenv('APP_DEBUG'));
// Always log errors
ini_set('log_errors', 1);
ini_set('error_log', APP_LOG_DIR . '/wp_debug.log');
define('WP_DEBUG', true);
define('WP_DEBUG_LOG', false);
define('WP_DEBUG_DISPLAY', APP_DEBUG);
define('SCRIPT_DEBUG', APP_DEBUG);
/*
* URLs
*/
define('WP_SITEURL', 'http://' . $_SERVER['HTTP_HOST'].'/help-advice/wp');
define('WP_HOME', 'http://' . $_SERVER['HTTP_HOST'].'/help-advice');
/*
* Custom Content Directory (/public/help-advice/app)
*/
define('CONTENT_DIR', '/app');
define('WP_CONTENT_DIR', APP_PUBLIC_DIR . CONTENT_DIR);
define('WP_CONTENT_URL', WP_HOME . CONTENT_DIR);
//google analytics
define('GA_PROPERTY_ID',getenv('GA_PROPERTY_ID'));
/**#@-*/
/**
* WordPress Database Table prefix.
*
* You can have multiple installations in one database if you give each
* a unique prefix. Only numbers, letters, and underscores please!
*/
$table_prefix = 'wp_';
/* That's all, stop editing! Happy blogging. */
/** Absolute path to the WordPress directory. */
if ( !defined('ABSPATH') )
define('ABSPATH', dirname(__FILE__) . '/../public/help-advice/wp/');
1 ответ
Я понятия не имею, почему он запускается дважды или запускается do_action( 'plugins_loaded'); на 2-м пробеге.
Так как это довольно уникальная сборка / ситуация, и я не ожидаю, что это будет легко исправить, или когда это понадобится более чем двум людям. Поэтому вместо того, чтобы продолжать рвать на себе волосы, я добавил проверку к каждому определению в моем application.php, чтобы увидеть, существует ли оно уже, и если да, не переопределять. пример: if (!defined('WP_DEBUG')) {define('WP_DEBUG', true);}
Я также получал ошибки из файла advanced-cache.php, отсутствующие в результате добавления dotenv в application.php, не знаю почему, тем более что я никогда не устанавливал и не имел ничего общего с advanced-cache. Так что я просто отключил это define('WP_CACHE', false);