- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
早上好
我到处搜索,但没有找到问题的答案。我想使用 jquery,但尝试使用“常规”Javascript 但收效甚微。
目标
我想通过 ajax(异步)将文件(只有一个)上传到将使用文件 (txt) 的 php 服务器。
问题
脚本不会调用php脚本,文件也不会上传。没有 javascript 错误,脚本运行正常。在 chrome 中,process.php 没有出现在网络部分,所以我不确定它是来自脚本还是我的 php 中的错误。
一般信息
浏览器:Chrome 版本 26.0.1410.64 m
wamp 服务器 (php, mysql)
布局 Bootstrap
代码
索引:
<div class="span12" id="upload_form_div" style="display: block;">
<form id="upload_form" enctype="multipart/form-data" class="upload_form">
<fieldset>
<legend>
Please select a file to parse and merge with the database.
</legend>
<p>
<label for="files">File:</label>
<input type="file" class="text" id="files" name="file">
</p>
<p>
<input type="button" value="Start Parse">
</p>
</fieldset>
</form>
</div>
我包括了 jquery.js、app.js(用于上传的脚本文件)和 bootstrap.min.js。只是认为没有必要显示完整的 html 标记。
脚本文件:
$(function(){
$("#progressbar").hide();
});
function showProgress(evt) {
if (evt.lengthComputable) {
var percentComplete = (evt.loaded / evt.total) * 100;
$('#progressbar').progressbar("option", "value", percentComplete );
}
}
$(':button').click(function(){
var fileIn = $("#files")[0];
//Has any file been selected yet?
if (fileIn.files === undefined || fileIn.files.length == 0) {
alert("Please select a file");
return;
}
//We will upload only one file
var file = fileIn.files[0];
console.log(file);
//Show the progress bar
$("#progressbar").show();
$.ajax({
url: 'process.php', //server script to process data
type: 'POST',
data: file,
contentType: file.type,
processData: false,
success: function(){
$("#progressbar").hide();
},
error: function(){
$("#progressbar").hide();
alert("Failed");
//alert(xhr.responseText);
},
xhr: function() { // custom xhr
myXhr = $.ajaxSettings.xhr();
if(myXhr.upload){ // check if upload property exists
//myXhr.upload.addEventListener('progress',showProgress, false); // for handling the progress of the upload
//console.log($.ajaxSettings.xhr().upload);
console.log(myXhr.responseText);
} else {
console.log("Upload progress is not supported.");
}
return myXhr;
}
});
});
这是直接复制粘贴,所以我注释掉了一些故障排除线。
PHP
<?php
set_error_handler("E_ALL");
$upload_directory = "files/";
move_uploaded_file($_FILES['file']['tmp_name'], $upload_directory . $_FILES['file']['name']);
?>
php 文件会做更多的事情,但此时我只是想让文件上传。
如果有人需要更多信息,请告诉我,我会尽力提供信息。
最佳答案
抱歉 - 您无法通过 ajax 请求上传文件。您必须发挥一点创意,并在提交时使用隐藏的 iframe。这通常涉及创建一个新的隐藏表单,将文件控件克隆(或在 IE 的情况下移动)到隐藏表单中,并将新表单附加到隐藏的 iframe。 iframe 的 post 方法 Hook 到您要将文件发送到的位置的 URL。您可以通过创建/克隆将作为查询字符串的一部分发送到 URL 的文本框来包含与文件一起使用的变量。
在客户端,在提交表单后创建一个计时器事件,该事件将检查 javascript 变量(在提交表单之前清除 var)。在服务器端,通过响应对象向下发送 javascript 以设置客户端 var。这是您将知道文件上传完成的方式。这个过程相当复杂 - 特别是在使用 IE 时,您需要将文件控件移回您移动它的位置,并创建一个“虚拟”文件控件来 stub 它。您可能需要查看一些jQuery文件上传插件...下面是一些代码,可帮助您开始使用 iframe 方法:
jQuery('#btn5Submit').click(function() {
//create a temporary form with the fileboxes on it, then attach to the end of the html form (to avoid nested form tags)
var wkForm = jQuery('<form id="tmpFileUpload" method="POST" action="filehandler.ashx" encType="multipart/form-data" target="uploadResult" class="ctlHidden"></form>');
for (var i = 1; i < 4; i++) {
var wkFile = jQuery('#file5Upload' + i);
if (wkFile.val() != '' && wkFile.length != 0) {
jQuery('<img src="Styles/Images/loading.gif" id="' + 'img5File' + i + '" />').insertAfter(wkFile);
wkForm.append(wkFile);
}
else {
//user did not provide a file, add a dummy file input to the temp form to maintain order
wkForm.append('<input name="file5TUpload' + i + '" type="file"/>');
}
}
jQuery('body').append(wkForm);
jQuery('#tmpFileUpload').submit();
});
jQuery('.deleteFile').live('click', function() {
editRow = jQuery(this).parent();
var ddlog = jQuery('<div></div>');
var btns = {};
var gMsg = 'Are you sure you want to delete this file? (This will allow you to specify a new file, but the server file will not be replaced until "Send Files To Server" is pressed.)';
ddlog.html(gMsg);
var button1 = 'Delete File';
var button2 = 'Cancel Deletion';
btns[button1] = function() {
var wkId = jQuery(editRow).attr('id');
wkId = wkId.charAt(wkId.length - 1);
jQuery('<input id="file5Upload' + wkId + '" name="file5Upload' + wkId + '" type="file" class="fileUpload" />').insertAfter(editRow);
jQuery(editRow).remove();
jQuery(this).dialog('close');
};
btns[button2] = function() {
//Do not save changes, reset section control buttons, reset global var, reset initial_data values (Do not save changes)
jQuery(this).dialog('close');
};
ddlog.dialog({ autoOpen: false, title: 'File Deletion Confirmation', resizable: false, modal: true, buttons: btns });
ddlog.dialog('open');
});
关于php - Jquery XMLHttpRequest 不调用 url,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16359342/
为了让我的代码几乎完全用 Jquery 编写,我想用 Jquery 重写 AJAX 调用。 这是从网页到 Tomcat servlet 的调用。 我目前情况的类似代码: var http = new
我想使用 JNI 从 Java 调用 C 函数。在 C 函数中,我想创建一个 JVM 并调用一些 Java 对象。当我尝试创建 JVM 时,JNI_CreateJavaVM 返回 -1。 所以,我想知
环顾四周,我发现从 HTML 调用 Javascript 函数的最佳方法是将函数本身放在 HTML 中,而不是外部 Javascript 文件。所以我一直在网上四处寻找,找到了一些简短的教程,我可以根
我有这个组件: import {Component} from 'angular2/core'; import {UserServices} from '../services/UserService
我正在尝试用 C 实现一个简单的 OpenSSL 客户端/服务器模型,并且对 BIO_* 调用的使用感到好奇,与原始 SSL_* 调用相比,它允许一些不错的功能。 我对此比较陌生,所以我可能会完全错误
我正在处理有关异步调用的难题: 一个 JQuery 函数在用户点击时执行,然后调用一个 php 文件来检查用户输入是否与数据库中已有的信息重叠。如果是这样,则应提示用户确认是否要继续或取消,如果他单击
我有以下类(class)。 public Task { public static Task getInstance(String taskName) { return new
嘿,我正在构建一个小游戏,我正在通过制作一个数字 vector 来创建关卡,该数字 vector 通过枚举与 1-4 种颜色相关联。问题是循环(在 Simon::loadChallenge 中)我将颜
我有一个java spring boot api(数据接收器),客户端调用它来保存一些数据。一旦我完成了数据的持久化,我想进行另一个 api 调用(应该处理持久化的数据 - 数据聚合器),它应该自行异
首先,这涉及桌面应用程序而不是 ASP .Net 应用程序。 我已经为我的项目添加了一个 Web 引用,并构建了各种数据对象,例如 PayerInfo、Address 和 CreditCard。但问题
我如何告诉 FAKE 编译 .fs文件使用 fsc ? 解释如何传递参数的奖励积分,如 -a和 -target:dll . 编辑:我应该澄清一下,我正在尝试在没有 MSBuild/xbuild/.sl
我使用下划线模板配置了一个简单的主干模型和 View 。两个单独的 API 使用完全相同的配置。 API 1 按预期工作。 要重现该问题,请注释掉 API 1 的 URL,并取消注释 API 2 的
我不确定什么是更好的做法或更现实的做法。我希望从头开始创建目录系统,但不确定最佳方法是什么。 我想我在需要显示信息时使用对象,例如 info.php?id=100。有这样的代码用于显示 Game.cl
from datetime import timedelta class A: def __abs__(self): return -self class B1(A):
我在操作此生命游戏示例代码中的数组时遇到问题。 情况: “生命游戏”是约翰·康威发明的一种细胞自动化技术。它由一个细胞网格组成,这些细胞可以根据数学规则生存/死亡/繁殖。该网格中的活细胞和死细胞通过
如果我像这样调用 read() 来读取文件: unsigned char buf[512]; memset(buf, 0, sizeof(unsigned char) * 512); int fd;
我用 C 编写了一个简单的服务器,并希望调用它的功能与调用其他 C 守护程序的功能相同(例如使用 ./ftpd start 调用它并使用 ./ftpd stop 关闭该实例)。显然我遇到的问题是我不知
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
我希望能够从 cmd 在我的 Windows 10 计算机上调用 python3。 我已重新安装 Python3.7 以确保选择“添加到路径”选项,但仍无法调用 python3 并使 CMD 启动 P
我是一名优秀的程序员,十分优秀!