Форум программистов, компьютерный форум, киберфорум
PHP
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
 Аватар для radiofan
3 / 2 / 1
Регистрация: 18.04.2018
Сообщений: 51

Отслеживание прогресса загрузки файлов (сессия)

06.05.2020, 13:41. Показов 1761. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, уважаемые форумчане. Столкнулся со странной проблемой. Создал форму с отправкой файла через ajax.

PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<div class="admin-section">
    <input type="hidden" name="MAX_FILE_SIZE" value="524288000">
    <input type="hidden" class="upload_progress_name" name="'.ini_get('session.upload_progress.name').'" value="modpuck_file">
    <table class="admin-data-table">
        <tr>
            <th>Файл</th>
            <td><input type="file" name="modpuck_file"></td>
            <td><div id="progress-bar"></div><div id="cancel-upload" class="admin-cancel" style="display:none;"></div></td>
        </tr>
        <tr>
            <th>Версия загружаемого модпака</th>
            <td><input type="text" class="admin-input" placeholder="Modpuck version" name="upload_modpuck_version" id="upload-modpuck-version"></td>
            <td></td>
        </tr>
    </table>
</div>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
var timer, check_timer, $progress, $progress_name, xhr;
    $form.on('click.upload_file', 'input.upload-modpuck', function(e){
        e.preventDefault();
        if(check_timer)
            return;
        $section = $(this).closest('.admin-section');
        //let data = {'action':'upload_modpuck'};
        
        let data = new FormData();
        
        data.append('action', 'upload_modpuck');
        
        $progress_name = $section.find('input.upload_progress_name');
        data.append($progress_name.attr('name'), $progress_name.val());
        
        let file = $section.find('input[name=modpuck_file]').prop('files')[0];
        if(!file){
            alert('Файл не указан');
            return;
        }
        data.append('modpuck_file', file);
        
        let version = valid_version($section.find('#upload-modpuck-version').val());
        if(version === ''){
            alert('Версия не указана');
            return;
        }
        if(check_version(version)){
            if(!confirm('Указана существующая версия.\nПроизвести замену?'))
                return false;
        }
        data.append('upload_modpuck_version', version);
        
        $progress = $section.find('#progress-bar');
        check_timer = true;
        
        xhr = $.ajax({
            url: '/ajax.php',
            type: 'POST',
            processData: false,
            contentType: false,
            cache:false,
            dataType: 'json',
            data: data,
            beforeSend: function(){
                $progress.text('0%');
                timer = setTimeout(check_upload, 100);
                $section.find('#cancel-upload').show();
            },
            complete: function(){
                $section.find('#cancel-upload').hide();
                clearTimeout(timer);
                check_timer = false;
            },
            success: function(data){
                console.log(data);
                if(data.success == 'OK'){
                    $progress.text('Загружено');
                    edit_mod_table(data);
                }else{
                    alert(data.error);
                    $progress.text('Ошибка');
                }
                clearTimeout(timer);
                check_timer = false;
            },
            error: function(){
                $progress.text('Прервано');
                clearTimeout(timer);
                check_timer = false;
            }
        });
    });
    
    $form.on('click.cancel_upload_file', '#cancel-upload', function(e){
        let data = {'action':'cancel_upload'};
        data[$progress_name.attr('name')] = $progress_name.val();
        $.ajax({
            url: '/ajax.php',
            type: 'POST',
            cache:false,
            dataType: 'json',
            data: data,
            complete: function(){
                //$progress.text('Прервано');
            },
            success: function(data){
                $section.find('#cancel-upload').hide();
                $progress.text('Прервано');
                clearTimeout(timer);
                check_timer = false;
                xhr.abort();
            }
        });
    });
Добавлено через 24 минуты
ПРОДОЛЖЕНИЕ
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
          function check_upload(){
        let data = {'action':'check_upload'};
        data[$progress_name.attr('name')] = $progress_name.val();
        $.ajax({
            url: '/ajax.php',
            type: 'POST',
            cache:false,
            dataType: 'json',
            data: data,
            error: function(){
                if(check_timer)
                    timer = setTimeout(check_upload, 500);
            },
            success: function(data){
                console.log(data);
                if(check_timer)
                    timer = setTimeout(check_upload, 250);
                if(data && data.hasOwnProperty('progress'))
                    $progress.text(data.progress + '%');
            }
        });
    }
Приемник

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
<?php
function action_upload_modpuck(){
    die(JSON_encode(upload_modpuck_help()));
}
 
