在导航规则上使用 <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 导航规则问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
Java从数组中删除重复项?Java Remove Duplicates from an Array?(Java从数组中删除重复项?)
如何修复调用失败来自服务器的意外响应:在 AnHow to fix Invocation failed Unexpected Response from Server: Unauthorized in Android studio(如何修复调用失败来自服务器的意外响应:在
AES 加密,解密文件中有多余的垃圾字符AES encryption, got extra trash characters in decrypted file(AES 加密,解密文件中有多余的垃圾字符)
AES 错误:给定的最终块未正确填充AES Error: Given final block not properly padded(AES 错误:给定的最终块未正确填充)
在 JAVA 中使用 AES/GCM 检测不正确的密钥Detecting incorrect key using AES/GCM in JAVA(在 JAVA 中使用 AES/GCM 检测不正确的密钥)
Java 中的 AES-256-CBCAES-256-CBC in Java(Java 中的 AES-256-CBC)