zatree插件优化:支持HTTP Basic Authorization认证访问zabbix API

简介:

zatree是监控软件zabbix的一个插件,主要功能是提供host group的树形展示和在item里指定关键字查询及数据排序。

zatree项目地址https://github.com/spide4k/zatree,安装方法进到不同版本目录看readme

   最近遇到一个问题,当zabbixweb端使用了http基本认证方式的时候,zatree插件不能正常调用zabbixapi,导致报错。

查看错误信息方法:打开php的显示错误,

# vi /etc/php.ini

1
display_errors = On

    重启web server

wKiom1PRzTaATc6qAAChzbh5j_U802.jpg

    点击Zatree按钮,就会在页面上看到错误信息。

wKioL1PRzl-C51W6AAL4xe5OUp4649.jpg


    解决方法如下,这里针对zatreezabbix-2.2.x版本做修改,方法同样适合zabbix-2.0.x版本。

    进入zatree目录,修改以下四个文件:

    步骤一、修改zabbix_config.php

添加HTTP Basic Authorization认证用户名和密码参数。如果没有设置HTTP Basic Authorization认证,http_userhttp_password的值为空就行。

1
2
3
4
5
6
7
8
9
10
11
12
13
<?php 
global  $zabbix_api_config ;
 
$zabbix_api_config = array (
  'api_url' => 'api_jsonrpc.php' ,
  'http_user' => 'xxxxx' ,
  'http_password' => 'xxxxx' ,
  'user' => 'Admin' ,
  'passowrd' => 'xxxxx' ,
  'graph_url' => 'zabbix_chart.php' ,
);
 
?>

    步骤二、修改zabbix_ajax.php33行,添加当有HTTP认证时的$url_http

1
         $url_http  = dirname(dirname( 'http://'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));

修改为:

1
2
3
4
5
         if  (! empty ( $zabbix_api_config [ 'http_user' ]) && ! empty ( $zabbix_api_config [ 'http_password' ])) {
                 $url_http  = dirname(dirname( 'http://'  . trim( $zabbix_api_config [ 'http_user' ]) .  ':'  . trim( $zabbix_api_config [ 'http_password' ]) .  '@'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));
         else  {
                 $url_http  = dirname(dirname( 'http://'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));
         }


    步骤三、修改graph.php第141行,添加当有HTTP认证时的$url_http

1
         $url_http  = dirname(dirname( 'http://'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));

修改为:

1
2
3
4
5
         if  (! empty ( $zabbix_api_config [ 'http_user' ]) && ! empty ( $zabbix_api_config [ 'http_password' ])) {
                 $url_http  = dirname(dirname( 'http://'  . trim( $zabbix_api_config [ 'http_user' ]) .  ':'  . trim( $zabbix_api_config [ 'http_password' ]) .  '@'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));
         else  {
                 $url_http  = dirname(dirname( 'http://'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));
         }


    步骤四、修改big_graph.php第88行,添加当有HTTP认证时的$url_http

1
         $url_http  = dirname(dirname( 'http://'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));

修改为:

1
2
3
4
5
         if  (! empty ( $zabbix_api_config [ 'http_user' ]) && ! empty ( $zabbix_api_config [ 'http_password' ])) {
                 $url_http  = dirname(dirname( 'http://'  . trim( $zabbix_api_config [ 'http_user' ]) .  ':'  . trim( $zabbix_api_config [ 'http_password' ]) .  '@'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));
         else  {
                 $url_http  = dirname(dirname( 'http://'  $_SERVER [ 'HTTP_HOST' ] .  $_SERVER [ "REQUEST_URI" ]));
         }

链接地址:https://github.com/spide4k/zatree/pull/2

本文转自 张斌_青岛 51CTO博客,原文链接:http://blog.51cto.com/qicheng0211/1530018


相关文章
|
3月前
|
自然语言处理 数据可视化 API
淘宝商品评论 API 接口:深度解析用户评论,优化产品与服务
淘宝是领先的中国电商平台,其API为开发者提供商品信息、交易记录及用户评价等数据访问服务。对于获授权的开发者和商家,可通过申请API权限、获取并解析评论数据来进行情感分析和统计,进而优化产品设计、提升服务质量、增强用户互动及调整营销策略。未授权用户可能受限于数据访问。
|
7天前
|
安全 网络协议 应用服务中间件
内网ip申请SSL证书实现https访问
内网IP地址虽不能直接申请公网SSL证书,但可通过IP SSL证书保障数据安全。流程包括:确定固定内网IP,选择支持内网IP的CA,注册申请证书,生成CSR,验证IP所有权,下载部署证书至Web服务器,测试HTTPS访问,确保配置正确及证书有效。此方法适用于内网环境,提升数据传输安全性。
内网ip申请SSL证书实现https访问
|
4天前
|
前端开发 JavaScript API
探究 React Hooks:如何利用全新 API 优化组件逻辑复用与状态管理
本文深入探讨React Hooks的使用方法,通过全新API优化组件逻辑复用和状态管理,提升开发效率和代码可维护性。
|
16天前
|
JSON 监控 JavaScript
Node.js-API 限流与日志优化
Node.js-API 限流与日志优化
|
16天前
|
Web App开发 算法 应用服务中间件
nginx开启局域网https访问
【10月更文挑战第22天】为了调试WebRTC功能,需要在局域网内搭建HTTPS协议。具体步骤包括:在已部署Nginx和安装OpenSSL的环境中生成私钥、证书签名请求和自签名证书;将生成的文件放置到Nginx的证书目录并修改Nginx配置文件,最后重启Nginx服务。注意,自签名证书不受第三方机构认可,如需正式使用,需向CA申请签名。
|
19天前
|
安全 网络安全 数据安全/隐私保护
政务内网实现https访问教程
政务内网实现HTTPS访问需经过多个步骤:了解HTTPS原理,选择并申请适合的SSL证书,配置SSL证书至服务器,设置端口映射与访问控制,测试验证HTTPS访问功能,注意证书安全性和兼容性,定期备份与恢复。这些措施确保了数据传输的安全性,提升了政务服务的效率与安全性。
|
15天前
|
安全 网络安全 数据安全/隐私保护
内网IP地址实现HTTPS加密访问教程
在内网环境中,为确保数据传输的安全性,绑定SSL证书搭建HTTPS服务器至关重要。本文介绍了内网IP地址的前期准备、申请SSL证书的步骤以及客户端配置方法。具体包括选择合适的CA、注册账号、提交申请、下载证书,并在客户端导入根证书,确保通信数据的安全加密。推荐使用JoySSL提供的技术解决方案,确保内网设备通信安全。
内网IP地址实现HTTPS加密访问教程
|
1月前
|
存储 网络安全 对象存储
缺乏中间证书导致通过HTTPS协议访问OSS异常
【10月更文挑战第4天】缺乏中间证书导致通过HTTPS协议访问OSS异常
88 4
|
1月前
|
安全 测试技术 API
优化 API 生命周期的 5 个关键领域
您是否曾遇到过令人沮丧的 API 文档?或为版本控制问题而苦恼?或为集成难题而苦恼?这些只是困扰 API 开发领域的一些常见挑战。
|
1月前
|
存储 缓存 安全
https访问提示不安全,证书密钥验证上如何解决
【10月更文挑战第4天】访问提示不安全,证书密钥验证上如何解决
288 2

热门文章

最新文章

推荐镜像

更多
下一篇
无影云桌面