AWS 弹性负载均衡器未将 HTTP Headers 转发到 EC2 实例
AWS Elastic Load Balancer not Forwarding HTTP Headers to EC2 Instance
我目前是 运行 Amazon Elastic Beanstalk 上的 Python Flask 应用程序。当我测试应用程序时,它在本地一切正常(我使用 Postman 发送 GET & POST 请求)。但是,在 AWS 上,它不起作用,因为到达我的 EC2 实例(在负载均衡器后面)的请求不包括 Authorization header。负载平衡器似乎剥离了 header。我这里有什么地方做错了吗?
这是我在本地和在 Elastic Beanstalk 上打印 header 时得到的结果的比较。
本地
[2017-07-04 13:18:14,650] [INFO] [common.decorators] Headers = Host: localhost:5000
Connection: keep-alive
Content-Length: 151
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36
Cache-Control: no-cache
Origin: chrome-extension://fhbjgbiflinjbdggehcddcbncdddomop
Content-Type: application/json
Authorization: Bearer ad9fd4d9-6ce6-497b-855a-dcebebdad65b
Postman-Token: xxxxx
Accept: */*
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.8
橡皮豆:
[2017-07-04 17:27:03,813] [DEBUG] [common.decorators] Headers = Accept-Language: en-US,en;q=0.8
Accept: */*
Host: dev.onetext.com
X-Forwarded-For: 66.30.13.108
Content-Type: application/json
Postman-Token: xxxxx
Connection: keep-alive
Accept-Encoding: gzip, deflate, sdch, br
X-Forwarded-Proto: https
Cache-Control: no-cache
X-Forwarded-Port: 443
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36
感谢@notionquest 的评论,我在https://forums.aws.amazon.com/thread.jspa?messageID=729128
找到了解决方案
我通过在 .ebextensions 文件夹下添加一个包含以下内容的新文件解决了这个问题:
files:
"/etc/httpd/conf.d/wsgihacks.conf":
mode: "000644"
owner: root
group: root
content: |
WSGIPassAuthorization On
AWS 不接受标头中的 unsercores (_),而我们可以使用 (-),因此删除 下划线 来自 header 变量,例如:-
header_var_val = "some value"
将其替换为
headervarval = "some value"
对我有用
我目前是 运行 Amazon Elastic Beanstalk 上的 Python Flask 应用程序。当我测试应用程序时,它在本地一切正常(我使用 Postman 发送 GET & POST 请求)。但是,在 AWS 上,它不起作用,因为到达我的 EC2 实例(在负载均衡器后面)的请求不包括 Authorization header。负载平衡器似乎剥离了 header。我这里有什么地方做错了吗?
这是我在本地和在 Elastic Beanstalk 上打印 header 时得到的结果的比较。
本地
[2017-07-04 13:18:14,650] [INFO] [common.decorators] Headers = Host: localhost:5000
Connection: keep-alive
Content-Length: 151
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36
Cache-Control: no-cache
Origin: chrome-extension://fhbjgbiflinjbdggehcddcbncdddomop
Content-Type: application/json
Authorization: Bearer ad9fd4d9-6ce6-497b-855a-dcebebdad65b
Postman-Token: xxxxx
Accept: */*
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.8
橡皮豆:
[2017-07-04 17:27:03,813] [DEBUG] [common.decorators] Headers = Accept-Language: en-US,en;q=0.8
Accept: */*
Host: dev.onetext.com
X-Forwarded-For: 66.30.13.108
Content-Type: application/json
Postman-Token: xxxxx
Connection: keep-alive
Accept-Encoding: gzip, deflate, sdch, br
X-Forwarded-Proto: https
Cache-Control: no-cache
X-Forwarded-Port: 443
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36
感谢@notionquest 的评论,我在https://forums.aws.amazon.com/thread.jspa?messageID=729128
找到了解决方案我通过在 .ebextensions 文件夹下添加一个包含以下内容的新文件解决了这个问题:
files:
"/etc/httpd/conf.d/wsgihacks.conf":
mode: "000644"
owner: root
group: root
content: |
WSGIPassAuthorization On
AWS 不接受标头中的 unsercores (_),而我们可以使用 (-),因此删除 下划线 来自 header 变量,例如:- header_var_val = "some value" 将其替换为
headervarval = "some value"
对我有用