- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 HTML5/JQuery cordova 混合应用程序,它与外部 REST Web 服务通信以获取页面动态内容的数据。这些 REST 资源受 Siteminder SSO 保护。对 Web 服务的所有调用都会被 siteminder 拦截,如果 session 未处于事件状态,则会弹出 siteminder 登录质询页面。
我们如何处理移动应用中的 siteminder 登录页面?
目前,我们有index.html,在onload上,页面(index.html)被提交并访问 protected REST服务,但siteminder拦截并抛出质询页面。身份验证后,它可以访问 protected REST 服务,并从 REST 服务返回“成功”的 json 结果。
基于此,我们需要在siteminder cookie上从移动passign调用其他页面/REST服务来进行 session 验证。实现这一目标的正确方法是什么?
最佳答案
最后我能够通过以下方法让它工作:
所有 REST 资源 URL 都必须受 siteminder 保护。
定义一个 GET 服务,该服务也是 protected 资源,将用于启动 siteminder session 。例如
@Context private HttpServletRequest httpRequest;
@GET
@Path("/OAMSSO")
@Produces(MediaType.APPLICATION_JSON)
public Response getOAMSSO() {
URI uri = null; UriBuilder uriBuilder = null;
String redirectHost = "https://localhost/callback";
uri = uriBuilder.queryParam("statusCode", "100")
.queryParam("authenticated", "true")
.queryParam("userName",
headers.getHeaderString("SM_USER")).build();
return Response.seeOther(uri).build();
}
在您的 JS 中,以下代码将在 InAppBrowser 中启动 siteminder SSO 身份验证。 InAppBrowser 是一个 Cordova 插件,需要添加到您的项目中。
cordova 插件添加 cordova-plugin-inappbrowser
function getParameterByName(url, name) {
var match = RegExp('[?&]' + name + '=([^&]*)').exec(url);
return match && decodeURIComponent(match[1].replace(/\+/g, ' '));
}
document.addEventListener("deviceReady", "onDeviceReady",false);
function onDeviceReady() {
callOAMSSO();
}
function callOAMSSO() {
var url = **<<yourProtectedServiceURL>>**/OAMSSO";
var target = '_blank';
var options = "location=yes,toolbar=yes,clearcache=yes,clearsessioncache,enableViewportScale=yes";
var redirectURL = "https://localhost/callback";
var ref = cordova.InAppBrowser.open(url, target, options);
ref.addEventListener('loadstart', loadstartCallback);
ref.addEventListener('exit', exitCallback);
function loadstartCallback(event) {
var url = event.url;
if(url.indexOf(redirectURL) > -1){
ref.close();
var statusCode = getParameterByName(url, 'statusCode');
var authenticated = getParameterByName(url, 'authenticated');
var userName = getParameterByName(url, 'userName');
if(statusCode && userName){
sessionStorage.userName = userName.toUpperCase();
sessionStorage.userNameisValid = "Y";
setTimeout(**invokeYourFunctionForOtherTasks**, 10);
}
}
}
function exitCallback() {
alert('Browser is closed...');
}
}
当您的应用程序打开时,InAppBrowser 将打开,并尝试获取 OAMSSO protected 资源。由于受站点管理器保护并且没有可用 session ,SSO 页面会在浏览器中打开,用户可以在其中输入凭据并提交。如果凭据成功,siteminder 将添加 SMSESSION cookie,然后重定向到 OAMSSO REST 资源。 OAMSSO REST 资源提取经过身份验证的站点管理器用户名,并将其作为查询参数附加到回调方法,即重定向到 localhost/callback。这只是一个虚拟 URL,用于标识用户已通过 siteminder 进行身份验证。在 JS 中,您可以检查此 URL 加载,提取用户名,然后继续执行应用程序的其他任务。由于 siteminder session 已处于事件状态,因此您可以从应用程序访问 REST 服务的其他 protected 资源。
希望这可以帮助任何通过 Javascript 处理 siteminder SSO 身份验证的人。
关于jquery - Cordova 混合应用程序与 Siteminder protected REST 资源集成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39078951/
Windows 集成 (NTLM) 身份验证和 Windows 集成 (Kerberos) 之间有什么区别? 如何在IIS6中实现这些 w.r.t. MSDN 最佳答案 Kerberos 和 NTLM
Keycloak是一个用 Java 编写的开源身份验证和身份管理解决方案。它提供了一个nodejs适配器,使用它我能够成功地与express集成。这是有效的路由文件: 'use strict'
这是我关于 Bamboo 的第二个问题 ( My First One )。阅读建议信息后我的理解是,我需要一个构建工具,例如 nAnt 或 MSbuild 来编写一个获取源代码并构建它的脚本(我正在开
可用于将第三方应用程序与 jira 4.3 集成的身份验证方案有哪些?显然,从客户那里获取用户名和密码听起来很荒谬。另外,我知道 oauth 身份验证仅适用于版本 5。请告诉我。谢谢。 附注。我不是在
我有一个使用 DDS 的旧版 C++ 应用程序用于异步通信/消息传递。我需要将此应用程序集成到使用 JMS 进行消息传递的 JavaEE 环境中。除了构建独立的 JMS/DDS 桥接模块之外,我还有其
我正在尝试使用 Whatsapp 发送测试消息,但收到此错误消息: "error":{"code":27,"description":"Recipient not available on chann
我想将 photologue 与我的 Django 应用程序集成,并使用它在车辆库存中显示照片......有点像 Boost Motor Group Inc. 提供的内容。我已经集成了该应用程序,所以
我目前正在尝试弄清楚如何与 fujitsu scansnap 扫描仪集成,但没有从 fujitsu 找到有关 fujitsu scansnap 管理器如何调用您的应用程序并将文件发送到您的应用程序的详
在我的项目中,我使用了 9 个(九个)int-ip:udp-inbound-channel-adapter 和一个 jms:inbound-channel-adapter。 Jms 适配器从服务器接收
在我们当前的原型(prototype)中,大多数标准 HTML 控件都被小程序取代,最重要的是表单提交由小程序触发。 有没有一种方法可以像 一样在服务器端调用关联的操作 ? 本文Applet and
是否可以使用 twilio 号码从 whatsapp 发送/接收短信?有人用whatsapp试过twilio吗?我问过客服,如果可能的话,他说,不确定,但很多人都问过这个问题。 最佳答案 万一其他人来
我们办公室中几乎不存在版本控制,这显然导致了很多麻烦。我们想使用SVN和Notepad++进行设置...任何人都对如何实现此目标有任何想法?我已经开始研究并浏览了这个网站: http://www.sw
曾经有提供这种集成的 spring-modules 项目;但是,该项目现已弃用。现在有没有人继续支持这种集成?谢谢。 最佳答案 工作正在进行中。 http://blog.athico.com/sear
我的理解是,根据 http://wiki.dbpedia.org/Datasets,DBpedia 从 YAGO 获取类层次结构,而不是实体。 .但是,类似 http://dbpedia.org/cl
任何人都可以帮助我如何将 OpenCMS 与 Java Spring Web 应用程序集成。已经用谷歌搜索并浏览了很多网站但没有用。所以,请帮助我。 最佳答案 我认为将 SpringMVC 与 Ope
我正在尝试使用新的 migs getaway (MPGS) 我遵循了下一个 url 中的代码 https://ap-gateway.mastercard.com/api/documentation/i
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
我有一个 cmake 项目。我想轻松完成以下操作 搜索光标下任何变量、函数等的声明、定义和引用,这些可能在外部头文件中声明,其路径是在CMakeLists.txt中使用INCLUDE_DIRECTOR
有人能给我指点一下 Objective-C(或 c/c++)库的方向,或者教通过 FTP 上传或下载的教程(Objective-C)吗?最好能展示如何将文件下载到临时目录,然后稍后上传?我不介意针对
集成()给出了非常错误的答案: integrate(function (x) dnorm(x, -5, 0.07), -Inf, Inf, subdivisions = 10000L) # 2.127
我是一名优秀的程序员,十分优秀!