วิธีปฏิบัติที่ดีที่สุดสำหรับการกำหนดเวอร์ชัน wp-config.php?


35

มีวิธีปฏิบัติที่ดีที่สุดในการรวมwp-config.phpไฟล์ของคุณในที่เก็บการควบคุมเวอร์ชันหรือไม่?

ฉันกำลังพิจารณาที่จะสร้างไซต์ใหม่ด้วยการกำหนดค่าประเภทนี้ (คล้ายกับAlex KingและMark Jaquith ):

/index.php
/local-config.php
/wp-config.php
/wp/ (core)
/wp-content/ (plugins, themes, etc.)

ฉันจะทำสิ่งนี้ได้อย่างไรโดยไม่เปิดเผยรหัสผ่านให้คอมไพล์ในกรณีที่ที่เก็บนี้กลายเป็นที่สาธารณะ

โดยเฉพาะอย่างยิ่งในโพสต์ของ Mark ดูเหมือนว่า local-config.php สามารถเก็บรายละเอียดฐานข้อมูลท้องถิ่นและรหัสผ่านได้ แต่คนที่ใช้งานจริงจะอยู่ใน wp-config.php นี่เป็นปัญหามากเกินไปหรือไม่และฉันควรปล่อยให้ wp-config.php ไม่มีการยกเลิกหรือไม่


ฉันคิดว่าวิธีที่ Mark Jaquith ทำนั้นไม่ใช่ปัญหาและทำงานได้ดีและดีกว่าคำตอบด้านล่างเล็กน้อย
Wyck

IMO ทุกอย่างควรอยู่ภายใต้การควบคุมเวอร์ชันและระบบควรจะสามารถจัดการกับสภาพแวดล้อมที่แตกต่างกันได้โดยไม่ต้องมีการแฮ็กข้อมูลตลอดจนทำให้สิ่งต่าง ๆ ปลอดภัยและง่ายต่อการทำงานด้วย ฉันเพิ่งโพสต์ว่าฉันทำได้อย่างไรซึ่งครอบคลุมข้อกังวลทั้งหมดของคุณ :) แจ้งให้เราทราบหากคุณมีคำถามใด ๆ เกี่ยวกับการตั้งค่าของฉัน
Ashfame

คำตอบ:


45

นี่คือวิธีที่ฉันทำและฉันไม่ได้เจออะไรที่ดีไปกว่านี้ ฉันเก็บไฟล์ wp-config.php เวอร์ชันอื่นไว้ภายใต้การควบคุมเวอร์ชันจากนั้นเก็บไฟล์หนึ่งไดเรกทอรีด้านบนซึ่งเก็บข้อมูลรับรองฐานข้อมูลและเกลือ / คีย์ทั้งหมด ด้วยวิธีนี้ฉันสามารถแยกแยะความแตกต่างระหว่างประเภทของการตั้งค่าที่ฉันกำลังทำงานและทำสิ่งต่าง ๆ บนพื้นฐานของสิ่งนั้น

