Чи коли-небудь викликається файл function.php під час дзвінка AJAX? Налагодження AJAX


23

Намагаючись розібратися в проблемі, яку має колега-програміст. Мені було цікаво, чи functions.phpвзагалі зателефонують у файл, коли ви робите адміністратор AJAX? Я знаю, що під час виклику AJAX частина WP завантажується для обробки дзвінка та повернення відповіді. Чи functions.phpдодається файл?

Я питаю, що він використовує клас із плагіна Meta-Box` і завантажує його як частину теми. У цьому класі є якийсь AJAX, який повертає лише порожні відповіді, і я вважаю, що код, який обробляє відповідь, не завантажується. Чи є документація до того, що завантажується, коли WP обробляє AJAX?

Відповіді:


28

admin-ajax.phpвантажі wp-load.php:

/** Load WordPress Bootstrap */
require_once( dirname( dirname( __FILE__ ) ) . '/wp-load.php' );

wp-load.phpвантажі wp-config.php, і там wp-settings.phpзавантажується.

І ось ми знаходимо це:

// Load the functions for the active theme, for both parent and child theme if applicable.
if ( ! defined( 'WP_INSTALLING' ) || 'wp-activate.php' === $pagenow ) {
    if ( TEMPLATEPATH !== STYLESHEETPATH && file_exists( STYLESHEETPATH . '/functions.php' ) )
        include( STYLESHEETPATH . '/functions.php' );
    if ( file_exists( TEMPLATEPATH . '/functions.php' ) )
        include( TEMPLATEPATH . '/functions.php' );
}

Отже, так, тема functions.phpзавантажена.


Є один виняток у wp-settings.php:

// Stop most of WordPress from being loaded if we just want the basics.
if ( SHORTINIT )
    return false;

Якщо SHORTINITвизначено як TRUEраніше, тема не завантажується.

Тож перевірте, чи SHORTINITце TRUEз якоїсь причини.


Ще одна поширена помилка - неправильне використання is_admin(). Це завжди TRUEв admin-ajax.php, тому наступне не вдасться:

if ( ! is_admin() )
    // register or execute AJAX stuff

Налагодження AJAX

Один з найпримітивніших і найефективніших методів - використання заголовка HTTP для налагодження AJAX.

Ось проста функція помічника:

function send_debug_header( $msg )
{
    static $counter = 1;
    header( "X-Debug-Ajax-$counter: $msg" );
    $counter += 1;
}

І цей плагін показує, як ним користуватися:

<?php # -*- coding: utf-8 -*-
/**
 * Plugin Name: Debug AJAX per HTTP
 * Description: Look at the HTTP headers in your browser's network console
 */

// The constant is already defined when plugins are loaded.
// Prove we have been called.
if ( defined( 'DOING_AJAX' ) && DOING_AJAX )
    send_debug_header( 'File "' . __FILE__ . '" was called on an AJAX request.' );

function send_debug_header( $msg )
{
    static $counter = 1;
    header( "X-Debug-Ajax-$counter: $msg" );
    $counter += 1;
}

add_action( 'wp_ajax_debug_test',        't5_debug_test' );
add_action( 'wp_ajax_nopriv_debug_test', 't5_debug_test' );

function t5_debug_test()
{
    $in = is_user_logged_in() ? '' : 'not ';
    send_debug_header( 'Function "' . __FUNCTION__ . '" was called and the user is ' . $in . 'logged in.' );
    print_r( debug_backtrace() );
    die(1);
}

add_action( 'wp_enqueue_scripts', 't5_enqueue_jquery' );

function t5_enqueue_jquery()
{
    wp_enqueue_script( 'jquery' );
}
add_action( 'wp_footer', 't5_debug_ajax_test_button', 0 );

function t5_debug_ajax_test_button()
{
    ?>
<input type="submit" id="t5debugajax" value="Debug AJAX">
<script>
jQuery( function($){
    var sendFeedBack = function( response ){
        console.log( response );
    };
    $("#t5debugajax").on("click", function(){
        $.post(
            "<?php echo admin_url( 'admin-ajax.php' ); ?>",
            {
                action: "debug_test"
            },
            sendFeedBack
        );
    });
});
</script>
    <?php
}

Це додасть кнопку на передній частині, яка запускає запит AJAX при натисканні на нього. Відкрийте мережеву консоль веб-переглядача та перегляньте заголовки відповідей на запит:

введіть тут опис зображення


Як детально, як ніколи, @toscho. Особливо важко налагоджувати, коли код працює на вашому кінці, але не для когось іншого. Здається, не відтворюється проблема, але ваша відповідь, ймовірно, надішле мене в правильному напрямку.
Менні Флермонд

@MannyFleurmond Я додав плагін помічника налагодження. Це повинно допомогти знайти проблему.
fuxia

9
Людина, ти ретельний :)
Менні Флермонд

TEMPLATEPATH? ;)
кайзер

1

Я припускаю, що ваша проблема працювала, якщо AJAX працював, якщо ви увійшли в систему, і він не працював у статусі виходу з системи, правда?
У WordPress є функція доступу до файлів на основі AJAX для користувачів, які не ввійшли в систему: wp_ajax_noprivнаприклад

/* works for logged users */
add_action( 'wp_ajax_my_action', 'my_action_callback');

/* works for non logged users */
add_action( 'wp_ajax_nopriv_my_action', 'my_action_callback');
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.