WordPress 管理插件是否加载在前端?

Are WordPress admin plugins loaded on the front end?

我的问题基本上是:"back-end" 插件是否会在匿名用户(例如浏览我的博客)时加载?"back-end" 插件不会影响博客前端吗?

比方说 EWWW 图像优化器:它只是在后端优化图像。它有一个管理界面来优化图像,但最终用户根本不使用它。它仍然会在每次访问页面时加载吗?

我不确定我是否表达清楚了。希望如此。

据我所知,在 WordPress API 中无法将插件指定为管理员。我知道的唯一插件类型是 'must use'、'network activitate'(用于多用户站点)和 'active',所以我认为管理插件也可以在非管理模式下加载。插件加载在 wp-settings.php 中。我阅读了代码,在我看来,就插件加载而言,WordPress 不区分管理模式和非管理模式。相关代码为:

// Load must-use plugins.
foreach ( wp_get_mu_plugins() as $mu_plugin ) {
  include_once( $mu_plugin );
}
unset( $mu_plugin );

// Load network activated plugins.
if ( is_multisite() ) {
  foreach ( wp_get_active_network_plugins() as $network_plugin ) {
    wp_register_plugin_realpath( $network_plugin );
    include_once( $network_plugin );
  }
  unset( $network_plugin );
}

...

// Load active plugins.
foreach ( wp_get_active_and_valid_plugins() as $plugin ) {
  wp_register_plugin_realpath( $plugin );
  include_once( $plugin );
}
unset( $plugin );

function wp_get_mu_plugins() {
  $mu_plugins = array();
  if ( !is_dir( WPMU_PLUGIN_DIR ) )
    return $mu_plugins;
  if ( ! $dh = opendir( WPMU_PLUGIN_DIR ) )
    return $mu_plugins;
  while ( ( $plugin = readdir( $dh ) ) !== false ) {
    if ( substr( $plugin, -4 ) == '.php' )
      $mu_plugins[] = WPMU_PLUGIN_DIR . '/' . $plugin;
  }
  closedir( $dh );
  sort( $mu_plugins );

  return $mu_plugins;
}

function wp_get_active_network_plugins() {
  $active_plugins = (array) get_site_option( 'active_sitewide_plugins', array() );
  if ( empty( $active_plugins ) )
    return array();

  $plugins = array();
  $active_plugins = array_keys( $active_plugins );
  sort( $active_plugins );

  foreach ( $active_plugins as $plugin ) {
    if ( ! validate_file( $plugin ) // $plugin must validate as file
      && '.php' == substr( $plugin, -4 ) // $plugin must end with '.php'
      && file_exists( WP_PLUGIN_DIR . '/' . $plugin ) // $plugin must exist
      )
    $plugins[] = WP_PLUGIN_DIR . '/' . $plugin;
  }
  return $plugins;
}

function wp_get_active_and_valid_plugins() {
  $plugins = array();
  $active_plugins = (array) get_option( 'active_plugins', array() );

  // Check for hacks file if the option is enabled
  if ( get_option( 'hack_file' ) && file_exists( ABSPATH . 'my-hacks.php' ) ) {
    _deprecated_file( 'my-hacks.php', '1.5.0' );
    array_unshift( $plugins, ABSPATH . 'my-hacks.php' );
  }

  if ( empty( $active_plugins ) || wp_installing() )
    return $plugins;

  $network_plugins = is_multisite() ? wp_get_active_network_plugins() : false;

  foreach ( $active_plugins as $plugin ) {
    if ( ! validate_file( $plugin ) // $plugin must validate as file
      && '.php' == substr( $plugin, -4 ) // $plugin must end with '.php'
      && file_exists( WP_PLUGIN_DIR . '/' . $plugin ) // $plugin must exist
      // not already included as a network plugin
      && ( ! $network_plugins || ! in_array( WP_PLUGIN_DIR . '/' . $plugin, $network_plugins ) )
      )
    $plugins[] = WP_PLUGIN_DIR . '/' . $plugin;
  }
  return $plugins;
}

当然,最简单的确定方法是使用可疑插件在 WordPress 安装上加载前端页面,并使用调试器检查它是否加载。

此外,如果插件仅供管理员使用,则插件作者只能拥有

if ( ! is_admin() ) {
    return;
}

在主插件文件的开头。所以插件基本上不会加载。