0 / 0 / 0
Регистрация: 16.03.2016
Сообщений: 30

Загрузка файлов на сервер при помощи ajax

10.06.2016, 13:26. Показов 1986. Ответов 5
Метки ajax (Все метки)

Студворк — интернет-сервис помощи студентам
ajax не передает изображение на сервер, js только начал познавать, я так понимаю надо как то конвектировать это изображение но что то лес тугой, подскажите в чем проблема. Вот код js
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
$(document).ready (function () {
            $('#add_content').click (function () {
                $('#message_error').hide ();
                $('#message_true').hide ();
                var select = $("#select").val ();
                var file = $("#file").val ();//Переменная с изображением
                var titl = $("#titl").val ();
                var eaze_text = $("#eaze_text").val ();
                var content = $("#content").val ();
                var input_link = $("#input_link").val ();
                var input_link_text = $("#input_link_text").val ();
                var fail = "";
                    if (select == false) fail = "Выберите раздел!";
                    else if (file == false) fail = "Добавте фото!";
                    else if (titl.length < 5 || titl.length > 70 ) fail = "Заголовок не менее 5 и не более 70 символов!";
                    else if (eaze_text.length < 100 || eaze_text.length > 200) fail = "Вступительный текст не менее 100 и не более 200 символов!";
                    else if (content.length < 500) fail = "Текст статьи не менее 500 символов!(сейчас ??)";
                    else if (input_link.length == false) fail = "Некоректный источник";
                    else if (input_link_text.split ('://').length - 1 == 0 ||input_link_text.split ('.').length - 1 == 0) fail = "Некоректная ссылка";
                    if (fail != "") {
                        $('#message_error').html (fail + "<br/>");
                        $('#message_error').show ();
                        return false;
                    }
                    
/*собственно говоря вычитал про new FormData думал поможет но увы*/
                        function setimage() {
                        var $image = $("#file");
                        var file = new FormData;
                        file.append('png', $image.prop('files')[0]);
                    }
                    
                    $.ajax ({
                        url: '/ajax/write_content.php',
                        type: 'POST',
                        cache: false,
                        data: {'select': select, 'file': file, 'titl': titl, 'eaze_text': eaze_text, 'content': content, 'input_link': input_link, 'input_link_text': input_link_text},
                        dataType: 'html',
                        success: function (data) {
                            $('#message_true').html (data + "<br/>");
                        $('#message_true').show ();
                        }
                    });
            });
        });
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.06.2016, 13:26
Ответы с готовыми решениями:

Ajax загрузка файлов на сервер
Доброго времени суток. Необходимо загружать файлы на сервер с помощью ajax. Серверный язык - python, фреймворк - Flask. На клиенте - чистый...

Загрузка файлов на сервер AJAX
Cобственно имеется скрипт. Рабочий,но есть проблема при загрузке файла размером больше 33 мб ,файл не передается обработчику. Максимальный...

Ajax загрузка файлов при onchange
К примеру, есть форма, при выборе файла с компьютера, данный файл сразу же должен загружатся на сервер. Тоесть, это не submit формы, а...

5
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
10.06.2016, 13:30
Денис Голота, потому что нужно не prop использовать а нормальные данные
JavaScript
1
2
3
var $image = $("#file");
var file = new FormData;
file.append('png', $image[0].files[0]);
0
0 / 0 / 0
Регистрация: 16.03.2016
Сообщений: 30
10.06.2016, 13:43  [ТС]
ajax не передает данные если я вставляю этот скрипт:
JavaScript
1
2
3
4
5
function setimage() {
                    var $image = $("#file");
                    var file = new FormData;
                    file.append('png', $image[0].files[0]);
                     }
