【发布时间】:2012-02-09 13:33:30
【问题描述】:
有没有人破解了如何让 HTTPS 在 dev_appserver.py 上工作?我需要它来进行 Facebook 画布应用程序测试。我已经搜索了文档,没有任何迹象表明有办法做到这一点(在 app.yaml 中粘贴“安全”在本地并不是什么都没有)。
我认为可能有一种方法可以代理它,但有人有这方面的经验吗?
【问题讨论】:
有没有人破解了如何让 HTTPS 在 dev_appserver.py 上工作?我需要它来进行 Facebook 画布应用程序测试。我已经搜索了文档,没有任何迹象表明有办法做到这一点(在 app.yaml 中粘贴“安全”在本地并不是什么都没有)。
我认为可能有一种方法可以代理它,但有人有这方面的经验吗?
【问题讨论】:
dev_appserver 不支持 HTTPS。唯一可行的方法是在您的应用程序前面设置一个反向代理 - 例如使用 nginx 或 Apache - 并让它代理 SSL 流量到您的应用程序。
【讨论】:
我知道这已经很晚了,以防其他人发现这个问题:
ngrok 很容易为自定义反向 HTTPS 代理设置..
唯一的缺点是我的 webapp2 应用程序仍然认为它是通过 HTTP 提供的,因此使用 redirect() 效果不佳,因为它使用 request.url 将相对 URL 解析为绝对 URL。
我的解决方法是覆盖RequestHandler.redirect,如下所示:
class BaseRequestHandler(RequestHandler):
def redirect(self, uri, permanent = False, abort = False, code = None, body = None):
if uri.startswith(('.', '/')):
base_url = self.request.url
if base_url.startswith('http://'):
base_url = 'https://' + base_url[7:]
uri = str(urlparse.urljoin(base_url, uri))
super(RequestHandler, self).redirect(uri, permanent, abort, code, body)
无论如何我都需要一个BaseRequestHandler 类来实现其他实用功能。
【讨论】:
我把它放在我的 Appache httpd.conf 中来代理连接:
<Location /myproject/>
ProxyPass http://localhost:8080/
</Location>
现在可以在我的浏览器中访问https://localhost/myproject/。
注意:需要在您的 Apache 服务器上启用 SSL。在我的 OS X 机器上,我取消注释 /etc/apache2/httpd.conf 中的 Include /private/etc/apache2/extra/httpd-ssl.conf 行并运行 sudo apachectl restart
【讨论】: