java中怎么把文件上传到服务器的指定路径?

java中怎么把文件上传到服务器的指定路径?,第1张

文件从本地到服务器的功能,其实是为了解决目前浏览器不支持获取本地文件路径。不得已而想到上传到服务器的固定目录,从而方便项目获取文件,进而使程序支持EXCEL批量导入数据。

java中文件上传到服务器的指定路径的代码:

在前台界面中输入:

<form method="post" enctype="multipart/form-data"  action="../manage/excelImport.do">

请选文件:<input type="file"  name="excelFile">

<input type="submit" value="导入" onclick="return impExcel()"/>

</form>

action中获取前台传来数据并保存

/**

* excel 导入文件

* @return

* @throws IOException

*/

@RequestMapping("/usermanager/excelImport.do")

public String excelImport(

String filePath,

MultipartFile  excelFile,HttpServletRequest request) throws IOException{

log.info("<<<<<<action:{} Method:{} start>>>>>>","usermanager","excelImport" )

if (excelFile != null){

String filename=excelFile.getOriginalFilename()

String a=request.getRealPath("u/cms/www/201509")

SaveFileFromInputStream(excelFile.getInputStream(),request.getRealPath("u/cms/www/201509"),filename)//保存到服务器的路径

}

log.info("<<<<<<action:{} Method:{} end>>>>>>","usermanager","excelImport" )

return ""

}

/**

* 将MultipartFile转化为file并保存到服务器上的某地

*/

public void SaveFileFromInputStream(InputStream stream,String path,String savefile) throws IOException

{    

FileOutputStream fs=new FileOutputStream( path + "/"+ savefile)

System.out.println("------------"+path + "/"+ savefile)

byte[] buffer =new byte[1024*1024]

int bytesum = 0

int byteread = 0

while ((byteread=stream.read(buffer))!=-1)

{

bytesum+=byteread

fs.write(buffer,0,byteread)

fs.flush()

}

fs.close()

stream.close()

}

String realpath = ServletActionContext.getServletContext().getRealPath("/upload") //获取服务器路径

String[] targetFileName = uploadFileName

for (int i = 0i <upload.lengthi++) {

File target = new File(realpath, targetFileName[i])

FileUtils.copyFile(upload[i], target)

//这是一个文件复制类copyFile()里面就是IO *** 作,如果你不用这个类也可以自己写一个IO复制文件的类

}

其中private File[] upload// 实际上传文件

private String[] uploadContentType// 文件的内容类型

private String[] uploadFileName// 上传文件名

这三个参数必须这样命名,因为文件上传控件默认是封装了这3个参数的,且在action里面他们应有get,set方法

common-fileupload是jakarta项目组开发的一个功能很强大的上传文件组件

下面先介绍上传文件到服务器(多文件上传):

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/htmlcharset=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()

// 设置允许用户上传文件大小,单位:字节,这里设为2m

fu.setSizeMax(2*1024*1024)

// 设置最多只允许在内存中存储的数据,单位:字节

fu.setSizeThreshold(4096)

// 设置一旦文件大小超过getSizeThreshold()的值时数据存放在硬盘的目录

fu.setRepositoryPath("c://windows//temp")

//开始读取上传信息

List fileItems = fu.parseRequest(request)

// 依次处理每个上传的文件

 Iterator iter = fileItems.iterator()

//正则匹配,过滤路径取文件名

 String regExp=".+////(.+)$"

//过滤掉的文件类型

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=0temp<ERRORTYPE.LENGTHTEMP++){

         if (m.group(1).endsWith(errorType[temp])){

               throw new IOException(name+": wrong type")

         }

         }

         try{

//保存上传的文件到指定的目录

//在下文中上传文件至数据库时,将对这里改写

         item.write(new File("d://" + m.group(1)))

out.print(name+"  "+size+"")

         }

         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)

}

}

}

现在介绍上传文件到服务器,下面只写出相关代码:

以sql2000为例,表结构如下:

字段名:name    filecode

类型: varchar     image

数据库插入代码为:PreparedStatement pstmt=conn.prepareStatement("insert into test values(?,?)")

代码如下:

。。。。。。

try{

      这段代码如果不去掉,将一同写入到服务器中

      //item.write(new File("d://" + m.group(1)))

         

      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+" ")

      }

。。。。。。

这样就实现了上传文件至数据库


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12102980.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存