Загрузка файла JQGrid - PullRequest
       4

Загрузка файла JQGrid

0 голосов
/ 26 августа 2010

Я хочу использовать загрузку нескольких файлов со встроенным редактированием JQGrid.Пользователь предоставит некоторую метаинформацию и файл.Мета-информация попадет в БД, и файл будет сохранен на веб-сервере.Мне нужно сделать это на кнопку Отправить.Любое предложение / ссылка?

Ответы [ 2 ]

0 голосов
/ 18 декабря 2013

Вот демоверсия , выполненная сотрудниками JqGrid на основе плагина Ajax для загрузки файлов .Это довольно простой скрипт!

у вас есть grid.php :

// add column "fileToUpload" , hidden in main table view, showed in add/edit forms
$grid->addCol(array("name"=>"fileToUpload", "hidden"=>true, "editable"=>true, "edittype"=>"file", "editrules"=>array("edithidden"=>true)));

// file upload code
$upload = <<< UPLOAD

function (formid) {

    //These are needed for fileupload plugin
    $(formid).attr("method", "POST");
    $(formid).attr("action", "");
    $(formid).attr("enctype", "multipart/form-data");

    // convert to jqueryUI button

    $("#fileToUpload", formid).button();

    // Create a button bellow the file field
    $("<BR/><button id='buttonUpload'>Upload</button>").button().insertAfter("#fileToUpload", formid);

    // bind a event

    $("#buttonUpload", formid).click(function () {

        $('<img src="loading.gif" />')
            .dialog()
            .ajaxStart(function () {
                $("#gview_grid").attr("disabled", true);  //disable jqgrid to avoid editing while uploading file
                $(this).show();
            })
            .ajaxComplete(function () {
                $(this).dialog("close");
                $("#gview_grid").removeAttr("disabled");;  //restore jqgrid after file loading complete
            });


        $.ajaxFileUpload({
            url: 'doajaxfileupload.php',
            secureuri: false,
            fileElementId: 'fileToUpload',
            dataType: 'json',


            success: function (data, status) {


                console.log(data);
                if (typeof (data.error) != 'undefined') {
                    if (data.error != '') {
                        /* if file-upload error */
                        alert(data.error);
                    } else {
                    // file successfully uploaded 
                        alert(data.msg);
                    }
                }
            },
            error: function (data, status, e) {
                alert(e);
            }
        });
        return false;
    });
}
UPLOAD;

// bind $upload code to onInitializeForm
$grid->setNavEvent('add', 'onInitializeForm', $upload);

и загрузчик файлов Ajax ( doajaxfileupload.php ):

<?php
    $error = "";
    $msg = "";
    $fileElementName = 'fileToUpload';
    if(!empty($_FILES[$fileElementName]['error']))
    {
        switch($_FILES[$fileElementName]['error'])
        {

            case '1':
                $error = 'The uploaded file exceeds the upload_max_filesize directive in php.ini';
                break;
            case '2':
                $error = 'The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form';
                break;
            case '3':
                $error = 'The uploaded file was only partially uploaded';
                break;
            case '4':
                $error = 'No file was uploaded.';
                break;

            case '6':
                $error = 'Missing a temporary folder';
                break;
            case '7':
                $error = 'Failed to write file to disk';
                break;
            case '8':
                $error = 'File upload stopped by extension';
                break;
            case '999':
            default:
                $error = 'No error code avaiable';
        }
    }elseif(empty($_FILES[$fileElementName]['tmp_name']) || $_FILES[$fileElementName]['tmp_name'] == 'none')
    {
        $error = 'No file was uploaded..';
    }else 
    {
            $msg .= " File Name: " . $_FILES[$fileElementName]['name'] . ", ";
            $msg .= " File Size: " . @filesize($_FILES[$fileElementName]['tmp_name']);
            //for security reason, we force to remove all uploaded file
            //@unlink($_FILES[$fileElementName]);
            $fname = basename($_FILES[$fileElementName]['name']);
            if (move_uploaded_file($_FILES[$fileElementName]['tmp_name'], $fname)) {
                $msg .= " OK";
            } else {
                $error= 'Possible file upload attack';
                @unlink($_FILES['fileToUpload']);
            }           
            //@unlink($_FILES['fileToUpload']);     

    }       
    echo "{";
    echo                "error: '" . $error . "',\n";
    echo                "msg: '" . $msg . "'\n";
    echo "}";
?>
0 голосов
/ 17 марта 2011

Этот вопрос немного устарел, но если кто-нибудь получит его в Google, здесь:

http://www.trirand.com/blog/?page_id=393/feature-request/file-upload-again/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...