• ftp上传文件到服务器


    <?php
    class Ftp
    {
        public $off; // 返回操作状态(成功/失败)
        public $conn_id; // FTP连接
        const FTP_HOST='';
        const FTP_PORT='21';
        const FTP_USER='';
        const FTP_PASS='';
    
        /**
         * FTP连接
         * @FTP_HOST -- FTP主机
         * @FTP_PORT -- 端口
         * @FTP_USER -- 用户名
         * @FTP_PASS -- 密码
         */
        function __construct()
        {
            $this->conn_id = @ftp_connect(self::FTP_HOST,self::FTP_PORT) or die("FTP服务器连接失败");
            @ftp_login($this->conn_id,self::FTP_USER,self::FTP_PASS) or die("FTP服务器登陆失败");
            @ftp_pasv($this->conn_id,1); // 打开被动模拟
        }
    
        /**
         * 上传文件
         * @param $path 本地路径
         * @param $newPath 目标目录
         * @param bool $type 若目标目录不存在则新建
         */
        function up_file($path,$newPath,$type=false)
        {
    
            if($type) $this->dir_mkdirs($newPath);
    
            // $this->off = ftp_put($this->conn_id,'/test/a.jpg','E:	estupload.jpg',FTP_BINARY);
            $this->off = ftp_put($this->conn_id,$newPath,$path,FTP_BINARY);
            if(!$this->off) {
    
                return false;
            }else{
                return true;
            }
        }
    
        /**
         * 移动文件
         * @param $path 原路径
         * @param $newPath 新路径
         * @param bool $type 若目标目录不存在则新建
         */
        function move_file($newPath,$type=true)
        {
            if($type) $this->dir_mkdirs($newPath);
            $this->off = @ftp_rename($this->conn_id,$path,$newPath);
            if(!$this->off) echo "文件移动失败,请检查权限及原路径是否正确!";
        }
    
        /**
         * 复制文件
         * 说明:由于FTP无复制命令,本方法变通操作为:下载后再上传到新的路径
         * @param $path 原路径
         * @param $newPath 新路径
         * @param bool $type 若目标目录不存在则新建
         */
        function copy_file($path,$newPath,$type=true)
        {
            $downPath = "c:/tmp.dat";
            $this->off = @ftp_get($this->conn_id,$downPath,$path,FTP_BINARY);// 下载
            if(!$this->off) echo "文件复制失败,请检查权限及原路径是否正确!";
            $this->up_file($downPath,$newPath,$type);
        }
    
        /**
         * 删除文件
         * @param $path 路径
         */
        function del_file($path)
        {
            $this->off = @ftp_delete($this->conn_id,$path);
            if(!$this->off) echo "文件删除失败,请检查权限及路径是否正确!";
        }
    
        /**
         * 生成目录
         * @param $path 路径
         */
        function dir_mkdirs($path)
        {
            $path_arr = explode('/',$path); // 取目录数组
            $file_name = array_pop($path_arr); // 弹出文件名
            $path_div = count($path_arr); // 取层数
            foreach($path_arr as $val) { // 创建目录
                if(@ftp_chdir($this->conn_id,$val) == FALSE) {
                    $tmp = @ftp_mkdir($this->conn_id,$val);
                    if($tmp == FALSE) {
                        echo "目录创建失败,请检查权限及路径是否正确!";
                        exit;
                    }
                    @ftp_chdir($this->conn_id,$val);
                }
            }
            for($i=1;$i=$path_div;$i++) {// 回退到根
                @ftp_cdup($this->conn_id);
            }
        }
    
        /**
         * 关闭FTP连接
         */
        function close()
        {
            @ftp_close($this->conn_id);
        }
    
    
    }
    <?php
     include './Ftp.php';
     $ftp = new Ftp();
     $local_file = './upload.jpg';
     $remote_file = '/test/upload.jpg';
    
     //上传文件
     if ($ftp->up_file($local_file,$remote_file)){
         echo "上传成功";
     }else{
         echo "上传失败";
     }
  • 相关阅读:
    fiber
    ACM用到的算法。先做个笔记,记一下
    matlab安装及破解
    银行家算法
    网络安全(超级详细)零基础带你一步一步走进缓冲区溢出漏洞和shellcode编写!
    心脏滴血漏洞复现(CVE-2014-0160)
    KMP算法分析
    利用BURPSUITE检测CSRF漏洞
    BURPSUITE爆破密码
    动态规划—最长回文子串LEETCODE第5题深度剖析
  • 原文地址:https://www.cnblogs.com/xiaobiaomei/p/9936441.html
Copyright © 2020-2023  润新知