Ajax实现文件上传

利用html5中的file对象利用FormData对象进行上传

前端页面

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Ajax文件上传</title>
</head>
<script type="text/javascript">
function upfile(){
	var pic=document.getElementsByTagName(‘input‘)[0].files;//返回filelist
	pic=pic[0];
	//console.log(pic);//返回file
	var str="文件名称:"+pic.name+"<br/>";
	str+="文件大小:"+pic.size+"字节<br/>";
	str+="文件类型:"+pic.type+"<br/>";
	document.getElementById(‘xinxi‘).innerHTML=str;

	//将上传的文件解析到页面上来
	var img=document.createElement(‘img‘);
	img.src=window.URL.createObjectURL(pic);
	document.getElementsByTagName(‘body‘)[0].appendChild(img);
	up();
}
function up(){
	//alert(‘运行了‘);
	var pic=document.getElementsByTagName(‘input‘)[0].files[0];
	var fd=new FormData();
	var xhr=new XMLHttpRequest();
	xhr.open(‘post‘,‘01.php‘,true);
	xhr.onreadystatechange=function (){
		if(this.readyState==4){
			document.getElementById(‘result‘).innerHTML=this.responseText;
		}
	}
	fd.append(‘pic‘,pic);//添加file对象到FormData对象中
	xhr.send(fd);
}
</script>
<body>
	<div id="result"></div>
    <input type="file" name="pic" onchange="upfile();"/>
	<div id="xinxi"></div>
</body>
</html>

01.php

<?php
//print_r($_FILES);
if($_FILES[‘pic‘][‘error‘]!=0){
	exit(‘上传失败‘);
}
move_uploaded_file($_FILES[‘pic‘][‘tmp_name‘],‘upload/‘.$_FILES[‘pic‘][‘name‘]);//将文件保存到upload目录下
echo ‘上传成功‘;
?>

上传效果

时间: 2024-11-05 14:54:19

Ajax实现文件上传的相关文章

ajax+spring文件上传

1.js代码 $(function(){ $('#upfileID').change(function(){ $.ajaxFileUpload({ url: '/upload/image', type: 'post', secureuri: false, //一般设置为false fileElementId: 'upfileID', // 上传文件的id属性名 dataType: 'text', //返回值类型,一般设置为json.application/json success: functi

ajax提交表单、ajax实现文件上传

ajax提交表单.ajax实现文件上传,有需要的朋友可以参考下. 方式一:利用from表单的targer属性 + 隐藏的iframe 达到类似效果, 支持提交含有文件和普通数据的复杂表单 方式二:使用jquery的$.ajax({..}), 支持提交普通表单,但不支持含有文件的复杂表单; ($.post 或 $.get底层用的都是$.ajax) 方式三:使用jquery插件ajaxFileUpload.js, 支持上传文件,但不支持提交表单 方式四:使用jquery.from.js,支持提交同时

7 款基于 JavaScript/AJAX 的文件上传插件

本文整理了7款基于JavaScript和AJAX的文件上传插件,这些插件基本上都能实现以下功能: 多文件上传 拖拽操作 实时上传进度 自定义上传限制 希望能为你的开发工作带来帮助. 1.  jQuery File Upload 具有多文件上传.拖拽.进度条和图像预览功能的文件上传插件,支持跨域.分块.暂停恢复和客户端图像缩放.可与任何服务端平台(如PHP.Python.Ruby on Rails.Java.Node.js.Go等)一起使用,支持标准的HTML表单文件上传. 2.  Pixelco

基于jsp的AJAX多文件上传的实现

最近的项目开发中,遇到了一个多文件上传的问题,即在不刷新页面的情况下,上传多个文件至服务器.现总结分享如下: 本文主要采用了基于jsp的ajax,jquery,servlet等技术. 1.upload.jsp 点击上传时,调用对应的fileupload函数,通过ajax将文件异步传送到servlet中处理.注意在文件上载时,所使用的编码类型应当是"multipart/form-data",它既可以发送文本数据,也支持二进制数据上载. <%@ page language="

基于jquery的Ajax实现 文件上传

---------------------------------------------------------------遇到困难的时候,勇敢一点,找同学朋友帮忙,找导师求助. Ajax Ajax简介 AJAX(Asynchronous Javascript And XML)翻译成中文就是"异步Javascript和XML".即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML,现在更多使用json数据). 同步交互:客户端发出一个请

AJAX与文件上传

一.ajax ajax(Asynchronous JavaScript And XML):异步JavaScript和XML,即使用JavaScript语句与服务器进行异步交互,传输的数据为XML(也可以是json数据).实际上就是在JavaScript语句里用ajax可以向服务器发送请求. 两大特点: 1,异步交互 2,页面局部刷新 语法: 基于jQuery:<script>$('.cc').click(function(){ #当我们点击'.cc'这个类的时候就会触发ajax请求 $.aja

ajax结合文件上传类进行多文件的单个上传

今天做项目的时候碰见一个问题:之前一个同事离职之前做了一个网站,有一个上传商品详细图片的功能,当时已经完成,但是由于后期程序的有更改以及更改的程序员的水平也是参差不齐,最后导致程序bug很多,由于当时用的是一个框架,最终也没找到说明文档,后来我就重新写了一个结合ajax上传文件的upload.classs.php虽然界面欠缺美观,但是通俗易懂好维护. //首先是页面. index.php <!DOCTYPE html> <html lang="en"> <

SpringMVC案例3----spring3.0项目拦截器、ajax、文件上传应用

依然是项目结构图和所需jar包图: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmVuamFtaW5fd2h4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" > watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmVuamFtaW5fd2h4/font/5a6L5L2T/fontsize/400/fil

JavaWEB+Ajax实现文件上传

准备:我们需要找一张绿色或者其它颜色的背景图,放在photo文件夹里就好哈,然后加jar:common-io和commo-fileupload就可以哈 创建progress.css文件: .pro{   height:15px;   width:500px;   background: #FFFFF0;   border: 1px solid #8FBC8F;   margin: 0;   padding: 0;   display:none;   position: relative;   l