function upload_modpuck_help(){
    global $DATA;
    $ret = array();
    if(!is_admin())
        return array('error' => 'Нет доступа');
    
    //$ret['dostup'] = 1;
    
    if(empty($_FILES['modpuck_file']['name']) || is_array($_FILES['modpuck_file']['name']))
        return array('error' => 'Файл отсутствует или их много');
    
    //$ret['files'] = 2;
    
    if($_FILES['modpuck_file']['error'] != UPLOAD_ERR_OK)
        return array('error' => 'Ошибка при загрузке');
    // || !is_uploaded_file($_FILES['modpuck_file']['tmp_name'])
    
    //$ret['upload'] = 3;
    
    $version = '';
    if(!isset($_POST['upload_modpuck_version']) || !strlen($version = validation_filename($_POST['upload_modpuck_version'])))
        return array('error' => 'Отсутствует версия');
    
    //$ret['version'] = 4;
    
    $ext = pathinfo($_FILES['modpuck_file']['name'], PATHINFO_EXTENSION);
    $ext = validation_filename($ext);
    if(!strlen($ext))
        return array('error' => 'Отсутствует расширение');
    
    //$ret['ext'] = 5;
    
    delete_modpuck($version);
    
    if(!move_uploaded_file($_FILES['modpuck_file']['tmp_name'], MAIN_DIR.'modpucks/'.$version.'.'.$ext.'.modpuck'))
        return array('error' => 'Произошла ошибка при копировании');
    
    //$ret['copy'] = 6;
    $DATA->set('main_modpuck_version', $version);
    $DATA->update('main_modpuck_version');
    
    $ret['success']  = 'OK';
    $ret['filesize'] = get_filesize(MAIN_DIR.'modpucks/'.$version.'.'.$ext.'.modpuck');
    $ret['version']  = $version;
    $ret['filename'] = $version.'.'.$ext;
    
    return $ret;
}
 
function action_check_upload(){
    is_session_exists();
    $ret = array();
    //$ret['post'] = 0;
    if(!isset($_POST[ini_get('session.upload_progress.name')]))
        die(JSON_encode($ret));
    
    //$ret['progress_name'] = 1;
    
    $sess_name = ini_get("session.upload_progress.prefix").$_POST[ini_get('session.upload_progress.name')];
    //$ret['_SESSION'] = $_SESSION;
    //$ret['sess_name'] = $sess_name;
    
    if(!isset($_SESSION[$sess_name]))
        die(JSON_encode($ret));
    
    //$ret['session'] = 2;
    
    if(!is_admin()){
        $_SESSION[$sess_name]['cancel_upload'] = true;
        //$ret['notadmin'] = 3;
    }else{
        //$ret['admin'] = 3;
        $p = (float)($_SESSION[$sess_name]['bytes_processed'] * 100) / $_SESSION[$sess_name]['content_length'];
        $p = round($p, 0);
        $ret['progress'] = $p;
        $ret['bytes_upload'] = $_SESSION[$sess_name]['bytes_processed'];
        //die(JSON_encode(array('progress' => $p, 'bytes_upload' => $_SESSION[$sess_name]['bytes_processed'])));
    }
    die(JSON_encode($ret));
}
 
function action_cancel_upload(){
    is_session_exists();
    $ret = array();
    //$ret['post'] = 0;
    if(!isset($_POST[ini_get('session.upload_progress.name')]))
        die(JSON_encode($ret));
    
    //$ret['progress_name'] = 1;
    
    $sess_name = ini_get("session.upload_progress.prefix").$_POST[ini_get('session.upload_progress.name')];
    
    if(!isset($_SESSION[$sess_name]))
        die(JSON_encode($ret));
    
    //$ret['session'] = 2;
    
    $_SESSION[$sess_name]['cancel_upload'] = true;
    die(JSON_encode($ret));
}
function is_admin(){
    //die(is_session_exists());
    if(is_session_exists()){
        return isset($_SESSION['admin']) && $_SESSION['admin'];
    }else{
        return false;
    }
}
 
function is_session_exists(){
    if(!session_id() && (isset($_REQUEST[session_name()]) || isset($_COOKIE[session_name()]))){
    //if(!session_id() && isset($_REQUEST[session_name()])){
        $sessid = isset($_REQUEST[session_name()]) ? $_REQUEST[session_name()] : '';
        if(!$sessid)
            $sessid = $_COOKIE[session_name()];
        session_id($sessid);
        my_start_session();
        if(empty($_SESSION)){
            session_destroy();
            return false;
        }
        return true;
    }else if(session_id()){
        return true;
    }
    return false;
}
 
