java web文件上传-无框架
2015-06-30 22:37
537 查看
一、不借助任何的外部工具上传文件(全是数据流,处理太麻烦)
1、创建一个web工程,写一个jsp页面,页面中包含如下代码
2、创建一个servlet,接收前台传递的数据,如果我们在servelt中使用request,getParameter()
获取username或者tmpFile,我们发现获取的值都是null,各位如果不信可以试试看看。为什么会出现这种情况呢?
因为我们在表单中使用了enctype="multipart/form-data",这样的设置让我们传递到后台的数据都是二进制的形式,
我们必须知道每一数据有多长才能准确的解析出来。当然,这样的方式是很麻烦的,我们没有那么多的时间去这么做.
既然这样,那么我们如何解决这样的问题呢,各位不用着急,因为别人已经为我们考虑到了这一点。
现在我们可以用FileUpload或者是smartupload上传组件更加方便的上传文件,当然这种方便也仅仅是相对而言,详细的请看(二)。
二、FileUpload文件上传组件
此处对于smartupload组件不多说,因为本人也没事用过,不是太了解,此处推荐FileUpload组件。
1、下载FileUpload组件支持jar包:
commons-fileupload-1.2.1.jar
commons-io-1.4.jar
下载地址:http://yunpan.cn/cQXIVF4eHrm6r
访问密码 d5e7
2、创建web工程,编写jsp页面,jsp页面内容如下:
解压commons-fileupload-1.2.1-bin.zip,打开commons-fileupload-1.2.1-bin\commons-fileupload-1.2.1\site下的index.html
该API中提供了两种上传文件的方式:User Guide、Streaming API
两种方式都可以,但是User Guide相对后者稍显复杂,所以使用Streaming API,对于前者,大家可以没事的时候,琢磨一下。
4、根据Streaming API提示,在创建的UploadServlet.java中编写上传文件代码,内容如下:
6、此时我们便可以打开浏览器进行上传文件测试了,相信应该是没有问题的。
三、log4j日志记录功能
项目中使用了日志记录功能,该功能并不复杂,此处介绍如何使用,至于其原理希望读者自己百度了。
1、导入日志相关jar包:log4j-1.2.11.jar以及将log4j.properties放置src目录下。
下载地址:http://yunpan.cn/cQXiS4acYW6Dt 访问密码 bd83
2、log4j.properties中配置如下:
1、创建一个web工程,写一个jsp页面,页面中包含如下代码
<form action="<%=basePath%>/upload" method="post" enctype="multipart/form-data"> 用户:<input type="text" name="username"/><br/> 上传文件:<input type="file" name="tmpFile"/><br/> <input type="submit" value="提交"/> </form>
2、创建一个servlet,接收前台传递的数据,如果我们在servelt中使用request,getParameter()
获取username或者tmpFile,我们发现获取的值都是null,各位如果不信可以试试看看。为什么会出现这种情况呢?
因为我们在表单中使用了enctype="multipart/form-data",这样的设置让我们传递到后台的数据都是二进制的形式,
我们必须知道每一数据有多长才能准确的解析出来。当然,这样的方式是很麻烦的,我们没有那么多的时间去这么做.
既然这样,那么我们如何解决这样的问题呢,各位不用着急,因为别人已经为我们考虑到了这一点。
现在我们可以用FileUpload或者是smartupload上传组件更加方便的上传文件,当然这种方便也仅仅是相对而言,详细的请看(二)。
二、FileUpload文件上传组件
此处对于smartupload组件不多说,因为本人也没事用过,不是太了解,此处推荐FileUpload组件。
1、下载FileUpload组件支持jar包:
commons-fileupload-1.2.1.jar
commons-io-1.4.jar
下载地址:http://yunpan.cn/cQXIVF4eHrm6r
访问密码 d5e7
2、创建web工程,编写jsp页面,jsp页面内容如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>3、提供的下载文件为commons-fileupload-1.2.1-bin.zip、commons-io-1.4-bin.zip
<%
String path=request.getContextPath();
String basePath=request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path;
%>
<!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=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<form action="<%=basePath%>/upload" method="post" enctype="multipart/form-data"> 用户:<input type="text" name="username"/><br/> 上传文件:<input type="file" name="tmpFile"/><br/> <input type="submit" value="提交"/> </form>
</body>
</html>
解压commons-fileupload-1.2.1-bin.zip,打开commons-fileupload-1.2.1-bin\commons-fileupload-1.2.1\site下的index.html
该API中提供了两种上传文件的方式:User Guide、Streaming API
两种方式都可以,但是User Guide相对后者稍显复杂,所以使用Streaming API,对于前者,大家可以没事的时候,琢磨一下。
4、根据Streaming API提示,在创建的UploadServlet.java中编写上传文件代码,内容如下:
package com.wonder.servelt; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStreamWriter; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.log4j.Logger; import org.apache.log4j.spi.LoggerFactory; import org.apache.tomcat.util.http.fileupload.FileItemIterator; import org.apache.tomcat.util.http.fileupload.FileItemStream; import org.apache.tomcat.util.http.fileupload.servlet.ServletFileUpload; import org.apache.tomcat.util.http.fileupload.util.Streams; /** * * @author Administrator * 基本的文件上传 * */ @WebServlet("/UploadServlet") public class UploadServlet extends HttpServlet { private static final long serialVersionUID = 1L; private static final Logger logger=Logger.getLogger(UploadServlet.class); protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request, response); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //判断是否包含文件 boolean isMultipart=ServletFileUpload.isMultipartContent(request); //创建文件输出流 FileOutputStream fos=null; InputStream ips=null; try { if(isMultipart){//包含文件 ServletFileUpload sfUpload=new ServletFileUpload(); FileItemIterator fiIterator=sfUpload.getItemIterator(request); while(fiIterator.hasNext()){ FileItemStream item=fiIterator.next(); //获取字段名称 String fieldName=item.getFieldName(); //打开流 ips=item.openStream(); if(item.isFormField()){//表单字段,即普通字段 logger.debug("fieldName:"+fieldName+",with value="+Streams.asString(ips)); }else{//文件域 //设置文件保存路径 String savePath=request.getSession().getServletContext().getRealPath("/upload")+"/"; savePath+=item.getName(); logger.debug("文件保存完整路径:"+savePath); //创建文件 File saveFile=new File(savePath); if(!saveFile.exists()){//判断文件是否存在 saveFile.createNewFile(); } fos=new FileOutputStream(saveFile); int len=-1; byte[] data=new byte[1024]; while((len=ips.read(data))>0){ fos.write(data,0,len); } logger.debug("fieldName:"+fieldName+",with filename="+item.getName()); } } } } catch (Exception e) { logger.error("Exception:",e); e.printStackTrace(); }finally{ //关闭输入流 ips.close(); //关闭输出流 fos.close(); } } }5、web.xml中配置
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5"> <servlet> <servlet-name>uploadServlet</servlet-name> <servlet-class>com.wonder.servelt.UploadServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>uploadServlet</servlet-name> <url-pattern>/upload</url-pattern> </servlet-mapping> </web-app>
6、此时我们便可以打开浏览器进行上传文件测试了,相信应该是没有问题的。
三、log4j日志记录功能
项目中使用了日志记录功能,该功能并不复杂,此处介绍如何使用,至于其原理希望读者自己百度了。
1、导入日志相关jar包:log4j-1.2.11.jar以及将log4j.properties放置src目录下。
下载地址:http://yunpan.cn/cQXiS4acYW6Dt 访问密码 bd83
2、log4j.properties中配置如下:
log4j.rootLogger=debug,myconsole log4j.appender.myconsole=org.apache.log4j.ConsoleAppender log4j.appender.myconsole.Target=System.out log4j.appender.myconsole.Threshold=DEBUG log4j.appender.myconsole.layout=org.apache.log4j.SimpleLayout3、此时就可以在项目使用了,此处配置的日志级别为debug,也就是说debug级别之上的日志信息都将被打印。
相关文章推荐
- java常用集合
- java中的list集合
- JAVA “Run as administrator” “UAC disabled” alternative solution
- Java - JSON Data Operation
- 正则表达式,Java反射相关
- Eclipse插件-PatternBox
- spring+struts+hibernate
- java自带的MD5加密 以及jsMD5加密
- 如何理解: java的import ???
- 软件包javax.servlet不存在的解决办法
- javaweb——Filter(过滤器)学习
- java多线程通信同步之多Condition通信
- Struts2(九)OGNL表达式
- java 对象排序
- Java实现websocket
- java多线程之线程间同步通信
- 我们如何看Java的开发环境???
- @Autowired和@Resource装配
- struts的titles框架
- spring mvc 数据绑定 400错误