นี่คือwp-config.phpฉันเก็บไว้ใต้git( https://gist.github.com/1923821 ):

<?php

/**
* Define type of server
*
* Depending on the type other stuff can be configured
* Note: Define them all, don't skip one if other is already defined
*/

define( 'DB_CREDENTIALS_PATH', dirname( ABSPATH ) ); // cache it for multiple use
define( 'WP_LOCAL_SERVER', file_exists( DB_CREDENTIALS_PATH . '/local-config.php' ) );
define( 'WP_DEV_SERVER', file_exists( DB_CREDENTIALS_PATH . '/dev-config.php' ) );
define( 'WP_STAGING_SERVER', file_exists( DB_CREDENTIALS_PATH . '/staging-config.php' ) );

/**
* Load DB credentials
*/

if ( WP_LOCAL_SERVER )
    require DB_CREDENTIALS_PATH . '/local-config.php';
elseif ( WP_DEV_SERVER )
    require DB_CREDENTIALS_PATH . '/dev-config.php';
elseif ( WP_STAGING_SERVER )
    require DB_CREDENTIALS_PATH . '/staging-config.php';
else
    require DB_CREDENTIALS_PATH . '/production-config.php';

/**
* 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.
*/

if ( ! defined( 'AUTH_KEY' ) )
    define('AUTH_KEY', '9*W=5&lt;Rw-)c].9}g?^[:!j]h+Efr&lt;y$&lt;YmV0XOo|lOIujEE}+[R}iAQZ :Sy3wN}');
if ( ! defined( 'SECURE_AUTH_KEY' ) )
    define('SECURE_AUTH_KEY', 'APge3~H;g+b0FyNF&amp;e`$=g?qj9@FQwqFe^Q4(@p#kDa=NR? $Z9|@v*a(tOj*B+.');
if ( ! defined( 'LOGGED_IN_KEY' ) )
    define('LOGGED_IN_KEY', '5l0+:WTpj8#[V|;&lt;Iw;%rkB(A}r++HwT|s[LW!.wt.=5J!b%Z{F1/[LxQ*d7J&gt;Cm');
if ( ! defined( 'NONCE_KEY' ) )
    define('NONCE_KEY', 'zO2cmQX`Kc~_XltJR&amp;T !Uc72=5Cc6`SxQ3;$f]#J)p&lt;/wwX&amp;7RTB2)K1Qn2Y*c0');
if ( ! defined( 'AUTH_SALT' ) )
    define('AUTH_SALT', 'je]#Yh=RN DCrP9/N=IX^,TWqvNsCZJ4f7@3,|@L]at .-,yc^-^+?0ZfcHjD,WV');
if ( ! defined( 'SECURE_AUTH_SALT' ) )
    define('SECURE_AUTH_SALT', '^`6z+F!|+$BmIp&gt;y}Kr7]0]Xb@&gt;2sGc&gt;Mk6,$5FycK;u.KU[Tw$345K9qoF}WV,-');
if ( ! defined( 'LOGGED_IN_SALT' ) )
    define('LOGGED_IN_SALT', 'a|+yZsR-k&lt;cSf@PQ~v82a_+{+hRCnL&amp;|aF|Z~yU&amp;V0IZ}Mrz@ND])YD22iUM[%Oc');
if ( ! defined( 'NONCE_SALT' ) )
    define('NONCE_SALT', '|1.e9Tx{fPv8D#IXO6[&lt;WY*,)+7+URp0~|:]uqiCOzu93b8,h4;iak+eIN7klkrW');

/**
* 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 = 'ft_';

/**
* WordPress Localized Language, defaults to English.
*
* Change this to localize WordPress. A corresponding MO file for the chosen
* language must be installed to wp-content/languages. For example, install
* de_DE.mo to wp-content/languages and set WPLANG to 'de_DE' to enable German
* language support.
*/

define( 'WPLANG', '' );

/**
* For developers: WordPress debugging mode.
*
* Change this to true to enable the display of notices during development.
* It is strongly recommended that plugin and theme developers use WP_DEBUG
* in their development environments.
*/

if ( WP_LOCAL_SERVER || WP_DEV_SERVER ) {

    define( 'WP_DEBUG', true );
    define( 'WP_DEBUG_LOG', true ); // Stored in wp-content/debug.log
    define( 'WP_DEBUG_DISPLAY', true );

    define( 'SCRIPT_DEBUG', true );
    define( 'SAVEQUERIES', true );

} else if ( WP_STAGING_SERVER ) {

    define( 'WP_DEBUG', true );
    define( 'WP_DEBUG_LOG', true ); // Stored in wp-content/debug.log
    define( 'WP_DEBUG_DISPLAY', false );

} else {

    define( 'WP_DEBUG', false );
}


/* That's all, stop editing! Happy blogging. */

/** Absolute path to the WordPress directory. */
if ( !defined('ABSPATH') )
define('ABSPATH', dirname(__FILE__) . '/');

/** Sets up WordPress vars and included files. */
require_once(ABSPATH . 'wp-settings.php');

และนี่คือไฟล์ config ท้องถิ่นซึ่งผมเก็บหนึ่งไดเรกทอรีดังกล่าวข้างต้นราก WordPress และนี้ยังทำให้มันนอกไดเรกทอรีเข้าถึงเว็บดังนั้นในกรณีของ Apache หยุดการแยกไฟล์ PHP และเริ่มขว้างปาพวกเขาออกข้อมูลประจำตัวของฐานข้อมูลของเรายังคงปลอดภัย ( https: / /gist.github.com/1923848 ):

<?php

/**
 * WordPress config file to use one directory above WordPress root, when awesome version of wp-config.php is in use.
 *
 * Awesome wp-config.php file - https://gist.github.com/1923821
 */

/* WordPress Local Environment DB credentials */

define('DB_NAME', 'project_21');
define('DB_USER', 'root');
define('DB_PASSWORD', 'root');
define('DB_HOST', 'localhost');
define('DB_CHARSET', 'utf8');
define('DB_COLLATE', '');

/* Keys & Salts */

define('AUTH_KEY',         '5H%)s-nQ,+fn0gwg/p1UjBTmCQ?l[8-!>Q{MW&?X3DM,OF;TaI<SOOTrl0+-@) *');
define('SECURE_AUTH_KEY',  '+%rr@,XIt-V+[.B9++uH1L,L+r)uq}5(:~=&4~Lk|.LV|y;R}fEo?G}+Sntf_JN}');
define('LOGGED_IN_KEY',    'Szv!gQm9#(L&TUD OnM`>sXGge:m1j`L2 5sO;hRNVhlN>IUED1/`%<[ly-GxVJ ');
define('NONCE_KEY',        'o-Jo;>G#-%~,[ki@REqXV%4^I.HDnc.3]P;e8];4pJt% $xe5K<aOb|a2*QKV4c-');
define('AUTH_SALT',        '8-tQb3d|W8,;Y_#mfuFB.1&b%U2fnlLD|F&yH).tLRX=ANEdNap{78o|9tqv6JPt');
define('SECURE_AUTH_SALT', 'RSa%^qd~T|@+!-;qgh,qK-GJ}zPpgxz#+@v6-I;BMwqT`TzGTtg_^n*ILxGOdbq4');
define('LOGGED_IN_SALT',   ']+XV)YK.Q-EU1vR [BT!Y$!d(J_[AO37OP[Fg[/esFx;6cI-L[^O|cvtw9F[;_*Q');
define('NONCE_SALT',       'iP{nTQBzy&f^hSbwBgyan.v9<+ErvAMi2ymLhz`Tl-fF?HXa(j<W`wA*8U3R#-|w');

วิธีนี้หากตั้งชื่อไฟล์ด้านบนlocal-config.phpระบบของฉันจะทำงานเหมือนการติดตั้งในเครื่อง หากตั้งชื่อstaging-config.phpไว้จะทำงานเหมือนกับการติดตั้ง staging และหากตั้งชื่อproduction-config.phpไว้ มันช่วยให้ฉันมีค่าที่แตกต่างกันของค่าคงที่บางอย่างเช่นการดีบักมีค่าแตกต่างกันภายใต้สภาพแวดล้อมที่แตกต่างกันและยังมีทุกอย่างภายใต้ SCM (git) ความเป็นไปได้ไม่มีที่สิ้นสุดและไม่จำเป็นต้องแฮ็กเกอร์สำหรับสภาพแวดล้อมที่แตกต่างกัน

สิ่งนี้ทำให้แน่ใจว่าคุณจะไม่เปิดเผยข้อมูลที่ละเอียดอ่อนใด ๆ ต่อสาธารณะและฉันใช้สิ่งนี้เพื่อเริ่มโครงการใด ๆ ที่ฉันทำงานอยู่ฉันมีคีย์ที่แข็งแรงกว่าโดยค่าเริ่มต้นและทันทีที่ฉันเพิ่มลงในไฟล์ config ที่สองหนึ่งไดเรกทอรีด้านบน สิ่งเหล่านี้จะถูกใช้แทนสิ่งที่กำหนดไว้ที่นี่ บลิส!


ฉันชอบวิธีนี้ฉันอาจจะทำอะไรแบบนี้
jjeaton

คุณอ้างอิงถึง-local-config-file-in-the-parent-directory จากไฟล์ config หลักได้อย่างไร? ผ่านลิงก์สัญลักษณ์หรือผ่าน../(เช่น../filename) ที่ไหนสักแห่ง? - ฉันไม่พบสิ่งใด../ในwp-config.phpไฟล์หลัก
KajMagnus

1
@KajMagnus คงที่DB_CREDENTIALS_PATHไม่ว่า
Ashfame

9

ฉันจะทำสิ่งนี้ได้อย่างไรโดยไม่เปิดเผยรหัสผ่านให้คอมไพล์ในกรณีที่ที่เก็บนี้กลายเป็นที่สาธารณะ

หากwp-config.phpไฟล์อยู่ในการควบคุมรุ่นแล้วรหัสผ่านใด ๆ มันมีจะยังอยู่ในการควบคุมรุ่น วิธีเดียวที่จะหลีกเลี่ยงได้คือไม่ต้องวางไฟล์ในการควบคุมเวอร์ชัน

นี่เป็นปัญหามากเกินไปหรือไม่และฉันควรปล่อยให้ wp-config.php ไม่มีการยกเลิกหรือไม่

ความรู้สึกของฉันคือการทำให้ไม่wp-config.phpรู้สึกตัวเลย แต่มีบางวิธีอยู่รอบ ๆ

แยกส่วนของwp-config.phpที่มีรหัสผ่านของคุณและแฮชเป็นไฟล์แยกต่างหากและinclude()มันอยู่ในwp-config.phpไฟล์ปกติ จากนั้นให้วางwp-config.phpภายใต้การควบคุมเวอร์ชัน แต่ให้include()แยกไฟล์ของคุณ

wp-config.php:

<?php
/**
 * The base configurations of the WordPress.
 *
 * This file has the following configurations: MySQL settings, Table Prefix,
 * Secret Keys, WordPress Language, and ABSPATH. You can find more information
 * by visiting {@link http://codex.wordpress.org/Editing_wp-config.php Editing
 * wp-config.php} Codex page. You can get the MySQL settings from your web host.
 *
 * This file is used by the wp-config.php creation script during the
 * installation. You don't have to use the web site, you can just copy this file
 * to "wp-config.php" and fill in the values.
 *
 * @package WordPress
 */

/** Database Charset to use in creating database tables. */
define('DB_CHARSET', 'utf8');

/** The Database Collate type. Don't change this if in doubt. */
define('DB_COLLATE', '');

include( 'conf.php' );    

/**#@-*/

/**
 * 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_';

/**
 * WordPress Localized Language, defaults to English.
 *
 * Change this to localize WordPress. A corresponding MO file for the chosen
 * language must be installed to wp-content/languages. For example, install
 * de_DE.mo to wp-content/languages and set WPLANG to 'de_DE' to enable German
 * language support.
 */
define('WPLANG', '');

/**
 * For developers: WordPress debugging mode.
 *
 * Change this to true to enable the display of notices during development.
 * It is strongly recommended that plugin and theme developers use WP_DEBUG
 * in their development environments.
 */
define('WP_DEBUG', false);

/* That's all, stop editing! Happy blogging. */

/** Absolute path to the WordPress directory. */
if ( !defined('ABSPATH') )
    define('ABSPATH', dirname(__FILE__) . '/');

/** Sets up WordPress vars and included files. */
require_once(ABSPATH . 'wp-settings.php');

คุณสามารถเห็นได้ว่ารหัสผ่านและแฮชไม่ได้รวมอยู่ในwp-config.phpทั้งหมด

conf.php:

// ** MySQL settings - You can get this info from your web host ** //
/** The name of the database for WordPress */
define('DB_NAME', 'database_name_here');

/** MySQL database username */
define('DB_USER', 'username_here');

/** MySQL database password */
define('DB_PASSWORD', 'password_here');

/** MySQL hostname */
define('DB_HOST', 'localhost');


/**#@+
 * 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',         'put your unique phrase here');
define('SECURE_AUTH_KEY',  'put your unique phrase here');
define('LOGGED_IN_KEY',    'put your unique phrase here');
define('NONCE_KEY',        'put your unique phrase here');
define('AUTH_SALT',        'put your unique phrase here');
define('SECURE_AUTH_SALT', 'put your unique phrase here');
define('LOGGED_IN_SALT',   'put your unique phrase here');
define('NONCE_SALT',       'put your unique phrase here');

แต่จริงๆแล้ว ณ จุดนี้คุณเพิ่งเพิ่มระดับนามธรรมที่เป็นนามธรรมที่นี่ เหตุผลทั้งหมดwp-config.phpแยกกันตั้งแต่แรกเพราะมันเป็นเรื่องของสิ่งแวดล้อม คุณไม่ควรคัดลอกจากเซิร์ฟเวอร์ภายในเครื่องไปยังการผลิตเลย ... ดังนั้นจึงไม่ควรอยู่ภายใต้การควบคุมเวอร์ชันเลย


ดูเหมือนว่าจะมีงานพิเศษ แต่ฉันสามารถเห็นประโยชน์ในการตรวจสอบให้แน่ใจว่าการตั้งค่า wp-config ทั้งหมดซิงค์กันระหว่างสภาพแวดล้อม
jjeaton

การแยกwp-config.phpมีข้อดีพิเศษ: คุณสามารถรวมconf.phpไว้ในสคริปต์ที่ไม่ใช่ WP โดยไม่ต้องโหลด WordPress ทั้งหมด
Tamlyn

4

ตัวอย่างของ Markถือว่าคุณทำงานกับ repo ส่วนตัว:

if ( file_exists( dirname( __FILE__ ) . '/local-config.php' ) ) {
  include( dirname( __FILE__ ) . '/local-config.php' );
  define( 'WP_LOCAL_DEV', true ); 
} else {
  define( 'DB_NAME',     'production_db'       );
  define( 'DB_USER',     'production_user'     );
  define( 'DB_PASSWORD', 'production_password' );
  define( 'DB_HOST',     'production_db_host'  );
}

แทนที่จะกำหนดข้อมูลประจำตัวคุณสามารถสร้างไฟล์ production-config.php ได้อย่างง่ายดายและรวมไว้ในการตรวจสอบตามเงื่อนไข:

if ( file_exists( dirname( __FILE__ ) . '/local-config.php' ) ) {
      include( dirname( __FILE__ ) . '/local-config.php' );
      define( 'WP_LOCAL_DEV', true ); 
    } else {
     include( dirname( __FILE__ ) . '/production-config.php' )
    }

จากนั้นใน production-config.php ที่ไม่ได้ติดอันดับของคุณ:

  define( 'DB_NAME',     'production_db'       );
  define( 'DB_USER',     'production_user'     );
  define( 'DB_PASSWORD', 'production_password' );
  define( 'DB_HOST',     'production_db_host'  );

แม้ว่าจะเป็น repo ส่วนตัวฉันก็ไม่ต้องการรหัสผ่านที่เก็บไว้ในนั้นและต้องการความยืดหยุ่นในการทำให้ repo เป็นสาธารณะถ้าฉันต้องการ production-config.php น่าจะเป็นวิธีที่ดีที่จะไป
jjeaton

2

คุณสามารถคอมมิตwp-config.phpไฟล์ไปยังที่เก็บโดยไม่มีสตริงลับของคุณจากนั้นรัน:

git update-index --assume-unchanged wp-config.php

สิ่งนี้จะบอกให้คอมไพล์สมมติว่าไฟล์นั้นดีไม่เปลี่ยนแปลง


4
เป็นการดีที่ไม่ทราบถึงการassume-unchangedสลับ แต่นี่คือสองจุดของฉัน: (1) หากคุณคอมไพล์เพิ่มไฟล์โดยตรงมันจะถูกเพิ่มไปยังดัชนี ดังนั้นจึงมีความเสี่ยงที่คุณสามารถเพิ่มเข้าไปได้ในบางจุด (2) การรวมการผูกมัดด้วยการตั้งค่าสถานะนี้จะทำให้การผสานล้มเหลวอย่างสง่างามเพื่อให้คุณสามารถจัดการได้ด้วยตนเองซึ่งทำให้สิ่งนี้ไม่ใช่โซลูชันที่สง่างาม สามารถใช้เพื่อเพิกเฉยต่อการเปลี่ยนแปลงในขณะที่บางสิ่งบางอย่างเช่นเซสชันการพัฒนาเท่านั้น อ่านเพิ่มเติมได้ที่ - gitready.com/intermediate/2009/02/18/…
Ashfame
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.