ajax(form)图片上传(spring)
第一步:spring-web.xml

<!--配置上传下载-->
<bean id="multipartResolver" class="org.springframework.web.multipart.support.StandardServletMultipartResolver" />
第二步:后台

@RequestMapping(value = "/bbbbb", method = RequestMethod.POST)
public String imageshangchuan(@RequestPart("xxx") MultipartFile multipartFile, Model model, HttpServletRequest request) {
if (!multipartFile.getContentType().contains("image/")) {
model.addAttribute("err", "只能是图片文件!");
return "/inputfile";
}
if (multipartFile.getSize() > 1024 * 1024 * 5) {
model.addAttribute("err", "只能是5M以下!");
return "/inputfile";
}
//取得相对路径
String basePath = request.getServletContext().getRealPath("/img");
String rekativePath;
try {
rekativePath = makeImagePath(basePath, multipartFile.getOriginalFilename());
File file = new File(rekativePath);
file.getParentFile().mkdir();
multipartFile.transferTo(file);
} catch (IOException e) {
model.addAttribute("err", "上传失败,请重试");
return "/inputfile";
}
return "/index";
}
public String makeImagePath (String basePath, String fileName){
Date date = new Date();
String[] filename = simpleFile(fileName);
return String.format("%s%s%s%supload_%s_%s.%s",
basePath,
File.separator,
new SimpleDateFormat("yyyyMMdd").format(date),
File.separator,
filename[0],
new SimpleDateFormat("hhmmss").format(date),
filename[1]
);
}
public String[] simpleFile (String file){
int sum = file.lastIndexOf(".");
return new String[]{
file.substring(0, sum),
file.substring(sum + 1)
};
}
第三步:web.xml
<multipart-config>
<max-file-size>102400</max-file-size>
</multipart-config>

第四步:jsp
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body> <form:form action="/bbbbb" method="post" enctype="multipart/form-data">
<div style="color: red">
${err}
</div>
<input type="file" name="xxx" />
<input type="submit"/>
</form:form>
</body>
</html>

运行测试

