Chat / support@radicenter.eu

WordPressis ei saa uuendada sisu või annab API veateate 403 / Offline

Viimasel paaril päeval on osad kasutajad, kellel WP install on domeeni alamkaustas või alamdomeenil ja kasutavad Gutenberg editori kuid käivitatakse veebilehte põhidomeeni kaudu, meie poole pöördunud murega, et kas WP API kaudu päringud ei toimi või ei ole võimalik uuendada lehtedel/postitustes olevat sisu.
Antud võimalik “murekoht” paistab olevat seotud CORS turvalisusega (Täpsemalt: https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS ) kus siis muudel domeenidel (ka põhidomeen on muu domeeninimi, kui üritatakse ligi pääseda API kaudu alamdomeenile ja vastupidi) kui WP installitud domeenil, keelatakse ligipääs veebiserveri ja veebibrowseri vahel vastavalt üldistele turvalisusmäärangutele olenevalt, millise CORS määrangu veebiserver veebibrowserile tagastab.

WordPressi jaoks oleks lahenduseks üks järgnevatest:
– Kasutada Gutenbergi asemel tavaeditori (Classic editor)
– Muuta site ja home URL’id samaks
– Lisada functions.php faili (soovitame kasutada child-theme oma, kuna vastasel juhul võib teema või WP uuendus selle uuesti üle kirjutada!) kood:

add_action('init', 'handle_preflight');
function handle_preflight() {
    $origin = get_http_origin();
    if ($origin === 'https://TEIEDOMEENINIMI_TLD') {
        header("Access-Control-Allow-Origin: TEIEDOMEENINIMI_TLD");
        header("Access-Control-Allow-Methods: POST, GET, OPTIONS, PUT, DELETE");
        header("Access-Control-Allow-Credentials: true");
        header('Access-Control-Allow-Headers: Origin, X-Requested-With, X-WP-Nonce, Content-Type, Accept, Authorization');
        if ('OPTIONS' == $_SERVER['REQUEST_METHOD']) {
            status_header(200);
            exit();
        }
    }
}
add_filter('rest_authentication_errors', 'rest_filter_incoming_connections');
function rest_filter_incoming_connections($errors) {
    $request_server = $_SERVER['REMOTE_ADDR'];
    $origin = get_http_origin();
    if ($origin !== 'https://TEIEDOMEENINIMI_TLD') return new WP_Error('forbidden_access', $origin, array(
        'status' => 403
    ));
    return $errors;
}

Kus siis TEIEDOMEENINIMI_TLD tuleks asendada vastava domeeniga/alamdomeeniga, millelt päringuid tehakse ja hetkel on blokeeritud!

Antud kood ja info on inglisekeelsena leitav lingilt:
WordPress REST API CORS Issues Solved
Lisainfot antud Gutenbergi WP vea kohta on leitav ka lehelt:
Gutenberg breaks completely if site URL is not the same as wordpress URL

Comments are currently closed.

See veebileht kasutab küpsiseid, mis aitavad teha lehe külastamise mugavamaks. Meie veebilehte külastades nõustute meiepoolse küpsiste kasutamisega.
Sain aru.