Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 16.03.2016
Сообщений: 30

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

10.06.2016, 13:26. Показов 1949. Ответов 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru