我有一个在Heroku上运行的rails应用程序,我正在尝试在/ blog上为我的域设置一个Wordpress博客用于搜索引擎优化目的.我在我的rails应用程序中设置了Rack :: ReverseProxy,指向博客的子域名,并设置了Wordpress端的所有配置,以便所有css和链接正常工作.我遇到的问题是,当我去/ blog / wp-admin时,我被重定向到/ blog / wp-login?redirect_to = {blog’s subdomain}& reauth = 1,并且在尝试登录后我就是发送到同一页面.
我注意到即使正在为正确的域设置Wordpress的测试Cookie,我也没有为登录做饭.我甚至在wp_set_auth_cookie中的wp-includes / pluggable.php中跟踪它,它在成功登录后实际设置了cookie,对setcookie的调用返回true,但是在cookie没有添加到我的会话之后立即(即使测试Cookie确实在标题中成功完成)
我在那里看错了方向吗?我应该调查哪些设置才能以这种方式登录?
最佳答案 我有这个确切的问题,我最终将其追踪到机架反向代理中的错误. set-cookie标头以不正确的格式发送,因此浏览器只能正确解释第一个cookie.这恰好是wordpress测试cookie.所有其他(有用的)都被扔掉了,所以当然我无法登录.
我计划提交一个bug和分支到rack-reverse-proxy,但同时我在我的config.ru中修复了这个补丁:
class MyReverseProxy < Rack::ReverseProxy
private
def create_response_headers(http_response)
response_headers = super(http_response)
if response_headers
if response_headers["Set-Cookie"].is_a?(Array)
response_headers["Set-Cookie"] = response_headers["Set-Cookie"].join("\n")
end
end
response_headers
end
end
# this is to make /blog show my wordpress blog
use MyReverseProxy do
reverse_proxy_options :preserve_host => false
reverse_proxy(/^\/blog(\/.*)$/, 'http://your-blog-server.com$1')
end