Wordpress Rest API反向代理

时间:2018-11-27 20:23:36

标签: http-proxy mod-proxy gatsby wordpress-rest-api

我正在尝试使用wordpress设置反向代理,并排除几个路径。我的排除规则适用于admin(包括..etc),但不适用于/ wp-json /。我怀疑是因为.htaccess。我需要wordpress返回其余的api数据,因为我在gatsbyjs中使用了它。

我整天都在努力解决这个问题。由于某种原因,我的设置/ wp-json /返回404,它被代理到我站点前端所在的netlify服务器。如果我删除所有代理规则,则wp-json起作用。

.htaccess包含默认的wordpress内容。

这是我的虚拟主机的粘贴框: https://pastebin.com/vFh6hCkN

<IfModule mod_ssl.c>
   <VirtualHost *:443>
    # The ServerName directive sets the request scheme, hostname and port that
    # the server uses to identify itself. This is used when creating
    # redirection URLs. In the context of virtual hosts, the ServerName
    # specifies what hostname must appear in the request's Host: header to
    # match this virtual host. For the default virtual host (this file) this
    # value is not decisive as it is used as a last resort host regardless.
    # However, you must set it for any further virtual host explicitly.

    Protocols h2 http/1.1
    ServerName  www.michaelharwinlaw.com
    ServerAlias michaelharwinlaw.com
    ServerAdmin webmaster@cyberserge.com
    DocumentRoot /var/www/html/

    <Directory /var/www/html>
            Options Indexes FollowSymLinks MultiViews
            AllowOverride All
            Order allow,deny
            allow from all
    </Directory>

    SSLProxyEngine on
    ProxyPass /wp-admin/ !
    ProxyPass /wp-login/ !
    ProxyPass /wp-json/ !
    ProxyPass /wp-content/plugins/ !
    ProxyPass /wp-includes/ !
    ProxyPassMatch .*\.xml !
    ProxyPass / https://stag.michaelharwinlaw.com/
    ProxyPassReverse / https://stag.michaelharwinlaw.com/

    # Available loglevels: trace8, ..., trace1, debug, info, notice, warn,
    # error, crit, alert, emerg.
    # It is also possible to configure the loglevel for particular
    # modules, e.g.
    #LogLevel info ssl:warn

    ErrorLog ${APACHE_LOG_DIR}/mc-error.log
    CustomLog ${APACHE_LOG_DIR}/mc-access.log combined

    # For most configuration files from conf-available/, which are
    # enabled or disabled at a global level, it is possible to
    # include a line for only one particular virtual host. For example the
    # following line enables the CGI configuration for this host only
    # after it has been globally disabled with "a2disconf".
    #Include conf-available/serve-cgi-bin.conf

    Include /var/www/html/wp-content/uploads/wpseo-redirects/.redirects

    SSLCertificateFile /etc/letsencrypt/live/www.michaelharwinlaw.com/fullchain.pem
    SSLCertificateKeyFile /etc/letsencrypt/live/www.michaelharwinlaw.com/privkey.pem
    Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>

.htaccess

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
</IfModule>
# END WordPress

2 个答案:

答案 0 :(得分:6)

它不起作用,因为/wp-json不是真实的文件或目录,如果不读取.htaccess,本地请求将得到404 not found响应,因此Apache将继续将请求转发到远程服务器。

要解决此URL重写问题,我们需要将请求发送到本地index.php

ProxyPass /wp-json/ !替换为

ProxyPass /index.php !
ProxyPass /wp-json !
需要

/wp-json而不使用斜杠/来处理对domain/wp-jsondomain/wp-json/的请求。

其他不存在的URL将由远程服务器处理。

答案 1 :(得分:0)

the documentation中,请参见分页导航不起作用部分:

“这是由于WordPress生成的.htaccess文件中存在故障。要解决该问题,请删除.htaccess文件中的内容,然后重新创建。

  1. 在控制面板中,转到“管理”>“文件”(有关编辑文件的更多信息);
  2. 点击指向.htaccess文件的链接以编辑其内容;
  3. 复制文件的内容并将其粘贴到文本编辑器中的文本文件中。如果您的.htaccess文件具有用于重定向,拒绝或其他方便的htaccess技巧的手动条目,这是一种预防措施;
  4. 从.htaccess文件中删除所有内容,然后单击“更新文件”按钮;
  5. 在控制面板中,转到选项>永久链接;
  6. 单击“更新永久链接结构”按钮为您的永久链接重新生成新的重写规则;
  7. 使用以前断开的链接测试结果;
  8. 在文件中添加任何手动htaccess条目(将手动htaccess条目放置在#BEGIN WordPress之前或#END WordPress行之后。)