Вот рабочее состояние, но нет отправки изображения

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
$(document).ready (function () {
            $('#add_content').click (function () {
                $('#message_error').hide ();
                $('#message_true').hide ();
                var select = $("#select").val ();
                file = $("#file").val ();
                var titl = $("#titl").val ();
                var eaze_text = $("#eaze_text").val ();
                var content = $("#content").val ();
                var input_link = $("#input_link").val ();
                var input_link_text = $("#input_link_text").val ();
                var fail = "";
                    if (select == false) fail = "Выберите раздел!";
                    else if (file == false) fail = "Добавте фото!";
                    else if (titl.length < 5 || titl.length > 70 ) fail = "Заголовок не менее 5 и не более 70 символов!";
                    else if (eaze_text.length < 100 || eaze_text.length > 200) fail = "Вступительный текст не менее 100 и не более 200 символов!";
                    else if (content.length < 500) fail = "Текст статьи не менее 500 символов!(сейчас ??)";
                    else if (input_link.length == false) fail = "Некоректный источник";
                    else if (input_link_text.split ('://').length - 1 == 0 ||input_link_text.split ('.').length - 1 == 0) fail = "Некоректная ссылка";
                    if (fail != "") {
                        $('#message_error').html (fail + "<br/>");
                        $('#message_error').show ();
                        return false;
                    }
                    /* function setimage() {
                    var $image = $("#file");
                    var file = new FormData;
                    file.append('png', $image[0].files[0]);
                     }*/
                    $.ajax ({
                        url: '/ajax/write_content.php',
                        type: 'POST',
                        cache: false,
                        data: {'select': select, 'file': file, 'titl': titl, 'eaze_text': eaze_text, 'content': content, 'input_link': input_link, 'input_link_text': input_link_text},
                        dataType: 'html',
                        success: function (data) {
                            $('#message_true').html (data + "<br/>");
                        $('#message_true').show ();
                        }
                    });
            });
        });
0
312 / 106 / 69
Регистрация: 18.04.2015
Сообщений: 346
10.06.2016, 14:30
Сколько уже тем про это в инете... 2 важных параметра ajax запроса забыли.

JavaScript
1
2
processData: false,  //убираем форматирование данных по умолчанию
contentType: false,  //убираем преобразование строк по умолчанию
0
0 / 0 / 0
Регистрация: 16.03.2016
Сообщений: 30
10.06.2016, 20:56  [ТС]
Цитата Сообщение от Armi Посмотреть сообщение
processData: false, *//убираем форматирование данных по умолчанию
contentType: false, *//убираем преобразование строк по умолчанию
у меня похожу уже мозг перекипел и я очевидного не вижу, учел про форматирование и преобразование перестал передавать переменные, отдает пустой post но при этом отдает его...(коломбур какой то)
Если без processData и contentType работает, но изображение по прежнему не идет на сервер в пост только путь откуда было взято изображение, глобальная $_FILES пустая.
укоротил код чтоб не путаться
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
$(document).ready (function () {
            $('#add_content').click (function () {
                $('#message_error').hide ();
                $('#message_true').hide ();
                var select = $("#select").val ();
                var file = $("#file").val (); //передаваемый фаил
                var titl = $("#titl").val ();
                var eaze_text = $("#eaze_text").val ();
                var content = $("#content").val ();
                var input_link = $("#input_link").val ();
                var input_link_text = $("#input_link_text").val ();
                var fail = "";
                                 $.ajax ({
                        url: '/ajax/write_content.php',
                        type: 'POST',
                        cache: false,
                        /*contentType: false, //нет передачи с этими свойствами
                        processData: false,*/
                        data: {'select': select, 'file': file, 'titl': titl, 'eaze_text': eaze_text, 'content': content,       'input_link': input_link, 'input_link_text': input_link_text},
                        dataType: 'html',
                        success: function (data) {
                            $('#message_true').html (data + "<br/>");
                        $('#message_true').show ();
                        }
                    });
            });
        });
0
0 / 0 / 0
Регистрация: 06.10.2017
Сообщений: 3
13.10.2017, 22:28
Цитата Сообщение от Денис Голота Посмотреть сообщение
dataType: 'html',
По идее, чтобы изображение отправлялось, нужно указать не html, а 'application/x-www-form-urlencoded'
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.10.2017, 22:28
Помогаю со студенческими работами здесь

Ajax загрузка картинки на сервер
Добрый день, мне нужно реализовать загрузку обычной картинки на сервер, без использваония Jquery и HTML5, т.е. на чистом js Я...

AJAX загрузка файлов.
Как сделать загрузку файла на jQuery без дополнительных плагинов (one click, ajaxForm и т.п.) и еще обязательно без iframe (target). ...

Получение данных при помощи ajax
В общем везде много написано про отсылку данных при помощи ajax... Но вот про получение что-то как-то не нарыл внятного... В общем по клику...

Добавление данных в БД с формы при помощи Ajax
есть форма &lt;form method=&quot;POST&quot; action=&quot;&quot; name=&quot;form&quot;&gt; &lt;table&gt; &lt;tr&gt; &lt;td&gt;Фамилия&lt;/td&gt; ...

Загрузка файлов на сервер
Добрый день. Прошу помощи, т.к. уже 3 день гуляю по google.ru и не могу найти ответа( Есть форма для загрузки файлов на сервер....


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru