common-fileupload是jakarta項目組開(kāi)發(fā)的一個(gè)功能很強大的上傳文件組件
下面先介紹上傳文件到服務(wù)器(多文件上傳):
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.util.*;
import java.util.regex.*;
import org.apache.commons.fileupload.*;
public class upload extends HttpServlet {
private static final String CONTENT_TYPE = "text/html; charset=GB2312";
//Process the HTTP Post request
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType(CONTENT_TYPE);
PrintWriter out=response.getWriter();
try {
DiskFileUpload fu = new DiskFileUpload();
// 設置允許用戶(hù)上傳文件大小,單位:字節,這里設為2m
fu.setSizeMax(2*1024*1024);
// 設置最多只允許在內存中存儲的數據,單位:字節
fu.setSizeThreshold(4096);
// 設置一旦文件大小超過(guò)getSizeThreshold()的值時(shí)數據存放在硬盤(pán)的目錄
fu.setRepositoryPath("c:\\windows\\temp");
//開(kāi)始讀取上傳信息
List fileItems = fu.parseRequest(request);
// 依次處理每個(gè)上傳的文件
Iterator iter = fileItems.iterator();
//正則匹配,過(guò)濾路徑取文件名
String regExp=".+\\\\(.+)$";
//過(guò)濾掉的文件類(lèi)型
String[] errorType={".exe",".com",".cgi",".asp"};
Pattern p = Pattern.compile(regExp);
while (iter.hasNext()) {
FileItem item = (FileItem)iter.next();
//忽略其他不是文件域的所有表單信息
if (!item.isFormField()) {
String name = item.getName();
long size = item.getSize();
if((name==null||name.equals("")) && size==0)
continue;
Matcher m = p.matcher(name);
boolean result = m.find();
if (result){
for (int temp=0;temp<errorType.length;temp++){
if (m.group(1).endsWith(errorType[temp])){
throw new IOException(name+": wrong type");
}
}
try{
//保存上傳的文件到指定的目錄
//在下文中上傳文件至數據庫時(shí),將對這里改寫(xiě)
item.write(new File("d:\\" + m.group(1)));
out.print(name+" "+size+"<br>");
}
catch(Exception e){
out.println(e);
}
}
else
{
throw new IOException("fail to upload");
}
}
}
}
catch (IOException e){
out.println(e);
}
catch (FileUploadException e){
out.println(e);
}
}
}
下面是個(gè)html的上傳頁(yè)面:
<h1>文件上傳演示</h1>
<form name="uploadform" method="POST" action="/upload" ENCTYPE="multipart/form-data">
<table border="1" width="450" cellpadding="4" cellspacing="2" bordercolor="#9BD7FF">
<tr><td width="100%" colspan="2">
文件1:<input name="x" size="40" type="file">
</td></tr>
<tr><td width="100%" colspan="2">
文件2:<input name="y" size="40" type="file">
</td></tr>
<tr><td width="100%" colspan="2">
文件3:<input name="z" size="40" type="file">
</td></tr>
</table>
<br/><br/>
<table>
<tr><td align="center"><input name="upload" type="submit" value="開(kāi)始上傳"/></td></tr>
</table>
</form>
現在介紹上傳文件到服務(wù)器,下面只寫(xiě)出相關(guān)代碼:
以sql2000為例,表結構如下:
字段名:name filecode
類(lèi)型: varchar image
數據庫插入代碼為:PreparedStatement pstmt=conn.prepareStatement("insert into test values(?,?)");
代碼如下:
。。。。。。
try{
//item.write(new File("d:\\" + m.group(1)));//這段代碼如果不去掉,將一同寫(xiě)入到服務(wù)器中
int byteread=0;
InputStream inStream=item.getInputStream(); //讀取輸入流,也就是上傳的文件內容
pstmt.setString(1,m.group(1));
pstmt.setBinaryStream(2,inStream,(int)size);
pstmt.executeUpdate();
inStream.close();
out.println(name+" "+size+"<br>");
}
。。。。。。
這樣就實(shí)現了上傳文件至數據庫
聯(lián)系客服