Javascript 使用jquery ajax和php将文件发送到客户端
我正在尝试通过jQuery、AJAX和PHP向客户机发送文件。我使用的是jQuery v1.11.2和xampp v3.2.1 以下是我的jQuery代码:Javascript 使用jquery ajax和php将文件发送到客户端,javascript,php,jquery,ajax,Javascript,Php,Jquery,Ajax,我正在尝试通过jQuery、AJAX和PHP向客户机发送文件。我使用的是jQuery v1.11.2和xampp v3.2.1 以下是我的jQuery代码: <script> $(document).ready(function(){ $("#myBtn").click(function(){ $.ajax({ // post file name type: "POST", data: {
<script>
$(document).ready(function(){
$("#myBtn").click(function(){
$.ajax({ // post file name
type: "POST",
data: {
file: "testfile.xlsx"
},
url: "sendfile.php",
context: $("#result"),
success: function(data, status, xhr){
$(this).html(data);
}
});
});
});
</script>
还有更有效的方法吗?如果您正在寻找另一种类似的方法,
尝试使用“uploadify”它的免费和简单-->如果您正在寻找另一种类似的方法,
尝试使用“uploadify”,它既免费又简单-->您无法通过AJAX接收下载。。。您需要执行某种重定向。我认为此链接将帮助您无法通过AJAX接收下载。。。您需要执行某种重定向。我认为此链接将对您有所帮助
<?php
FUNCTION send_file($name) { // function ... send file to client
OB_END_CLEAN();
$path = $name;
//cek connection if lost connection with client
IF (!IS_FILE($path) or CONNECTION_STATUS()!=0) RETURN(FALSE);
//header
//-------------------------------------------------------------
HEADER("Cache-Control: no-store, no-cache, must-revalidate");
HEADER("Cache-Control: post-check=0, pre-check=0", FALSE);
HEADER("Pragma: no-cache");
HEADER("Expires: ".GMDATE("D, d M Y H:i:s", MKTIME(DATE("H")+2, DATE("i"), DATE("s"), DATE("m"), DATE("d"), DATE("Y")))." GMT");
//set last modified property
HEADER("Last-Modified: ".GMDATE("D, d M Y H:i:s")." GMT");
HEADER("Content-Type: application/octet-stream");
HEADER("Content-Length: ".(string)(FILESIZE($path)));
HEADER("Content-Disposition: inline; filename=$name"); // file
HEADER("Content-Transfer-Encoding: binary\n");
//-----------------------------------------------------------------
IF ($file = FOPEN($path, 'rb')) { // send file
WHILE(!FEOF($file) and (CONNECTION_STATUS()==0)) {
PRINT(FREAD($file, 1024*8));
FLUSH();
}
FCLOSE($file);
}
RETURN((CONNECTION_STATUS()==0) and !CONNECTION_ABORTED());
}
// send file
if(!send_file($_POST['file'])){
echo "error.";
}
send_file("testfile.xlsx");