heroku godaddy域java堆栈SSL设置

heroku godaddy域java堆栈SSL设置,java,ssl,heroku,cedar,Java,Ssl,Heroku,Cedar,我正在尝试为我的heroku java应用程序设置SSL。我已经在secure.mydomain.com上安装了SSL。如果我这样做,一切都很好。但是, 1如何将所有http通信转发到https?有人可以共享示例代码来执行此操作吗?i、 如果我去,它会把我转到 2我只有secure.mydomain.com的证书。我可以在godaddy为www.mydomain.com设置CNAME,将我的所有流量转发到 简而言之,我想将所有请求转发到mydomain.com、www.mydomain.com和

我正在尝试为我的heroku java应用程序设置SSL。我已经在secure.mydomain.com上安装了SSL。如果我这样做,一切都很好。但是,

1如何将所有http通信转发到https?有人可以共享示例代码来执行此操作吗?i、 如果我去,它会把我转到

2我只有secure.mydomain.com的证书。我可以在godaddy为www.mydomain.com设置CNAME,将我的所有流量转发到

简而言之,我想将所有请求转发到mydomain.com、www.mydomain.com和secure.mydomain.com


提前感谢。

我相信这段代码可以稍微整理一下,它可能会错过一些特殊情况,但这里有一个通用servlet过滤器,它将所有http流量重定向到https:

通过在web.xml中插入以下内容将其添加到应用程序:


您使用的是什么框架?嵌入式码头?Spring MVC编译为WAR+Tomcat/Jetty runner?其他?杰斯珀也是。Heroku没有提供这样做的设施。您需要在应用程序级别执行此操作。因此,解决方案取决于您使用的框架。。
import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class SecureFilter implements Filter {

    public void init(FilterConfig arg0) throws ServletException {}
    public void destroy() {}

    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) 
            throws IOException, ServletException {

        HttpServletRequest hr = (HttpServletRequest) req;
        HttpServletResponse hs = (HttpServletResponse) res;

        if(req.isSecure() || 
            (hr.getHeader("X-Forwarded-Proto")!=null && 
             hr.getHeader("X-Forwarded-Proto").equals("https"))) {
            chain.doFilter(req,res);
        } else {
            hs.sendRedirect("https://"+
                            hr.getHeader("Host")+
                            hr.getRequestURI()+
                            (hr.getQueryString()!=null? "?"+hr.getQueryString():""));
        }
    }
}
<filter>
    <filter-name>SecureFilter</filter-name>
    <filter-class>SecureFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>SecureFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>