【问题标题】:GAE dev_appserver.py over HTTPSHTTPS 上的 GAE dev_appserver.py
【发布时间】:2012-02-09 13:33:30
【问题描述】:

有没有人破解了如何让 HTTPS 在 dev_appserver.py 上工作?我需要它来进行 Facebook 画布应用程序测试。我已经搜索了文档,没有任何迹象表明有办法做到这一点(在 app.yaml 中粘贴“安全”在本地并不是什么都没有)。

我认为可能有一种方法可以代理它,但有人有这方面的经验吗?

【问题讨论】:

    标签: google-app-engine https


    【解决方案1】:

    dev_appserver 不支持 HTTPS。唯一可行的方法是在您的应用程序前面设置一个反向代理 - 例如使用 nginx 或 Apache - 并让它代理 SSL 流量到您的应用程序。

    【讨论】:

    • @AhmedNuaman 这将是一个不同的问题 - 对于 serverfault.com,而不是 Stack Overflow。
    【解决方案2】:

    我知道这已经很晚了,以防其他人发现这个问题:

    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 类来实现其他实用功能。

    【讨论】:

      【解决方案3】:

      我把它放在我的 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

      【讨论】:

        猜你喜欢
        • 2012-02-09
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2013-09-02
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多