`

博客系统之文件上传

 
阅读更多

一个博客系统中,图片的上传时必不可少的。

 

<form action="<%=URL%>/PhotoAction.action?action=upload" method="post" 
		  enctype="multipart/form-data">

  这是一个文件上传的表单的form项,enctype属性规定在发送到服务器之前应该如何对表单数据进行编码,一般默认是在发送表单前编码所有字符,默认值是”application/x-www-form-urlencoded”,我们进行文件上传时,不用编码,所以我们的设置值为multipart/form-data,因为对于文件上传的过程中是将文件以流的形式提交到服务器端的。

 

 

<input type="file" name="upfile">

  然后inputtypefile,表示上传文件,nameupfile

 

文件上传的表单时代码是这样:

 

<form action="<%=URL%>/PhotoAction.action?action=upload" method="post" 
		  enctype="multipart/form-data">
	<!--  <input type="hidden" name="action" value="upload">  -->
		<div>
			<table>
			<tr>
				<td>
					<input type="file" name="upfile">
				</td>	
			</tr>
			<tr>
				<td>
					<label for="photoInfo">图片描述:</label>
			<input type="text" id="photoInfo" name="photoInfo">
				</td>	
			</tr>
			<tr>
				<td>
					<input type="submit" value="上传">
				</td>	
			</tr>
			</table>
		</div>
		
	</form>

  表单弄好了我们就可以上传了,一般地,我们用servlet来处理文件上传。一般我们如果是直接获取上传的输入流后,再解析里面的请求参数是很麻烦的,处理不好可能会使保存的文件出现错误。

 

就比如下面这个例子,我们把这个表单上传的内容全部输出看看是什么样的结构:

 

String getAction = request.getParameter("action");
		if (getAction != null && (getAction.equals("upload"))) // 上传文件
		{
			// 定义上传的最大文件字节数1M
			int MAX_SIZE = 1024000;
			String rootPath;
			//输入流
			DataInputStream in = null;
			//文件输出流
			FileOutputStream fileOut = null;
			String remoteAddr = request.getRemoteAddr();
			String serverName = request.getServerName();
			String realPath = request.getRealPath("/");
			realPath = realPath.substring(0, realPath.lastIndexOf("\\"));
			// 设置保存文件的目录
			rootPath = realPath + "\\upload\\telRecord\\";
			// 取得客户端上传的数据类型
			String contentType = request.getContentType();
			if (contentType.indexOf("multipart/form-data") >= 0) {
				try {
					//获取request的输入流,并创建DataInputStream流
					in = new DataInputStream(request.getInputStream());
					//获取内容大小
					int formDataLength = request.getContentLength();
					if (formDataLength > MAX_SIZE) {
						//大于限制则禁止上传
						String url = "error.jsp";
						return url;
					}
					// 用dateBytes保存上传的文件数据
					byte dateBytes[] = new byte[formDataLength];
					int byteRead = 0;
					int totalRead = 0;
					//读取表单所有内容
					while (totalRead < formDataLength) {
						byteRead = in.read(dateBytes, totalRead, formDataLength);
						//读取内容,并保存在dateBytes里面
						totalRead += byteRead;
					}
					String data = new String(dateBytes, "UTF-8");
					//把表单的内容转成utf-8
					System.out.println(data);
					//输出内容
					
					
					//后面的是如何截取表单中的文件内容,并把内容存入文件
					//的操作但是我们必须是对dateBytes截取,不能是data,
					//因为必须是非编码内容,如果是转成了string的data,估计
					//已经对其编码了,如果我们截取data,那可能会乱码的。
					
					//后面的步骤就省略了
					String url = this.adminSelectPhoto(request, response);
					return url;

				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		}
		String url = "error.jsp";
		return url;

  我们上传的表单是这样设置的:

我们点击上传后。

  这是我们输出的表单内容的最前面的一部分:

  这是我们输出表单内容的最后面的一部分:

  我们会发现,我们上传的表单的内容是用

  这个字符串来隔开的,它把上传文件和图片描述输入框这两部分内容分割开来,而且整个表单开始也是用这个字符串。

  整个表单结束是

  这个字符从结束的

 

  首先第一个是文件


 
 文件名是123.jpg.

  ?PNG及其后面这些乱码就是文件内容。

 

  然后是我们的图片描述的输入,我们输入的是123,

  可以看出,我们的输入框的名字photoInfo,内容是123。

  看到这里,我们已经明白了怎么把文件内容取出来了,这整个表单内容,我们只要截取文件内容那一段,然后把它保存到文件里面就ok了,但是我们一般不宜采取string的格式来寻找文件内容,应该是按照比较原始的byte的格式来截取,转成string后来弄的话,会造成我们保存的文件出现问题。截取表单中的文件内容,并把内容存入文件的操作,我们必须是对dateBytes截取,不能是data,因为必须是非编码内容,如果是转成了string的data,估计已经对其编码了,如果我们截取data,那可能会乱码的。

所以我们一般采用apache的开源工具common-fileupload这个文件上传组件,然后common-fileupload是依赖于common-io这个包的,所以还要下载这个包。

 

然后这两个包放在项目的WebContent/WEB-INF/lib文件夹里面:


 
 然后我们处理上传的代码如下:

// 获得目前登录的博主的id
		HttpSession session = request.getSession();
		MasterBean master = (MasterBean) session.getAttribute("masterBean");
		int masterID = master.getId();
		File file;
		// 上传文件的最大值
		int maxFileSize = 5000 * 1024;
		// 内存中存储文件的最大值
		int maxMemSize = 5000 * 1024;
		// 为了设置文件存储路径,我们先获取该类PhotoAction.Java在web项目下的路径
		URL url_photoAction = this.getClass().getResource("PhotoAction.class");
		System.out.println(url_photoAction);
		// 将URL类型的路径转换成String类型,方便后面利用indexOf方法对路径进行截取
		String str_url_photoAction = url_photoAction.toString();
		System.out.println(str_url_photoAction);
		// 由于url_photoAction的路径是D:\JavaWeb\tomcat\wtpwebapps\MyBlog\WEB-INF\classes\com\MyBlog\action_implements
		// 自己希望存储的路径为D:\JavaWeb\tomcat\wtpwebapps\MyBlog\images\photo
		// 因此需要进行路径截取,以及配置,找到所需路径的最后一个位置的坐标
		int pos = str_url_photoAction.indexOf("WEB-INF");
		// 通过pos值。截取,先获得web服务器所在的根路径
		String rootPath = str_url_photoAction.substring(6, pos);
		// 设置自己想要存储的相对路径
		String relativePath = "images/photo";
		// 最后,设置文件存储路径
		String filePath = rootPath + relativePath;
		System.out.println(filePath);
		System.out.println("action=" + request.getParameter("action"));

		// 验证上传内容了类型
		String contentType = request.getContentType();
		if ((contentType.indexOf("multipart/form-data") >= 0)) {
			// 如果上传的是"multipart/form-data",即不编码的内容,那么久处理,

			// 创建一个DiskFileItemFactory工厂,
			// 这个类的作用就是把文件内容临时保存到内存中
			DiskFileItemFactory factory = new DiskFileItemFactory();
			// 设置内存中存储文件的最大值
			factory.setSizeThreshold(maxMemSize);
			// 当内存中存储的数据大于 maxMemSize,那么保存到磁盘中,
			// 所以这里设置用于存放临时文件的存放路径
			factory.setRepository(new File("c:\\temp"));

			// 创建一个新的文件上传解析器
			// 把刚刚创建的factory传进去,
			// 因为这个ServletFileUpload依赖于
			// DiskFileItemFactory工厂
			ServletFileUpload upload = new ServletFileUpload(factory);
			// 设置最大上传的文件大小
			upload.setSizeMax(maxFileSize);
			try {
				// 解析获取的文件,解析结果返回的是一个List<FileItem>集合,
				// 每一个FileItem都对应一个form表单的ipnutx项。
				List fileItems = upload.parseRequest(request);

				// 处理上传的文件。先获取fileItems迭代器
				Iterator i = fileItems.iterator();
				while (i.hasNext()) {// 遍历整个迭代器
					FileItem fi = (FileItem) i.next();
					// 获取fileItems中的一项的内容,并强制转换为FileItem
					if (!fi.isFormField()) {
						// 这里是判断这个input项是不是非普通输入,即是文件输入

						// 获取上传的文件名字,因为上传过程中,可能会在原文件
						// 上面添加一些附加的信息,所以截掉"\\"前面的所有字符以及"\\"
						String fileName = fi.getName();
						// 写入文件
						if (fileName.lastIndexOf("\\") >= 0) {
							file = new File(filePath, fileName.substring(fileName.lastIndexOf("\\")));
						} else {
							file = new File(filePath, fileName.substring(fileName.lastIndexOf("\\") + 1));
						} // 对文件名字进行处理

						System.out.println(">>>>>>>>>>" + file);
						if (!file.exists())
							file.createNewFile();// 如果文件不存在,先创建文件

						fi.write(file);// 将内容写入文件
						// out.println("Uploaded Filename: " + filePath +
						// fileName + "<br>");
						// 获取页面上面的关于图片的描述信息
						String photo_info = request.getParameter("photoInfo");
						System.out.println("photoInfo:" + photo_info);
						PhotoBean photoBean = new PhotoBean();
						photoBean.setPhotoAddr("/images/photo/" + fileName);
						photoBean.setPhotoSdTime(Common.changeTime(new Date()));
						if (photo_info == null || photo_info.equals("")) {
							// 若页面没有添加图片描述信息,则默认为文件名作为描述信息
							photoBean.setPhotoInfo(fileName);
						} else {
							photoBean.setPhotoInfo(photo_info);
						}
						photoBean.setMasterID(masterID);
						PhotoDao photoDao = new PhotoDao();
						boolean flag = photoDao.operationPhoto("upload", photoBean);
						if (flag) {
							String url = this.adminSelectPhoto(request, response);
							return url;
						}
					}
				}
			} catch (Exception ex) {
				ex.printStackTrace();
			}
		}
		String url = "error.jsp";
		return url;

 

  这里面涉及到一个迭代器的使用。

List的迭代器的用法如下:  

 Iterator it = list.iterator();

    while (it.hasNext()) {

        personnelID= (String) it.next();

//这里一般要强制转换会原来的数据类型,因为这里返回的是object类型。

    }

1)使用iterator()方法可使list返回一个迭代器It

2)it第一次调用next方法会返回list的第一个元素。

3)hasnext是判断是否存在下一个元素。

4)next方法获取下一个元素,并把这个迭代器移到这个元素的位置上。

  这样不断循环,直到下一个没有元素,退出循环,达到遍历list的目的。

 

 

 

 

 

  • 大小: 5.9 KB
  • 大小: 71.8 KB
  • 大小: 20.1 KB
  • 大小: 4.7 KB
  • 大小: 7.8 KB
  • 大小: 5 KB
  • 大小: 79.1 KB
  • 大小: 6.3 KB
  • 大小: 21 KB
分享到:
评论

相关推荐

    基于ThinkPHP 6 和 LayUI 框架 的博客管理系统,用户登录注册包含验证码,博客文件上传,博客文章的crud

    基于ThinkPHP 6 和 LayUI 框架 的博客管理系统,用户登录注册包含验证码,博客文件上传,博客文章的crud,用户个人信息的crud,jquery操作dom的ajax回调,博客文章上传的加密操作,用户密码加密,用户的登出。...

    免费个人博客系统(兼多用户博客系统)

    免费个人博客系统(兼多用户博客系统)是支持一个空间2个网站的全能型网站管理系统,本免费个人博客系统通用和拓展性强,博客、文章系统、商城、企业网站、个性化论坛等类型网站都可以使用,将来网站无论如何转型或...

    Folk博客系统 asp博客系统 nodejs博客系统 基于nodejs的博客系统

    而强大的插件系统,则可以让您在Folk的基础上,扩展出您所能想像的任何功能,甚至将她变成一个cms系统。 Folk默认使用markdown语法来撰写日志,但是Folk也支持通过插件来使用可视化的html编辑器,让您自由选择、随心...

    侯爷轻博客系统 v1.30.rar

    一、请将本目录下所有文件上传到空间根目录,如在本地调试请放到相应目录下; 二、执行install/install.php安装 三、安装完成后登陆后台管理,后台目录为backweb/ 四、后台用户名和密码:admin 五、修改系统管理...

    数据库应用课程设计报告-博客管理系统.doc

    5) 博客系统应为博客用户提供文件上传功能, 包括博客用户可以上传自己喜欢的文件,下载已上传的文件,删除已上传的文件 的。在该页面中,还可以显示已使用的空间。 6) 博客系统应为博客用户提供文章分类管理功能,...

    PJBlog4博客系统

    5. 开放在线安装更新功能,时刻与官方一起维护我们的博客系统。 全新安装: 1.下载PJBlog最新本程序,解压压缩包文件; 2.将install.asp和setup文件夹上传至服务器; 3.浏览器运行http://你的域名/install.asp,...

    冠格空间博客系统 4.2 开源版.rar

    冠格空间博客系统是目前采用Asp.Net2.0+Access/Sql Server 2005技术实现的空间博客,兼容Firefox、IE等多种主流浏览器。个人空间页面可用鼠标进行拖拽排版,20多套的皮肤可供选择,包括版式、隐藏模块、鼠标样式、...

    sharetronix微博客系统 v3.4.zip

    Sharetronix是一款免费开源微博客系统,多国语言版,默认是英文,后台设置可以选择简体或繁体中文,共支持包括简繁中文在内的21种语言。   Sharetronix (blogtronix) 作为一个多媒体微博客平台,具备微博客必备的...

    多用户博客系统源码

    LxBlog 多用户博客个人主页系统,一套基于php+mysql 数据库平台架构的多用户博客系统,该系统融合了Blog的最新元素,拥有强大的个人主页系统,独立的二级域名功能,灵活的用户模版系统,丰富的朋友圈和个性相册功能...

    javaweb博客系统(纯手写,无框架)

    本人2年前手写的web博客系统,功能简单,可以发布文章、添加好友、发表评论、上传照片等,可供学习javaweb的初级程序员参考,内附数据库脚本文件blogs.sql,使用mysql数据库,不使用任何框架,由servlet完成功能跳转

    基于J2EE框架的个人博客系统项目毕业设计论...

    该在线博客系统服务器端如果需要布置到其他主机上,则该主机必备条件如下: 1. 服务器端操作系统:独立于操作系统的跨平台系统,客户端MicroSoft Windows 2000及以上; 2. 数据库:MySQL 5.0.27版本; 3. Web...

    自写博客系统

    (1)单击“博客文章管理”/“发表博客文件”按钮,对博客文章进行添加操作。 (2)单击“博客文章管理”/“博客文章设置”按钮,对博客文章进行查看、修改及删除操作。 (3)单击“博客文章管理”/“文章分类”按钮...

    个人博客系统基于JSP和SSM框架.zip

    本系统是一个实用的个人博客网站,集博客、留言板、链接于一身。未注册用户(访客)可以浏览文章,发表评论及留言。也可以通过注册成为该系统的注册用户,注册用户可以管理自己的博客、留言板、友情链接等,同时还可以...

    秀品博客系统 1.0.rar

    秀品博客系统使用ASP.NET MVC4 code first方式开发,使用SimpleMembership保存用户信息。程序及其简单,只有基本的管理员登录后台,发布文章,前台显示功能。和其他博客系统强大的功能没法比,开发此系统的目的仅供...

    简单的博客系统-SSH

    完整的个人博客系统,有上传文件的功能。详细的代码和实现,使用Struts2+Spring+ hibernate技术,。

    Roclog v5.0.26.2 简洁轻便个人博客系统.rar

    欢迎您使用本人开发的 Roclog 个人博客系统,本系统融合了我的心血和时间,希望能让您在使用中感受到我的热情和它带给您的愉快! 首先要欢迎 Roclog 的新用户——您,加入到这个大家族中来。我是该项目负责人,我...

    永丫个人博客系统 1.3.rar

    1、后台添加文件上传功能; 2、后台添加数据库管理功能; 3、后台结构优化; 4、主题优化,清除所有广告内容; 5、开发新的主题; 永丫个人博客系统在继承永丫个人博客系统一贯风格的基础上,Mango又对此系统...

    基于SpringBoot Thymeleaf的超漂亮的博客系统源码.zip

    基于SpringBoot Thymeleaf的超漂亮的博客系统源码.zip 完整代码,可运行 。 项目背景 对于刚学习springboot的同学,最好的就是拿一个...支持文件上传 支持删除已上传的文件 友情联机 支持增加友情链接 支持删除友情链接

    Java个人博客系统(含数据库)

    个人博客系统,采用jsp+hibernate+mvc 编写,可实现用户注册,登录。日志的发表,删除,修改。回复评论。上传下载文件等等。

    GBlog好文本博客系统 v2.0

    好文本个人博客系统(GBlog)吸取之前版本的经验,更重视生成更新速度、易用性和内部调用的改进,尽量做到一次生成多次调用,有效地降低了更新生成文件的数量使性能和用户体验得到改善。 好文本个人博客系统...

Global site tag (gtag.js) - Google Analytics