在 HTTPS 上使用重定向的 JSF 导航规则问题

Issues with JSF navigation rules using redirect on HTTPS(在 HTTPS 上使用重定向的 JSF 导航规则问题)
本文介绍了在 HTTPS 上使用重定向的 JSF 导航规则问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

在导航规则上使用 <redirect/> 时遇到问题.我的应用程序在 HTTPS 上运行,当导航规则使用 <redirect/> 时,重定向将执行到 HTTP,而不是 HTTPS.有没有办法解决这个问题?

I'm having issues when using <redirect/> on navigation rules. My application works on HTTPS and when a navigation rule uses <redirect/> the redirect is done to HTTP, not HTTPS. Is there any way to solve this?

推荐答案

你应该实现一个自定义 ConfigurableNavigationHandler 将根据操作源重新映射 URL(我在这里假设并非所有重定向都是到 https 目的地).举个例子:

You should implement a custom ConfigurableNavigationHandler that will remap the URL based on the source of the action (I'm assuming here that not all your redirects are to https destinations). As an example:

 public class NavigationHandlerTest extends ConfigurableNavigationHandler {

 private NavigationHandlerTest concreteHandler;

 public NavigationHandlerTest(NavigationHandler concreteHandler) {
      this.concreteHandler = concreteHandler;
 }


 @Override
 public void handleNavigation(FacesContext context, String fromAction, String outcome) 
 {
    //here, check where navigation is going to/coming from and based on that build an appropriate URL.
     if(outcome.equals("someAction"){
        outcome = "https://foo.bar.baz"; //set destination url
          }


     concreteHandler.handleNavigation(context, fromAction, outcome);   

 }


   } 

faces-config.xml

     <application>
        <navigation-handler>com.example.NavigationHandlerTest</navigation-handler>
     </application> 

这篇关于在 HTTPS 上使用重定向的 JSF 导航规则问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Reliable implementation of PBKDF2-HMAC-SHA256 for JAVA(PBKDF2-HMAC-SHA256 for JAVA 的可靠实现)
Correct way to sign and verify signature using bouncycastle(使用 bouncycastle 签名和验证签名的正确方法)
Creating RSA Public Key From String(从字符串创建 RSA 公钥)
Why java.security.NoSuchProviderException No such provider: BC?(为什么 java.security.NoSuchProviderException 没有这样的提供者:BC?)
Generating X509 Certificate using Bouncy Castle Java(使用 Bouncy Castle Java 生成 X509 证书)
How can I get a PublicKey object from EC public key bytes?(如何从 EC 公钥字节中获取 PublicKey 对象?)