php ajaxfileupload.js 使用,使用ajaxfileupload.js实现上传文件功能

一直以来上传文件都是使用form表单上传文件,也看到过有人使用js上传文件,不过看起来蛮简单的也就没有怎么去理会。今天突然要使用这种方式上传文件,期间还遇到点问题。因此就记录下来,方便以后遇到这样的问题可以查看。

首先就是引入js和ajaxfileupload的文件,这个不需要多说。

然后就是ajax请求后台地址。代码如下:

选择文件

$("#upload").on("change",function(){

$.ajaxFileUpload({

url : '/test/user/imgUpload',//后台请求地址

type: 'post',//请求方式 当要提交自定义参数时,这个参数要设置成post

secureuri : false,//是否启用安全提交,默认为false。

fileElementId : 'upload',// 需要上传的文件域的ID,即的ID。

dataType : 'json',//服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。如果json返回的带pre,这里修改为json即可解决。

success : function (json, status) {//提交成功后自动执行的处理函数,参数data就是服务器返回的数据。

alert(json.retMsg);

},

error : function (json, status, e) {//提交失败自动执行的处理函数。

}

});

});

前台代码完成就开始开发后台代码了。

package com.roc.test;import java.io.File;import java.util.List;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import javax.ws.rs.Consumes;

import javax.ws.rs.POST;

import javax.ws.rs.Path;

import javax.ws.rs.Produces;

import javax.ws.rs.QueryParam;

import javax.ws.rs.core.Context;

import javax.ws.rs.core.MediaType;

import net.sf.json.JSONObject;

import org.apache.commons.fileupload.FileItem;

import org.apache.commons.fileupload.disk.DiskFileItemFactory;

import org.apache.commons.fileupload.servlet.ServletFileUpload;

import org.jboss.resteasy.annotations.providers.jaxb.json.BadgerFish;

import org.springframework.stereotype.Controller;import net.sf.json.JSONObject;/**

* 上传文件

* @author liaowp

*

*/

@Controller

@Path("/user")

public class UploadImg {

@Path("/imgUpload")

@POST

@Produces("application/json; charset=utf-8")

@Consumes(MediaType.MULTIPART_FORM_DATA )

@BadgerFish

public JSONObject upload(@QueryParam("orderId") String orderId,@Context HttpServletRequest request,@Context HttpServletResponse response) {

JSONObject jsonobj = new JSONObject();

String file_path=request.getSession().getServletContext().getRealPath("/")+File.separator+"corpfile"+File.separator;//文件存储路径

String upload_file_path="";

File file =new File(file_path);

if(!file.exists() && !file.isDirectory()){ //如果文件夹不存在则创建

file.mkdir();

upload_file_path=file_path;

}else{

upload_file_path=file_path;

}

DiskFileItemFactory factory = new DiskFileItemFactory(); // 设置工厂

factory.setRepository(new File(file_path));// 设置文件存储位置

factory.setSizeThreshold(2048 * 1024);// 设置大小,如果文件小于设置大小的话,放入内存中,如果大于的话则放入磁盘中

ServletFileUpload upload = new ServletFileUpload(factory);

upload.setHeaderEncoding("utf-8");// 这里就是中文文件名处理的代码,其实只有一行

String fileName = "";

List list;

JSONObject jsonobj = new JSONObject();

try {

list = upload.parseRequest(request);

for (FileItem item : list) {

if (item.isFormField()) {

String name = item.getFieldName();

String value = item.getString("utf-8");

} else {

String name = item.getFieldName();

String value = item.getName();

fileName =name + ".jpg";

if (item.getSize() > 10485760) {//您好,上传文件要小于10M!

jsonobj.put("retCode","100");

jsonobj.put("retMsg","您好,上传文件要小于10M!"):

} else {//上传成功

item.write(new File(upload_file_path, fileName));

System.out.println(File.separator + "corpfile" + File.separator + fileName);

jsonobj.put("retCode","0");

jsonobj.put("retMsg","您好,上传成功!");

}

}

}

} catch (Exception e) {//上传失败

e.printStackTrace();

jsonobj.put("retCode","9999");       jsonobj.put("retMsg","您好,文件上传失败,");

}

return jsonobj;

}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值