Parece que as extensões php-xml
e php-xmlrpc
não estão instaladas.
Instale-os com:
apt-get install php-xml php-xmlrpc
ou (CentOS, RHEL etc.)
yum install php-xml php-xmlrpc
Instalei o Wordpress com Nginx e PHP-FPM no meu próprio servidor, no link
A instalação funciona muito bem, mas o XML-RPC (usado pelo Jetpack e pelos aplicativos do telefone) gera o seguinte erro:
<?xml version="1.0" encoding="UTF-8"?>
<methodResponse>
<fault>
<value>
<struct>
<member>
<name>faultCode</name>
<value><int>-32700</int></value>
</member>
<member>
<name>faultString</name>
<value><string>parse error. not well formed</string></value>
</member>
</struct>
</value>
</fault>
</methodResponse>
Você mesmo pode ver o erro executando
curl -A "Jetpack by WordPress.com" -is -H 'Content-Type: text/xml' --data '<?xml version="1.0"?><methodCall><methodName>demo.sayHello</methodName><params></params></methodCall>' 'https://saskia.photo/xmlrpc.php' && echo
Trabalhei com a página de solução de problemas do Jetpack , mas sem sorte.
O erro XML retornado me leva a especular que o XML de solicitação do cliente está sendo corrompido em algum lugar entre o nginx e o PHP para que não possa ser analisado.
Aqui está o meu arquivo de configuração nginx
server {
listen 80;
listen [::]:80;
server_name saskia.photo;
rewrite ^ https://$server_name$request_uri? permanent;
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name saskia.photo;
ssl_certificate /etc/letsencrypt/live/saskia.photo/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/saskia.photo/privkey.pem;
root /srv/wordpress/;
charset utf-8;
client_max_body_size 64M;
# Deny access to any files with a .php extension in the uploads directory
location ~* /(?:uploads|files)/.*\.php$ {
deny all;
}
location / {
index index.php index.html index.htm;
try_files $uri $uri/ /index.php?$args;
}
location ~* \.(gif|jpg|jpeg|png|css|js)$ {
expires max;
}
location ~ \.php$ {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_index index.php;
fastcgi_pass unix:/var/run/php/wordpress.sock;
fastcgi_param SCRIPT_FILENAME
$document_root$fastcgi_script_name;
include fastcgi_params;
}
}
Alguém viu um problema como este ou pode detectar um problema em meus arquivos de configuração?