Woocommerce Rest API无法正常工作401未授权

时间:2020-06-03 13:20:33

标签: woocommerce woocommerce-rest-api

我有wordpress 5.4.1和woocommerce 4.2,还有我们加密的ssl证书

在使用查询字符串https://www.store.com/wp-json/wc/v3/products?consumer_key=ck_XXXX&consumer_secret=cs_XXX之前,我设法从API得到响应,但是突然它停止工作,给我401未经授权的错误。我对钥匙有100%的把握。

我在FastCgi中使用php,并且我读到服务器有时无法正确读取授权,所以我尝试了以下操作

我添加了

<IfModule mod_setenvif>
  SetEnvIf Authorization "(.*)" HTTP_AUTHORIZATION=$1
</IfModule>

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization}]
RewriteBase /
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
</IfModule>

到我的.htaccess文件

我也添加了

RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]

在RewriteEngine上后进入我的httpd.conf文件

我还安装了基本身份验证插件https://github.com/WP-API/Basic-Auth

以上所有解决方案均未得到邮递员或失眠的回应,并且未授权出现相同的错误401。

1 个答案:

答案 0 :(得分:0)

两天后我终于得到了答案

最好的解决方案是删除所有上述内容,然后添加

RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization}]

所以我的整个htaccess块看起来像:

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization}]
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
</IfModule>