这篇文章主要为大家详细介绍了java使用ajax完成上传文件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了java使用ajax完成上传文件的具体代码,供大家参考,具体内容如下
使用ajax上传文件最重要的就是实例化FormData来进行上传文件:
1、html代码:
<div class="kuang">
<p>文件上传</p>
<div class="san3">
<input type="file" name="fujianID" id="fujianID" onchange="UpdateFile()"/>
<input type = "hidden" name="fujianid" id="file2" />
</div>
</div>
2、ajax请求代码:
<script type="text/javascript">
//上传文件
function UpdateFile(){
var file_fujian = $("input[name='fujianID']").val();//用户文件内容(文件)
// 判断文件是否为空
if ( file_fujian== "") {
layer.msg("青选择上传的附件",{icon:1,time:1000});
return false;
}
//判断文件类型,根据自己需要来做判断
/*var fujianID = file_fujian.substring( file_fujian.lastIndexOf(".") + 1).toLowerCase();
if(fujianID != "xls" && fujianID !="xlsx"&&fujianID !="docx"&&fujianID !="doc"&&fujianID !="txt"){
layer.msg("请选择Execl文或者word文件或者txt文件格式!",{icon:1,time:2000});
return false;
}*/
//判断文件大小
var size1 = $("input[name='fujianID']")[0].files[0].size;
if (size1>104857600) {
layer.msg("上传的附件不能大于100M",{icon:1,time:2000});
return false;
}
boo1 = true;
var type = "file";
var formData = new FormData();//这里需要实例化一个FormData来进行文件上传
formData.append(type,$("#fujianID")[0].files[0]);
$.ajax({
type:'POST',
url:'<%=request.getContextPath()%>/login/fujian_file',
data:formData,
async:false,
processData:false,
contentType:false,
success:function(data){
if (data=="error") {
layer.msg("附件添加失败",{icon:1,time:2000});
}else{
$("#file2").val(data.list);
layer.msg("附件已添加",{icon:1,time:2000});
}
}
});
}
3、Java后台数据处理代码:
/**
* 上传文件
* @param file
* @param model
* @param request
* @return
*/
@RequestMapping(value="/fujian_file")
@ResponseBody
public Map<String, Object> uploadToUser(@RequestParam("file") MultipartFile file, Model model,HttpServletRequest request) {
String fileName = file.getOriginalFilename();
if (fileName.indexOf("\\") != -1) {
fileName = fileName.substring(fileName.lastIndexOf("\\"));
}
//String filePath = request.getContextPath()+ File.separator+"WebRoot"+ File.separator+"updatefile"+ File.separator;
// 获取项目名称,文件上传位置
String filePath = request.getSession().getServletContext().getRealPath("/static/updatefile/files");
File f = new File(filePath);
if (!f.exists()) {
f.mkdirs();// 不存在路径则进行创建
}
FileOutputStream out = null;
try {
// 重新自定义文件的名称
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
String d = sdf.format(date);// 时间
//拼接文件路径和文件名
filePath = filePath +File.separator+ d + fileName;
out = new FileOutputStream(filePath);
out.write(file.getBytes());
out.flush();//清空缓冲区的数据流
out.close();//关闭流
} catch (Exception e) {
//System.out.println(e); //打印抛出的异常
}
Map<String,Object> map = new HashMap<String,Object>();
map.put("list",filePath );
return map; // 返回文件地址
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。
沃梦达教程
本文标题为:java使用ajax完成上传文件
基础教程推荐
猜你喜欢
- Java实现查找文件和替换文件内容 2023-04-06
- Java并发编程进阶之线程控制篇 2023-03-07
- JDK数组阻塞队列源码深入分析总结 2023-04-18
- Java文件管理操作的知识点整理 2023-05-19
- java实现多人聊天系统 2023-05-19
- springboot自定义starter方法及注解实例 2023-03-31
- ConditionalOnProperty配置swagger不生效问题及解决 2023-01-02
- java基础知识之FileInputStream流的使用 2023-08-11
- Java数据结构之对象比较详解 2023-03-07
- Java实现线程插队的示例代码 2022-09-03