使用ajax
js
function asdsa() {
var formData = new FormData();
formData.append("xxx",document.getElementById("myfile").files[0]);
$.ajax({
url: '/bbbbb',
type: 'POST',
Accept: 'text/html;charset=UTF-8',
cache: false,
contentType:false,
data:formData,
processData: false,
xhr: function () {
myXhr = $.ajaxSettings.xhr();
console.log(myXhr.upload);
if (myXhr.upload) {
myXhr.upload.addEventListener('progress', function (e) {
console.log(e);
var loaded = e.loaded;//已经上传大小情况
var tot = e.total;//附件总大小
var per = Math.floor(100 * loaded / tot); //已经上传的百分比
console.log('附件总大小 = ' + loaded);
console.log('已经上传大小 = ' + tot);
}, false);
}
return myXhr;
}, success: function (data) {
console.log(data);
console.log("上传成功!!!!");
}, error: function () {
console.log("上传失败!");
}
});
}
jsp
<%--
Created by IntelliJ IDEA.
User: Administrator
Date: 2018/11/6
Time: 20:00
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>$Title$</title>
</head>
<script src="css/jquery-1.11.3.js"></script>
<script>
$(function () {
$.get("login.html", {name: "John", time: "2pm"},
function (data) {
console.log(data);
});
})
</script>
<body>
<h1>测试</h1>
<button onclick="asdsa()">测试</button>
<meter id="p1" value="60" max="100">60%</meter>
<input id="myfile" type="file" multiple="multiple"/>
<progress id='progress' style='width:100px' value='0' max='100'>3/10</progress>
<audio controls="controls" src="mp3/白小白%20-%20最美情侣.mp3"/>
<img id="imd" src=""/> <script>
function asdsa() {
var formData = new FormData();
formData.append("xxx",document.getElementById("myfile").files[0]);
$.ajax({
url: '/bbbbb',
type: 'POST',
Accept: 'text/html;charset=UTF-8',
cache: false,
contentType:false,
data:formData,
processData: false,
xhr: function () {
myXhr = $.ajaxSettings.xhr();
console.log(myXhr.upload);
if (myXhr.upload) {
myXhr.upload.addEventListener('progress', function (e) {
console.log(e);
var loaded = e.loaded;//已经上传大小情况
var tot = e.total;//附件总大小
var per = Math.floor(100 * loaded / tot); //已经上传的百分比
console.log('附件总大小 = ' + loaded);
console.log('已经上传大小 = ' + tot);
}, false);
}
return myXhr;
}, success: function (data) {
console.log(data);
console.log("上传成功!!!!");
}, error: function () {
console.log("上传失败!");
}
});
} function da() {
var files = document.getElementById("myfile").files[0]; var read = new FileReader();
read.readAsDataURL(files);
read.onprogress = function (ev) { }
read.onload = function (ev) {
var c = document.getElementById("p1");
c.value = 100;
progress.value = 50;
var c = document.getElementById("imd");
c.src = ev.target.result;
progress.value = 100;
} ; }
</script>
</body>
</html>
项目地址:https://github.com/weibanggang/Picture
ajax(form)图片上传(spring)的更多相关文章
- php form 图片上传至服务器上
本文章也是写给自己看的,因为写的很简洁,连判断都没有,只是直接实现了能上传的功能. 前台: <form action="upload.php" method="PO ...
- python - django 使用ajax将图片上传到服务器并渲染到前端
一.前端代码 <!doctype html> <html lang="en"> <head> <meta charset="UT ...
- Ajax实现文件上传(Spring MVC)
## 前端表单 和 JQuery jsp/html代码 使用JQuery <script src="static/js/jquery-3.4.1.js"></sc ...
- 一般处理程序、Ajax多图片上传带进度条
<!DOCTYPE html><html><head> <meta charset="utf-8" /> <tit ...
- ajax多图片上传demo
<!DOCTYPE html> <html> <head> <title></title> </head> <body&g ...
- jquery Ajax 实现图片上传的功能。
$('#image').on('change', function () { var url = ""; var form = new FormDa ...
- ajax实现图片上传
1.创建formData表单,模拟表单传递数据(formData有兼容性问题) var formData = new FormData();2.获取到相应的元素 var jobName = $(&qu ...
- struts2 使用ajax进行图片上传
第一步:引入一个插件 jquery.form.js /*! * jQuery Form Plugin * version: 3.36.0-2013.06.16 * @requires jQuer ...
- jquery php ajax多图片上传.上传进度,生成缩略图
本例用到其他2个php class.upload.php和 functions.php还有css和js以及img文件 下载地址为www.freejs.net/demo/91/down.zip 演示 J ...
随机推荐
- Hadoop 2.0 安装配置
1. install jdk 2. install hadoop. 安装包hadoop-2.2.0.tar.gz存放在一个目录.并解压. 3. 修改配置文件,一般配置文件在/etc/hadoop下面. ...
- c++中赋值运算符重载为什么要用引用做返回值?
class string{ public: string(const char *str=NULL); string(const string& str); //copy构造函数的参数 ...
- ckeditor(在线文本编辑器)使用教程
ckeditor是一款由javascript编写的富文本网页编辑器,它可以填写文字.插入图片.视频.Excel等富媒体信息,也可以在源码方式下填写内容,在各个网站中应用非常广泛. 下面就来说说cked ...
- python自学-day2(变量、if条件判断、运算符操作)
1.变量 变量只是用于保存内存位置,将变量存储在内存中的作用,方便后面调用,这意味着,在创建变量时会在内存中开辟一个空间. 变量命名规则: 由字母.数字.下划线(_)组成 不能以数字开头 不能使用 P ...
- git使用笔记-基础篇
git使用手册:https://git-scm.com/book/zh/v1/ 一.分支 1.查看所有本地分支 git branch 2.查看所有本地分支和远程分支 git branch -a 3.查 ...
- Git常用配置
Git设置默认用户名和密码 1.进入C:\users\Administrator目录下,通过git bash终端输入touch .git-credentials后回车2.打开生成的.git-crede ...
- spring4 使用websocket
要了解的内容: sockjs,对于低版本的ie等不支持websocket的浏览器,采用js模拟websocket对象的办法来实现兼容(其实也有轮询的情况).sockjs地址 https://githu ...
- http request 字段
Accept: 客户端支持的文件类型, 如果为/表示任何类型 Accept-Encoding: 客户端浏览器支持的文件压缩格式 Accept-Language: 客户端支持的语言 User-Agent ...
- HDU 5351——MZL's Border——————【高精度+找规律】
MZL's Border Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Tota ...
- 用户“Michael-PC\Michael”不具有所需的权限。请验证授予了足够的权限并且解决了 Windows 用户帐户控制(UAC)限制问题。
解决方法:在注册表增加键值 [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System] 新建-选择“D ...