jsp上传的一个很好的例子

文件上传原理简单实现  
 
 
 
要实现文件上载,我们必须先了解上载文件的HTTP请求。下面这个简单的应用示范了如何上载文件以及把HTTP请求的原始数据写入文件。用文本编辑器查看该文件即可了解请求的格式,在此基础上我们就可以提取出上载文件的名字、文件内容以及原本混合在一起的其他信息。    
 
在这里我们写一个简单的html页面up.html,提供一个表单,用户从这里选择文件并把文件上载到服务器。    
 
<html>    
 
<head>    
 
<title>文件上载</title>    
 
</head>    
 
<body>    
 
<form  action="upjsp.jsp"  enctype="MULTIPART/FORM-DATA"  method=post>    
 
<br  />    
 
公司:  <input  type="text"  name="company"  />    
 
<br  />    
 
选择要上载的文件  <input  type="file"  name="filename"  />    
 
<br  />    
 
<input  type="submit"  value="上载"  />    
 
</form>    
 
</body>    
 
</html>    
 
注意,<form>标记有一个enctype属性,属性值是"MULTIPART/FORM-DATA"。还有个type为file的输入框是用来选择上传文件的。    
 
表单的action属性值是upjsp.jsp,这是将请求发送给upjsp.jsp文件。upjsp.jsp调用了名为UpBean的JavaBean。    
 
程序如下:    
 
<jsp:useBean  id="TheBean"  scope="page"  class="UpBean  "  />    
 
<%    
 
TheBean.doUpload(request);    
 
%>    
 
 
 
  下面是UpBean的实现代码:    
 
import  java.io.*;    
 
import  javax.servlet.http.HttpServletRequest;    
 
import  javax.servlet.http.HttpServletResponse;    
 
import  javax.servlet.ServletInputStream;    
 
 
 
public  class  UpBean  {    
 
 
 
public  void  doUpload(HttpServletRequest  request)  throws    
 
IOException  {    
 
PrintWriter  pw  =  new  PrintWriter(    
 
new  BufferedWriter(new  FileWriter("test.txt")));    
 
ServletInputStream  in  =  request.getInputStream();    
 
 
 
int  i  =  in.read();    
 
while  (i  !=  -1)  {    
 
pw.print((char)  i);    
 
i  =  in.read();    
 
}    
 
pw.close();    
 
}    
 
}    
 
这个JavaBean把HttpServletRequest对象的表单原始数据写入test.txt文件.    
 
选择上传一个文本或者网页文件。点击“上载”按钮之后,表单就发送给了upjsp.jsp文件,一起发送的还有上传的文件。upjsp.jsp文件不会向浏览器发送任何应答内容,但它会生成一个test.txt文件。打开test.txt文件,我们可以看到上传文件的内容和一些上传的信息了。    
 
-----------------------------7d15340138    
 
Content-Disposition:  form-data;  name="Author"    
 
 
 
A.  Christie    
 
-----------------------------7d15340138    
 
Content-Disposition:  form-data;  name="Company"Abisco    
 
-----------------------------7d15340138    
 
Content-Disposition:  form-data;  name="Filename";  filename="C:/123data/abisco.html"    
 
Content-Type:  text/html    
 
 
 
/*这里是上传的内容*/    
 
可以看到,HTTP请求体内包含了所有的表单输入,包括上载的文件。这些输入数据的分隔由一个分隔符实现。分隔符由一系列的“-”字符和一个随机数字构成。在上面的例子中,分隔符为“-----------------------------7d15340138”。最后一个分隔符结束请求体,这个分隔符的后面多出两个“-”符号。    
 
对于非文件类型的输入数据,分隔符后面跟着下面这行内容:Content-Disposition:  form-data;  name=inputName。其中inputName是表单元素的名字。例如:Content-Disposition:  form-data;  name="Author"。在这行内容的后面,紧跟着两个连续的回车换行符和表单元素值。    
 
而对于文件型输入域,分隔符的后面有两行内容。第一行内容包含输入元素的名字以及上载文件在客户端的完整路径。注意Windows浏览器会设置文件路径,而Unix/Linux以及Mac浏览器只发送文件名字。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值