Enforce SSL on Play! Framework

后端 未结 2 1322
失恋的感觉
失恋的感觉 2021-02-04 01:52

I\'m currently using Play! 1.2.2 and its new Netty client framework.

I haven\'t found a straightforward method to enforce SSL, although can get HTTP and HTTPS to serve a

相关标签:
2条回答
  • 2021-02-04 02:14

    There are a couple of ways to enforce SSL.

    Firstly, you can set all your actions to use the .secure() method, for example

    <a href="@{Application.index.secure()}">index page</a>
    

    Alternatively, and probably the best way, is to do this via a frontend HTTP server, such as Apache, Nginx or Lighttpd.

    The idea of the frontend http server, is that your application runs on port 9000, but is not accessible from the outside network. HTTP is responsible for all incoming requests, and is configured to only accept HTTPS. The HTTPS is handled by the HTTP server, and the request is then forwarded on to Play.

    This leaves your entire Play application to work as normal, and the SSL is offloaded to another application.

    This same method can be applied to a load balancer, rather than HTTP server, but I am guessing the majority of people will go with the far cheaper alternative of a HTTP server, unless running in a corporate environment.

    0 讨论(0)
  • 2021-02-04 02:16

    In the controller you can check against request.secure and either do a redirect or return 403/access denied.

    You can force SSL for a whole controller doing this:

    public static class ForceSSL extends Controller
    {
        @Before
        static void verifySSL()
        {
            if (request.secure == false)
                redirect("https://" + request.host + request.url); 
        }
    }
    

    ... and annotate another controller:

    @With(ForceSSL.class)
    public class Foo extends Controller
    {
    ....
    }
    

    See also http://groups.google.com/group/play-framework/browse_thread/thread/7b9aa36be85d0f7b

    0 讨论(0)
提交回复
热议问题