【转载】PHP调用kangle的API

        根据管理的API公布写了一个类封装了一个操作集合,这是一个kangleAPI的一个封装吧,是在其他地方看到的,接口包含获取easypanel的信息(包括了kangle的信息)、获取站点信息、创建kangle站点、修改指定kangle站点信息、获取kangle站点列表、修改指定kangle站点密码、修改指定kangle站点状态、删除指定kangle站点、获取指定kangle站点的数据库使用量。功能很强大,像EP分销这些都是利用的kangle接口开发的,你还可以开发其他的产品,需要的直接带走。代码中包含作者版权,未修改。


调用页示例:

<?php
//引入类
include_once('kangle_init.class.php');
//初始化
//$kangle = new kangle_init('IP或域名(默认127.0.0.1)','端口(默认3312)','秘钥(默认test)','协议(http/https,默认http)');
$kangle = new kangle_init('127.0.0.1','3312','asfsvsvsyYD6Y6ue','http');
//调用方法示例,具体请参照类文件,有详细的代码注释说明
$kangle->update_vh('test',0)

封装的函数:

<?php
class kangle_init{
    /*
     * 配置需求:PHP >= 5.2.0
     * by:  千里溃
     * 参照出处: https://www.kanglesoft.com/thread-44506-1-1.html
     * c : (control)表示哪个控制文件(目前有whm,cdn)
     * a : (action)表示哪个方法,以下介绍
     * r : 随机数
     * s : 秘钥,通过md5(a + skey +r)得到,如a=add,skey=test,r=888,则s=md5(addtest888)
     * 其中skey是服务器安全码
     * 所有返回成功都报[result] => 200
     * 不成功报[result] => 500 或者 新建(修改)站点时 product_id 和 product_name 都存在参数时报 [result] => 505
     */
    public $protocol ;
    public $ip;
    public $port;
    public $r;
    public $skey;
    public function __construct($ip = '127.0.0.1',$port = '3312',$skey = 'test',$protocol = 'http')
    {
        $this->protocol = $protocol; //仅支持http和https
        $this->ip = $ip;
        $this->port = $port;
        $this->r = rand(100000,999999);
        $this->skey = $skey;
    }
    public function __destruct()
    {
        // TODO: Implement __destruct() method.
    }
    public function url($info=array()){
        $url = '';
        foreach ($info as $k=>$v){
            $url .= $k.'='.$v.'&';
        }
        return $this->protocol.'://'.$this->ip.':'.$this->port.'/api/index.php?'.$url.'r='.$this->r.'&s='.md5($info['a'].$this->skey.$this->r).'&json=1';
    }
    public function open($info=array()){
        $url = $this->url($info);
        if(function_exists('curl_init')){
            $ch = curl_init();
            curl_setopt($ch, CURLOPT_URL, $url);
            curl_setopt($ch, CURLOPT_TIMEOUT, 5);
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
            if ($this->protocol == 'https' or $this->protocol == 'HTTPS'){
                curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查
                curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, true);  // 从证书中检查SSL加密算法是否存在
            }
            $r = curl_exec($ch);
            curl_close($ch);
            return json_decode($r,true);
        }else{
            return json_decode(file_get_contents($url),true);
        }
    }
    //获取easypanel的信息(包括了kangle的信息)
    public function info(){
        /*
         * c : whm
         * a : info
         * 调用成功后你将得到如下返回数据:
         * {"result":200,"server":[{"0":"kangle"}],"version":[{"0":"3.4.8"}],"type":[{"0":"enterprise"}],"os":[{"0":"windows"}],"license_id":[{"0":"73646_1387957818"}],"license_name":[{"0":"dsdds"}],"total_run":[{"0":"611038"}],"connect":[{"0":"4"}],"request":[{"0":"14105"}],"accept":[{"0":"4722"}],"vh":[{"0":"43"}],"kangle_home":[{"0":"D:\easypanel\"}],"update_code":[{"0":"win_x64"}],"easypanel_version":"2.6.17"}
         * 其中result=200表示调用成功。
         * version是kangle的版本
         * type是kangle的商业版还是免费版(enterprise  or free)
         * total_run 是运行时间
         * vh 是虚拟主机数量
         * connect是当前有多少请求进来。
         *
         */
        return $this->open(array('c'=>'whm','a'=>'info'));
    }
    //获取站点信息
    public function getvh($name = null){
        /*
         * c : whm
         * a : getVh
         * name : (虚拟主机名称)
         *
         * 返回的虚拟主机的参数说明
         * name : 主机名称
         * doc_root:主机的主目录
         * uid:系统生成(用户在服务器上的账户ID),权限控制使用。不可更改。
         * gid :系统账户组ID
         * module:是属于哪个模块,目前有php和iis两个模块。
         * templete,subtemplete,已废弃
         * create_time :创建时间
         * expire_time2 :过期时间
         * status:站点状态,0正常,1为关闭。
         * subdir_flag 是否允许子域名,1为允许,0为不允许
         * subdir 默认子目录名称
         * web_quota 空间大小
         * db_quota 数据库大小
         * domain :允许绑定域名数量 -1为不限
         * max_connect 最多连接数
         * max_worker 最多工作者
         * ftp : 是否开通ftp,1为开通,0为不开通
         * db_name 数据库名称(一般和主机名称等同,sql server 特殊)
         */
        return $this->open(array('c'=>'whm','a'=>'getVh','name'=>$name));
    }
    //创建站点
    public function add_vh($info = array()){
        /*
         * 固定值:
         * c : whm
         * a : add_vh
         * r : 随机
         * s : 秘钥
         * init : 1  //表示创建
         * name:网站账号,数据库账号,ftp账号同步
         * passwd:网站密码,数据库密码,ftp密码同步(只创建时同步)
         * product_id 和 product_name 都存在参数时报 [result] => 505,product_id 和 product_name 只能存在一个或者 一个都不存在,当一个都不存在时 详细配置虚拟主机参数
         */
        if(trim(intval($info['product_id'])) != null and trim($info['product_name']) != null){
            return array('result'=>'505');
        }elseif(trim(intval($info['product_id'])) != null){
            return $this->open(array('c'=>'whm','a'=>'add_vh','init'=>1,'name'=>$info['name'],'passwd'=>$info['passwd'],'product_id'=>$info['product_id']));
        }elseif (trim($info['product_name']) != null){
            return $this->open(array('c'=>'whm','a'=>'add_vh','init'=>1,'name'=>$info['name'],'passwd'=>$info['passwd'],'product_id'=>$info['product_name']));
        }else{
            /*
             * 详细配置模式下的传入值列表
             * cdn:是否为CDN空间,是则发送1
             * Templete:语言(html|php|iis)
             * Subtemplete:语言引擎,php52|php53|php5217
             * web_quota:网页空间大小,数字
             * db_quota:数据库大小,数字
             * db_type:数据库类型,mysql|sqlsrv
             * subdir_flag:是否允许绑定子目录,1为是
             * Subdir:默认绑定目录,可为空,例:wwwroot
             * max_subdir:最多子目录数
             * domain:需要绑定的域名,可空,默认会绑定到subdir指 定的目录下。
             * ftp:是否开启ftp,1为是
             * ftp_connect:ftp最多连接数
             * ftp_usl:ftp上传速度限制,单位kb
             * ftp_dsl:ftp下载限制。单位kb
             * access:是否启用自定义控制,如果是请输入自定义控制文件名access.xml
             * speed_limit:带宽限制,数字型,默认为不限(kb)
             * log_handle:是否开启日志析分功能,1为是
             * flow_limit:流量限制,数字型,默认不限(kb)
             */
            $info=array('c'=>'whm','a'=>'add_vh','init'=>1,'name'=>$info['name'],'passwd'=>$info['passwd']);
            return $this->open($info);
        }
    }
    //修改站点信息
    public function edit_vh($info = array()){
        /*
         * 固定值:
         * c : whm
         * a : add_vh
         * r : 随机
         * s : 秘钥
         * edit : 1  //表示修改
         * name:网站账号,数据库账号,ftp账号同步
         * passwd:网站密码,数据库密码,ftp密码同步(只创建时同步)
         *  product_id 和 product_name 都存在参数时报 [result] => 505,product_id 和 product_name 只能存在一个或者 一个都不存在,当一个都不存在时 详细配置虚拟主机参数
         */
        if(trim(intval($info['product_id'])) != null and trim($info['product_name']) != null){
            return array('result'=>'505');
        }elseif(trim(intval($info['product_id'])) != null){
            return $this->open(array('c'=>'whm','a'=>'add_vh','edit'=>'1','name'=>$info['name'],'passwd'=>$info['passwd'],'product_id'=>$info['product_id']));
        }elseif (trim($info['product_name']) != null){
            return $this->open(array('c'=>'whm','a'=>'add_vh','edit'=>'1','name'=>$info['name'],'passwd'=>$info['passwd'],'product_id'=>$info['product_name']));
        }else{
            /*
             * 详细配置模式下的传入值列表
             * cdn:是否为CDN空间,是则发送1
             * Templete:语言(html|php|iis)
             * Subtemplete:语言引擎,php52|php53|php5217
             * web_quota:网页空间大小,数字
             * db_quota:数据库大小,数字
             * db_type:数据库类型,mysql|sqlsrv
             * subdir_flag:是否允许绑定子目录,1为是
             * Subdir:默认绑定目录,可为空,例:wwwroot
             * max_subdir:最多子目录数
             * domain:需要绑定的域名,可空,默认会绑定到subdir指 定的目录下。
             * ftp:是否开启ftp,1为是
             * ftp_connect:ftp最多连接数
             * ftp_usl:ftp上传速度限制,单位kb
             * ftp_dsl:ftp下载限制。单位kb
             * access:是否启用自定义控制,如果是请输入自定义控制文件名access.xml
             * speed_limit:带宽限制,数字型,默认为不限(kb)
             * log_handle:是否开启日志析分功能,1为是
             * flow_limit:流量限制,数字型,默认不限(kb)
             */
            $info=array('c'=>'whm','a'=>'add_vh','edit'=>'1','name'=>$info['name'],'passwd'=>$info['passwd']);
            return $this->open($info);
        }
    }
    //获取站点列表
    public function listvh(){
        /*
         * a : whm
         * c : listVh
         */
        return $this->open(array('c'=>'whm','a'=>'listVh'));
    }
    //修改站点密码
    public function change_password($name,$passwd){
        /*
         * c :whm
         * a : change_password
         * name :站点名称
         * passwd :新的密码
         */
        return $this->open(array('c'=>'whm','a'=>'change_password','name'=>$name,'passwd'=>$passwd));
    }
    //修改站点状态
    public function update_vh($name,$status){
        /*
         * c :whm
         * a : update_vh
         * name :站点名称
         * status : 新状态(0正常,1关闭)
         */
        return $this->open(array('c'=>'whm','a'=>'update_vh','name'=>$name,'status'=>$status));
    }
    //删除站点
    public function del_vh($name){
        /*
         * c :whm
         * a : del_vh
         * name :站点名称
         */
        return $this->open(array('c'=>'whm','a'=>'del_vh','name'=>$name));
    }
    //获取站点的数据库使用量
    public function getDbUsed($name){
        /*
         * c :whm
         * a : getDbUsed
         * name :站点名称
         */
        return $this->open(array('c'=>'whm','a'=>'getDbUsed','name'=>$name));
    }
}

© 版权声明
THE END
喜欢就支持一下吧
点赞8 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称常用语 夸夸
夸夸
还有吗!没看够!
表情代码图片

    暂无评论内容