上传文件


1.导包(commons-fileupload-1.2.2.jar和commons-io-2.3.jar)
2.写一个jsp页面 uploads.jsp
//method='POST'必须是post enctype='multipart/form-data'必须是multipart/form-data
<form method='POST' action='<%=application.getContextPath() %>/upload' enctype='multipart/form-data'>
<input type='file' name='file_a'><br>
<input type='file' name='file_b'><br>
<input type='submit'>
</form>
3.映射 web.xml
<servlet>
<servlet-name>fileUploads</servlet-name>
<servlet-class>handler.FileUploads</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>fileUploads</servlet-name>
<url-pattern>/upload</url-pattern>
</servlet-mapping>
4.计算sha1码 Md5.java
package handler;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class Md5 {
public static String sha1(byte[] data) {
try {
byte[] sha1data = MessageDigest.getInstance("sha1").digest(data);
return new String(byteToHex(sha1data));
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException(e);
}
}

public static byte[] byteToHex(byte[] bytes) {
final String HEX_CHAR = "0123456789abcdef";
byte[] r = new byte[bytes.length * 2];
for (int i = 0; i < bytes.length; ++i) {
r[i * 2] = (byte) HEX_CHAR.charAt((bytes[i] >>> 4) & 15);
r[i * 2 + 1] = (byte) HEX_CHAR.charAt(bytes[i] & 15);
}
return r;
}

public static void main(String[] args) {
System.out.println(sha1("password".getBytes()));
}
}
5.servlet类 FileUploads.java
package handler;

import java.io.File;
import java.io.IOException;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

public class FileUploads extends HttpServlet{

@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
req.setCharacterEncoding("utf-8");

// 初始化和配置
ServletFileUpload upload = new ServletFileUpload(new DiskFileItemFactory());
upload.setFileSizeMax(1024*1024);//设置单个文件大小
upload.setSizeMax(1024*1024*8);//设置全部文件大小的总和

try {
// 解析请求, 得到文件列表
List<FileItem> items = upload.parseRequest(req);
for (FileItem item : items) {
if(item.getName().isEmpty()){
continue;
}
System.out.println("用户上传的文件名:"+item.getName());
// 确定文件该保存在哪里
System.out.println("getServletContext().getRealPath ==>"+getServletContext().getRealPath("uploads"));
String sha1=Md5.sha1(item.get());
System.out.println("sha1---"+sha1);
File target = new File(getServletContext().getRealPath("uploads")
+ File.separatorChar + sha1);
if(target.exists()){
System.out.println("file exists");
continue;
}
// 保存文件
System.out.println("保存位置:"+target.getAbsolutePath());
item.write(target);
}
} catch (FileUploadException e) {
throw new IOException(e);
}catch (Exception e) {
throw new IOException(e);
}
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值