文件上传

本文探讨了三种图片上传方案:上传至Tomcat服务器、指定文件目录并映射服务器路径、存储于数据库二进制字段。分析了各方案优劣,并详细介绍了通过Struts框架实现图片上传的具体步骤,包括JSP页面设计、文件复制方法及服务器映射配置。

文件上传:
三种上传方案
1、上传到tomcat服务器 上传图片的存放位置与tomcat服务器的耦合度太高
2、上传到指定文件目录,添加服务器与真实目录的映射关系,从而解耦上传文件与tomcat的关系
文件服务器
3、在数据库表中建立二进制字段,将图片存储到数据库

第一种文件上传基本上不用了需要刷新才能看到图片
tomcat关掉再次启动的时候图片就看不到了!
上传图片存放的位置与tomcat服务器的耦合度太高
第三种图片流量太大也不行!
我们首先要建立一个jsp用于图片上传的

clzUpload.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>图片上传</title>
</head>
<body>
<form action="${pageContext.request.contextPath}/sy/clz_upload.action" method="post" enctype="multipart/form-data">
	<input type="hidden" name="cid" value="${result.cid }"><br>
	<input type="hidden" name="cname" value="${result.cname }"><br>
	<input type="hidden" name="cteacher" value="${result.cteacher }"><br>
	<input type="file" name="file">
	<input type="submit" value="提交">
</form>
</body>
</html>

然后这里接下来我们来写图片上传的方法

//	这里的属性名要和name对应 xxx
	private File file;
//	xxxFileName
	private String fileFileName;
//	xxxContentType
	private String fileContentType;
	/**
	 * 跳转上传图片的界面
	 * @return
	 */
	public String preUpload() {
			try {
				this.result= this.clazzDao.list(clz, null).get(0);
			} catch (InstantiationException | IllegalAccessException | SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		return "preUpload";
		
	}
	
	public String upload(){
		String realDir = "E:/T226";
		String serverDir = "/upload";
		try {
			copyFile(file, new File(realDir+"/"+fileFileName));
			//			FileUtils.copyFile(file, new File(realDir+"/"+fileFileName));
			clz.setPic(serverDir+"/"+fileFileName);
				try {
					this.clazzDao.edit(clz);
				} catch (NoSuchFieldException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (SecurityException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (IllegalArgumentException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (IllegalAccessException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				} catch (SQLException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return "toList";
	
}
	/**
	 * 利用缓存流技术进行拷贝
	 * @param source
	 * @param target
	 * @throws IOException 
	 */
	public void copyFile(File source,File target) throws IOException {
		BufferedInputStream in =new BufferedInputStream(new FileInputStream(source));
		BufferedOutputStream out =new BufferedOutputStream(new FileOutputStream(target));
		byte[] bbuf =new byte[1024];
		int len = 0;
		while((len = in.read(bbuf))!=-1) {
			out.write(bbuf, 0, len);
		}
		in.close();
		out.close();
	}
	
	public File getFile() {
		return file;
	}
	public void setFile(File file) {
		this.file = file;
	}
	public String getFileFileName() {
		return fileFileName;
	}
	public void setFileFileName(String fileFileName) {
		this.fileFileName = fileFileName;
	}
	public String getFileContentType() {
		return fileContentType;
	}
	public void setFileContentType(String fileContentType) {
		this.fileContentType = fileContentType;
	}

那个缓存流是我们自己写的方法同样也可以实现图片上传而且性能也比自带的要好!!

struts-sy.xml文件配置:

			<result name="preUpload">/clzUpload.jsp</result>

那边jsp页面的跳转我就不说了
还有一个最重要的就是Servers
在这里插入图片描述
需要添加服务器与真实目录的映射关系!

		<Context path="/chenkang_struts/upload" docBase="E:/T226"/>

前面要写当前的项目名!!
运行结果
在这里插入图片描述
后台的数据库也改了。。
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值