function my_start_session(){
    $params = session_get_cookie_params();
    $params['httponly'] = true;
    session_set_cookie_params($params['lifetime'], $params['path'], $params['domain'], $params['secure'], $params['httponly']);
    
    session_start();
}
?>
Данный код прекрасно работает на локалке (DENWER Apache/2.4.23 (Win32) OpenSSL/1.0.2h PHP/7.0.10)
С такими настройками сессии
DirectiveLocal ValueMaster Value
session.auto_startOffOff
session.cache_expire180180
session.cache_limiternocachenocache
session.cookie_domainno valueno value
session.cookie_httponlyOffOff
session.cookie_lifetime00
session.cookie_path//
session.cookie_secureOffOff
session.entropy_fileno value novalue
session.entropy_length00
session.gc_divisor10001000
session.gc_maxlifetime14401440
session.gc_probability11
session.hash_bits_per_character55
session.hash_function00
session.lazy_writeOnOn
session.namePHPSESSIDPHPSESSID
session.referer_checkno valueno value
session.save_handlerfilesfiles
session.save_path/tmp/tmp
session.serialize_handlerphpphp
session.upload_progress.cleanupOnOn
session.upload_progress.enabledOnOn
session.upload_progress.freq1%1%
session.upload_progress.min_freq11
session.upload_progress.namePHP_SESSION_UPLOAD_PROGRESSPHP_SESSION_UPLOAD_PROGRESS
session.upload_progress.prefixupload_progress_upload_progress_
session.use_cookiesOnOn
session.use_only_cookiesOnOn
session.use_strict_modeOffOff
session.use_trans_sid00

Но на проде в сессии отсутствует данные о загрузке (а об админе есть ), хотя настройки сессии отличаются только в значениях session.entropy_file, session.entropy_length, session.save_path.

На хосте также установлены memcached и memcache, могут ли они как-нибудь влиять?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.05.2020, 13:41
Ответы с готовыми решениями:

Не работает отслеживание прогресса загрузки файлов на сессиях
Использую РНР 5.5 , в рнр.ini включил настройки. Код страницы: &lt;?php header('Content-Type: text/html; charset=utf-8'); ...

Отслеживание порядка загрузки файлов в ОЗУ
1. Привет всем. Сам не программер. Интересен вопрос возможно ли создать резидентную программу по ОС семейства windows (XP,vista), которая...

Отображение прогресса загрузки страницы
Доброго дня всем подскажите код чтоб ProgressBar отображел ход загрузки Web страници если есть такая тема то подскажите где найти:)

1
0 / 0 / 0
Регистрация: 04.06.2021
Сообщений: 1
04.06.2021, 22:21
всё в одном файле index.php

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
<?php
$ret = array();
 
if(!session_id())
    session_start();
 
if($_POST["action"] == "check_upload")
{
    $key = ini_get('session.upload_progress.name');
    $session_name = ini_get("session.upload_progress.prefix") . $_POST[$key];
 
    if(empty($_SESSION[$session_name]))
        exit(json_encode(array('error' => 'Пустая сессия')));
 
    $p = (float)($_SESSION[$session_name]['bytes_processed'] * 100) / $_SESSION[$session_name]['content_length'];
    $p = round($p, 0);
    $ret['progress'] = $p;
    $ret['bytes_upload'] = $_SESSION[$session_name]['bytes_processed'];
    exit(json_encode($ret));
}
 
if($_POST["action"] == "cancel_upload")
{
    $key = ini_get('session.upload_progress.name');
    $session_name = ini_get("session.upload_progress.prefix") . $_POST[$key];
    $_SESSION[$session_name]['cancel_upload'] = true;
    exit(json_encode($ret));
}
 
if($_POST["action"] == "upload_modpuck")
{
    $file = $_FILES['upload_file'];
    if(empty($file['name']))
        exit(json_encode(array('error' => 'Файл отсутствует')));
 
    if($file['error'] != UPLOAD_ERR_OK)
        exit(json_encode(array('error' => 'Ошибка при загрузке: error '.$file['error'])));
 
 
    $ext = pathinfo($file['name'], PATHINFO_EXTENSION);
    if(!strlen($ext))
        exit(json_encode(array('error' => 'Отсутствует расширение')));
 
    $size = filesize($file['tmp_name']);
    if(!move_uploaded_file($file['tmp_name'], 'filename.'.$ext))
        exit(json_encode(array('error' => 'Произошла ошибка при копировании')));
 
    $ret['success']  = 'OK';
    $ret['filesize'] = $size;
    $ret['filename'] = 'filename.'.$ext;
    exit(json_encode($ret));
}
?>
HTML5
1
2
3
4
5
6
7
<!DOCTYPE HTML>
<html>
<head>
  <meta charset="utf-8">
