• php用jquery-ajax上传多张图片限制图片大小


    php用jquery-ajax上传多张图片限制图片大小

    /**
     * 上传图片,默认大小限制为3M
     * @param String $fileInputName
     * @param number $size
     */
    public function processUpload($fileInputName,$size=3145728)
    {
        $result = array('status'=>0, 'errcode'=>null, 'group'=>'', 'path'=>'', 'site'=>'', 'size'=>0);
        $file = $_FILES[$fileInputName];
        //用filesize函数获取文件大小,filesize这个内置函数不能直接放$fileInputName或者$file['name'],要用$file['tmp_name'],或者直接用$file['size']
        $bytes = $file['size'];
        if($bytes==0 || $bytes > $size){
            $result['status'] = -1;
            $result['size'] = $bytes;
            return $result;
        }
        $fileMIME = $file['type'];
        $originFilename = $file['name'];
        $tmpFileDir = C('FILE_UPLOAD_SWAP_DIR');
        $fileName = CommonUtil::generateUUid();
        switch ($fileMIME)
        {
            case 'image/jpeg': //jpeg jpg jpe
                $tmpFile = $tmpFileDir.$fileName.'.jpg';
                break;
            case 'application/x-jpg':
                $tmpFile = $tmpFileDir.$fileName.'.jpg';
                break;
            default:
                $result['status'] = 1;
                $result['group'] = $tmpFileDir.$fileName;
                $result['site'] = $fileMIME;
                return $result;
        }
        //......
    }

     上图是打印出来的$file属性
     
    下面是控制器代码
    /**
     * 上传多张图片公共方法
     * fileName 为input的name属性
     */
    public function doUploadJpgMultiple()
    {
        $filename = I('get.fileName','');
        $uploader = new UploadJpgUtil();
        $result = $uploader->processUpload($filename);
        echo json_encode($result);
    }

    下面是ajax代码

    //一个页面上传多张图片
    function ajaxUploadMultiple(j) {
        $.ajaxFileUpload({
            url : base_url+"/UploadImgUtil/doUploadJpgMultiple?fileName=fileToUpload"+ j,
            secureuri : false,
            fileElementId : "fileToUpload"+ j,// file控件id
            type: "POST",
            dataType: 'json',
            success : function(data, status) {
                if (typeof (data.status) != 'undefined') {
                    if (data.status == -1) {
                        alert('上传图片不能超过规定大小');
                    }else if (data.status == 1) {
                        alert('上传图片不是JPG格式');
                    }else if (data.status != 0) {
                        alert('status='+data.status + ' errcode=' + data.errcode);
                    }
                    else {
                        var fileUrl = 'http://' + data.site + '/' + data.group
                            + '/' + data.path;
                        $('#flatImgthumb'+ j).attr('src', fileUrl);
                        $('#hidFlatImgthumb'+ j).val(data.group + '/' + data.path);
                    }
                }
            },
            error : function(data, status, e) {
                alert(e);
            }
        });
        return false;
    }

     

  • 相关阅读:
    类加载,初始化
    jvm classLoader architecture
    只选择年份的下拉菜单
    spring框架学习(二)依赖注入
    spring框架学习(一)
    JSP 过滤器
    JSP9个内置对象
    JSP 动作元素
    众数
    基于excel9.h的excel处理
  • 原文地址:https://www.cnblogs.com/zdz8207/p/php-jquery-ajax-upload-filesize.html
Copyright © 2020-2023  润新知