Enforce SSL on Play! Framework

2020-05-22 07:37发布

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 asynchronously. Does anyone that's worked with Play! have a straightforward method of enforcing SSL? Not sure if I need to create redirects or if this can be solved quickly in a conf file.

2条回答
狗以群分
2楼-- · 2020-05-22 08:09

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

查看更多
爱情/是我丢掉的垃圾
3楼-- · 2020-05-22 08:13

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.

查看更多
登录 后发表回答