99行代码(HTML+js+php)实现ajax上传文件并保存

20 篇文章 0 订阅
19 篇文章 0 订阅

99行代码(HTML+js+php)实现ajax上传文件并保存,不依赖其他函数比如jq;

支持上传前后都进行后缀和文件大小判断;

支持修改参数设定可上传文件大小及可上传后缀。

<?php
$isup = ".csv|.txt|.jpg|.gif|.rar|.zip|.doc|.xls|.xlsx"; //修改可上传格式
$lenx = 500; //修改上传文件最大值,单位KB
function getext($file){
$info = pathinfo($file);
return $info['extension'];
}
if($_GET["act"]=="up"){
$path=$_POST["tim"];
$base=$_POST["txt"];
//可加入文件大小 和 格式判断
$tape = getext($path);
if(!stristr("|{$isup}|","|.{$tape}|")){ exit("上传失败,文件名后缀[{$tape}]不支持!");}
$txts=explode("base64,",$base);
$txto=base64_decode(str_replace(" ","+",$txts[1]));
if(strlen($txto)>$lenx*1024){ exit("上传失败,文件大小超过允许值{$lenx}KB!");}
$files = date("YmdHis").".".$tape;
file_put_contents($files, $txto);
 exit($path."上传成功,更名为:".$files);
}
?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Ajax File upload</title>
<style>
</style>
<script>
var $=function(node){
return document.getElementById(node);
}
function $(objId){
return document.getElementById(objId);
}
function GetRequest(Url,GetFunction){
if(window.ActiveXObject){
var xpost = new ActiveXObject("Microsoft.XMLHTTP");
}else{
var xpost = new XMLHttpRequest();
}
xpost.onreadystatechange = function(){
if(xpost.readyState == 4){
if(xpost.status == 200){
GetFunction(xpost.responseText);
}else{
GetFunction(404);
}
}else{
GetFunction("载入中...");
}
}
xpost.open("post",'?act=up',true);
xpost.setRequestHeader("Content-type","application/x-www-form-urlencoded;charset-UTF-8");
xpost.send(Url);
}

 window.onload = function () {
 var input = $("fielinput");
 if (typeof (FileReader) === 'undefined') {
 $("tips").innerHTML = "抱歉,请使用chrome,firefox等现代浏览器,国产浏览器请使用急速模式!";
 input.setAttribute('disabled', 'disabled');
 } else {
 input.addEventListener('change', readFile, false);
 }
 }
 function readFile() {
 var file = this.files[0];
 if (file.size>1) {
 $("fielinput").value=""; //初始化防止上传同名无反应
 if (!/(<?php echo $isup; ?>)$/.test(file.name)){
 $("tips").innerHTML = "上传失败:该后缀格式不支持上传!";
 return false;
 }
 if (file.size><?php echo $lenx; ?>*1024) {
 $("tips").innerHTML = "上传失败:文件大小请控制在<?php echo $lenx; ?>kB以内!";
 return false;
 }
 var reader = new FileReader();
 reader.readAsDataURL(file);//readAsText(file,"UTF-8")
 reader.onload = function (e) { 
 SendUrl = "tim="+file.name+"&txt="+this.result;
GetRequest(SendUrl,function(GetText){
if(GetText == 404){
 $("tips").innerHTML = "上传失败!";
 return false;
}else{
 $("tips").innerHTML = GetText;
}
});
 } 
 }
} 
</script>
</head>
<body> 
<p><input type="file" id="fielinput" /></p>
<div id="tips"></div>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YUJIANYUE

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值