跨域登陆zabbix系统

背景:

最近在做一个运维平台,要从该平台直接可以联入zabbix平台的“事件详情”页面。

考虑过的方法:

1.单点登陆:在多个应用系统中,只需要登录一次,就可以访问其他相互信任的应用系统。(比较复杂工作量也比较大直接否定)。

2.分析zabbix请求时携带的cookie数据,在后台通过zabbixAPI接口获取session_id写入zabbix系统域下的cookie中。

3dd5527def5f89f9dd7cd3498e51f56bb20.jpg

由于跨域写cookie也是比较麻烦,也否定了。

3.在本系统中模拟zabbix登陆,建立zabbix会话。在以后的请求到zabbix页面时可以直接使用该会话进行请求。

要在本系统页面通过ajax登陆zabbix系统,就要解决跨区post提交。

请求路径:http://11.202.16.28/zabbix/index.php?name=admin&password=admin123&autologin=1&enter=Sign+in

在zabbix的index.php中增加

header("Access-Control-Allow-Origin: *");//允许所有地址跨域请求

在本系统首页执行

	//同时进行zabbix登陆,建立会话
	function loginZabbix(){
		$.ajax({
			url:"${zabbixLoginUrl}",
			type:'post',
			// 下面的两行代码,就是解决跨域的关键
			xhrFields: {withCredentials: true},
		    crossDomain: true,
		    //就是上面的两行代码
		    dataType: 'jsonp',
			success:function(data){
			}
		});
	}

经过测试可以满足要求。

转载于:https://my.oschina.net/u/3100849/blog/3055516

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个用于创建独立的、基于生产级别的Java应用程序的开源框架。它通过提供一个简化的开发流程和内置的开箱即用功能,使得构建和部署应用变得更加容易。 在某些情况下,我们可能需要在Spring Boot应用程序中实现跨域单点登录跨域指的是在不同的域之间进行HTTP请求,而单点登录指的是用户只需一次登录即可在多个应用程序中进行身份验证。 要实现跨域单点登录,我们可以使用Spring Security框架。首先,我们需要配置Spring Security来允许跨域请求。 在Spring Boot中,可以通过添加一个配置类来实现跨域请求的允许。在配置类中,我们可以使用`@Configuration`注解将其标记为配置类,并使用`@Bean`注解创建一个`CorsConfigurationSource`的实例。在这个实例中,我们可以设置允许的请求源和支持的HTTP方法。 接下来,我们需要配置Spring Security来使用我们创建的`CorsConfigurationSource`实例。我们可以通过创建另一个配置类,并使用`WebSecurityConfigurerAdapter`来配置Spring Security。在这个配置类中,我们可以使用`configure(HttpSecurity http)`方法来设置需要进行身份验证的URL和允许跨域请求。 一旦配置了允许跨域请求,我们可以使用一种适合我们应用程序的单点登录解决方案,例如使用OAuth 2.0或OpenID Connect。这些解决方案可以帮助我们在不同的域之间实现单点登录,并确保用户只需登录一次即可在多个应用程序中进行身份验证。 总之,通过适当的配置和使用单点登录解决方案,我们可以在Spring Boot应用程序中实现跨域单点登录。这样,用户只需一次登录即可在多个应用程序中进行身份验证,提高了用户体验和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值