Invio di una stringa JSON tramite wp_remote_post ()


13

Sto costruendo un'integrazione mailchimp e richiedono una chiamata POST con codice JSON.

No, sto usando questo codice che funziona davvero :

$data = wp_remote_post($url, array(
    'headers'   => array('Content-Type' => 'application/json; charset=utf-8'),
    'body'      => json_encode($array_with_parameters),
    'method'    => 'POST'
));

Ma restituisce un avviso PHP

Avviso: http_build_query (): il parametro 1 dovrebbe essere Array o Object. Valore errato fornito in ../wp-includes/Requests/Transport/cURL.php sulla riga 507

Come evitarlo?

Ho provato a usare l'array semplice nell'indice 'body' ma MailChimp restituisce un errore di analisi JSON.


1
Hai applicato questa patch al core? core.trac.wordpress.org/ticket/37700
Otto,

Interessante. È un plugin commerciale, quindi deve funzionare su qualsiasi installazione WP. Ma dal momento che sembra essere un bug WP, per me è ok. Grazie molto!
a-coder,

Risposte:


16

Prova a impostare il data_formatparametro nella tua richiesta in questo modo:

$data = wp_remote_post($url, array(
    'headers'     => array('Content-Type' => 'application/json; charset=utf-8'),
    'body'        => json_encode($array_with_parameters),
    'method'      => 'POST',
    'data_format' => 'body',
));

Sembra che il formato possa essere predefinito query, nel qual caso WordPress tenta di formattare i dati utilizzando http_build_query, il che ti dà problemi poiché stai già formattando il corpo come una stringa. Ecco il check in rilevante wp-includes/class-http.php:

if (!empty($data)) {
    $data_format = $options['data_format'];

    if ($data_format === 'query') {
        $url = self::format_get($url, $data);
        $data = '';
    }
    elseif (!is_string($data)) {
        $data = http_build_query($data, null, '&');
    }
}

Poiché il tuo errore proviene dalla riga 507 di wp-includes/Requests/Transport/cURL.php, possiamo vedere che questa è la chiamata di root a http_build_query:

protected static function format_get($url, $data) {
    if (!empty($data)) {
        $url_parts = parse_url($url);
        if (empty($url_parts['query'])) {
            $query = $url_parts['query'] = '';
        }
        else {
            $query = $url_parts['query'];
        }

        $query .= '&' . http_build_query($data, null, '&');
        $query = trim($query, '&');

        if (empty($url_parts['query'])) {
            $url .= '?' . $query;
        }
        else {
            $url = str_replace($url_parts['query'], $query, $url);
        }
    }
    return $url;
}
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.