WordPress Rest API 反向代理
Wordpress Rest API reverse Proxy
我正在尝试使用 wordpress 设置反向代理并排除几个路径。我的排除规则适用于 admin、includes、..etc 但不适用于 /wp-json/。我怀疑是因为 .htaccess。我需要 wordpress 来 return 其余 api 数据,因为我在 gatsbyjs 中使用它。
我花了一整天的时间来弄清楚这个问题。出于某种原因,我的设置 /wp-json/ returns 404 被代理到我网站前端部分所在的 netlify 服务器。如果我删除所有代理规则 wp-json 有效。
.htaccess 包含默认的 wordpress 内容。
这是我的虚拟主机的 pastebin:
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
来自 the documentation,请参阅 分页导航不起作用 部分:
“这是由于 WordPress 生成的 .htaccess 文件中存在故障。要修复它,请删除 .htaccess 文件的内容并重新创建它。
- 在“控制面板”中,转到“管理”>“文件”(有关编辑文件的更多信息);
- 单击 link 到您的 .htaccess 文件以编辑其内容;
- 复制文件内容并将其粘贴到文本编辑器中的文本文件中。这是一种预防措施,以防您的 .htaccess 文件包含用于重定向、拒绝或其他方便的 htaccess 技巧的手动条目;
- 从您的 .htaccess 文件中删除所有内容并单击“更新文件”按钮;
- 在控制面板中,转到选项 > Permalinks;
- 单击更新 Permalink 结构按钮为您的 permalinks 重新生成新的重写规则;
- 使用之前损坏的 link 测试结果;
- 将任何手动 htaccess 条目添加回您的文件(将手动 htaccess 条目放在 # BEGIN WordPress 之前或 # END WordPress 行之后。)"
它不起作用,因为/wp-json
不是真正的文件或目录,不读取.htaccess
,本地请求将得到404
not found
响应,所以Apache 会继续将请求转发到远程服务器。
要修复此 URL 重写,我们需要将请求发送到本地 index.php
。
将ProxyPass /wp-json/ !
替换为
ProxyPass /index.php !
ProxyPass /wp-json !
/wp-json
没有结束斜线 /
需要处理对 domain/wp-json
或 domain/wp-json/
的请求。
任何其他不存在的 URL 将由远程服务器处理。
我正在尝试使用 wordpress 设置反向代理并排除几个路径。我的排除规则适用于 admin、includes、..etc 但不适用于 /wp-json/。我怀疑是因为 .htaccess。我需要 wordpress 来 return 其余 api 数据,因为我在 gatsbyjs 中使用它。
我花了一整天的时间来弄清楚这个问题。出于某种原因,我的设置 /wp-json/ returns 404 被代理到我网站前端部分所在的 netlify 服务器。如果我删除所有代理规则 wp-json 有效。
.htaccess 包含默认的 wordpress 内容。
这是我的虚拟主机的 pastebin: 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
来自 the documentation,请参阅 分页导航不起作用 部分:
“这是由于 WordPress 生成的 .htaccess 文件中存在故障。要修复它,请删除 .htaccess 文件的内容并重新创建它。
- 在“控制面板”中,转到“管理”>“文件”(有关编辑文件的更多信息);
- 单击 link 到您的 .htaccess 文件以编辑其内容;
- 复制文件内容并将其粘贴到文本编辑器中的文本文件中。这是一种预防措施,以防您的 .htaccess 文件包含用于重定向、拒绝或其他方便的 htaccess 技巧的手动条目;
- 从您的 .htaccess 文件中删除所有内容并单击“更新文件”按钮;
- 在控制面板中,转到选项 > Permalinks;
- 单击更新 Permalink 结构按钮为您的 permalinks 重新生成新的重写规则;
- 使用之前损坏的 link 测试结果;
- 将任何手动 htaccess 条目添加回您的文件(将手动 htaccess 条目放在 # BEGIN WordPress 之前或 # END WordPress 行之后。)"
它不起作用,因为/wp-json
不是真正的文件或目录,不读取.htaccess
,本地请求将得到404
not found
响应,所以Apache 会继续将请求转发到远程服务器。
要修复此 URL 重写,我们需要将请求发送到本地 index.php
。
将ProxyPass /wp-json/ !
替换为
ProxyPass /index.php !
ProxyPass /wp-json !
/wp-json
没有结束斜线 /
需要处理对 domain/wp-json
或 domain/wp-json/
的请求。
任何其他不存在的 URL 将由远程服务器处理。