</head>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
$( document ).ready(function() {
    var timer, check_timer, $progress, $progress_name, xhr;
    var timeout = 1000;
 
    $form = $('form#upload');
    session_prefix = $form.find('input.upload_progress_name').attr('name');
    session_value = $form.find('input.upload_progress_name').val();
 
    $('form#upload').on('change', function(e){
        e.preventDefault();
        if(check_timer)
            return;
 
        let data = new FormData();
        data.append('action', 'upload_modpuck');
        data.append(session_prefix, session_value);
 
        let file = $form.find('input[name=upload_file]').prop('files')[0];
        if(!file)
        {
            alert('Файл не указан');
            return;
        }
        data.append('upload_file', file);
 
        $progress = $form.find('#progress-bar');
        check_timer = true;
 
        xhr = $.ajax({
            url: window.location.href,
            type: 'POST',
            processData: false,
            contentType: false,
            cache:false,
            dataType: 'json',
            data: data,
            beforeSend: function(){
                $progress.text('0%');
                timer = setTimeout(check_upload, timeout);
                $form.find('#cancel-upload').show();
            },
            complete: function(){
                $form.find('#cancel-upload').hide();
                clearTimeout(timer);
                check_timer = false;
            },
            success: function(data){
                if(data.success == 'OK')
                {
                    $progress.text('Загружено');
                }
                else
                {
                    alert(data.error);
                    $progress.text('Ошибка');
                }
                clearTimeout(timer);
                check_timer = false;
            },
            error: function(){
                $progress.text('Прервано');
                clearTimeout(timer);
                check_timer = false;
            }
        });
    });
 
    $('#cancel-upload').on('click', function(e){
        let data = {'action':'cancel_upload'};
        data[session_prefix] = session_value;
        $.ajax({
            url: window.location.href,
            type: 'POST',
            cache:false,
            dataType: 'json',
            data: data,
            complete: function(){
                progress.text('Прервано');
            },
            success: function(data){
                $form.find('#cancel-upload').hide();
                $progress.text('Прервано');
                clearTimeout(timer);
                check_timer = false;
                xhr.abort();
            }
        });
    });
 
    function check_upload(){
        let data = {'action':'check_upload'};
        data[session_prefix] = session_value;
        $.ajax({
            url: window.location.href,
            type: 'POST',
            cache:false,
            dataType: 'json',
            data: data,
            error: function(){
                clearTimeout(timer);
                check_timer = false;
            },
            success: function(data){
                console.log(data);
                if(check_timer)
                    timer = setTimeout(check_upload, timeout);
                if(data && data.hasOwnProperty('progress'))
                    $progress.text(data.progress + '%');
            }
        });
    }
});
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
</script>
 
<body>
    <form name="upload" id="upload">
        <input type="hidden" name="MAX_FILE_SIZE" value="524288000">
        <input type="hidden" class="upload_progress_name" name="<?php ini_get('session.upload_progress.name');?>" value="upload_file">
        <input type="file" name="upload_file">
        <span id="progress-bar"></span>
        <span><a id="cancel-upload" href="javascript:void(0);" style="display:none">Отменить</a></span>
    </form>
</body>
 
</html>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.06.2021, 22:21
Помогаю со студенческими работами здесь

Индикатор прогресса загрузки страницы ?
Подскажите пожалуйста, как создать индикатор прогресса загрузки страницы, что-бы он реально отображал процесс загрузки страницы, т.е. какой...

Отображение прогресса загрузки файла
Как сделать, чтобы во время загрузки файла запускался прогресс бар?

Upload компонета с индикатором прогресса загрузки
Кто-то видел upload компонету с индикатором прогреса загрузки ... а то у меня стоит aspSmartUpload ... люди грузят фотки на сайт (есть...

Показывать индикатор прогресса загрузки формы
Добрый день! Есть две формы. Вторая форма вызывается из первой путем нажатия кнопки. При загрузке второй формы (Load) происходит много...

Использование BackgroundWorker в WPF для отображения прогресса загрузки БД
Допустим, есть какой-то UserControl, в который надо вывести таблицу из БД. В том же UserControl`е имеется ProgressBar. Как правильно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru