上传文件

本文介绍了一个使用Java Web实现多文件上传的应用案例,包括必要的依赖包、JSP页面设计、Web配置、SHA1加密算法实现及Servlet处理流程。通过此教程,读者可以学习如何搭建文件上传功能,并确保文件内容的安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


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);
}
}
}
内容概要:本文深入解析了扣子COZE AI编程及其详细应用代码案例,旨在帮助读者理解新一代低门槛智能体开发范式。文章从五个维度展开:关键概念、核心技巧、典型应用场景、详细代码案例分析以及未来发展趋势。首先介绍了扣子COZE的核心概念,如Bot、Workflow、Plugin、Memory和Knowledge。接着分享了意图识别、函数调用链、动态Prompt、渐进式发布及监控可观测等核心技巧。然后列举了企业内部智能客服、电商导购助手、教育领域AI助教和金融行业合规质检等应用场景。最后,通过构建“会议纪要智能助手”的详细代码案例,展示了从需求描述、技术方案、Workflow节点拆解到调试与上线的全过程,并展望了多智能体协作、本地私有部署、Agent2Agent协议、边缘计算插件和实时RAG等未来发展方向。; 适合人群:对AI编程感兴趣的开发者,尤其是希望快速落地AI产品的技术人员。; 使用场景及目标:①学习如何使用扣子COZE构建生产级智能体;②掌握智能体实例、自动化流程、扩展能力和知识库的使用方法;③通过实际案例理解如何实现会议纪要智能助手的功能,包括触发器设置、下载节点、LLM节点Prompt设计、Code节点处理和邮件节点配置。; 阅读建议:本文不仅提供了理论知识,还包含了详细的代码案例,建议读者结合实际业务需求进行实践,逐步掌握扣子COZE的各项功能,并关注其未来的发展趋势。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值