JAVA 发送下载文件(未测试)

来源:互联网 发布:淘宝已买到的宝贝 编辑:程序博客网 时间:2024/06/05 14:45

下载文件

protected void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException {// TODO Auto-generated method stub//doPost(request, response);//System.out.println("下载");response.setContentType("application/x-download");PropertyBean propertyBeanURL = new PropertyBean();propertyBeanURL.setPropertiesFile("mail.properties");propertyBeanURL.init();String tempUrl = propertyBeanURL.get("temp"); String filePath = tempUrl+ File.separatorChar+ "CrmUpload" +File.separatorChar;String filedownload = filePath + "tcsl_mobile.xls";//String filePath = getPropertyBean("ticketFilePath"); //"E:\\CrmUpload\\";//String filedownload = filePath + getPropertyBean("ticketTemplatesFile");  //filePath + "mobile.xls";//文件名String filedisplay = "非会员电话号码模版.xls";//下载文件时显示的文件保存名称String filenamedisplay = URLEncoder.encode(filedisplay,"UTF-8");response.addHeader("Content-Disposition","attachment;filename=" + filenamedisplay);OutputStream outp = null;FileInputStream in = null;try{    outp = response.getOutputStream();    File truefile=new File(filedownload);    in = new FileInputStream(truefile);    byte[] b = new byte[1024];    int i = 0;    while((i = in.read(b)) > 0){        outp.write(b, 0, i);    }    outp.flush();}catch(Exception e){    //System.out.println("Error!");    logger.error(e.getMessage(),e);}finally{    if(in != null)    {        in.close();        in = null;    }    if(outp != null)    {        outp.close();        outp = null;    }}}

接收文件(此例是接收xls文件,并解析)

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {response.setContentType("text/html");response.setCharacterEncoding("UTF-8");request.setCharacterEncoding("UTF-8");PrintWriter out = response.getWriter();final long MAX_SIZE = 1024 * 1024 * 1;// 设置上传文件最大为1G 1B *1024 = 1*1024 = 1M *1024 = 1G// 上传文件路径//String filePath = getPropertyBean("ticketFilePath"); //"E:\\CrmUpload\\";PropertyBean propertyBeanURL = new PropertyBean();propertyBeanURL.setPropertiesFile("mail.properties");propertyBeanURL.init();String tempUrl = propertyBeanURL.get("temp"); String filePath = tempUrl+ File.separatorChar+ "CrmUpload" +File.separatorChar;//System.out.println(filePath);try {checkPath(filePath);} catch (Exception e1) {e1.printStackTrace();}// 临时存放目录String tempPath = filePath + "temp"+File.separator;try {checkPath(tempPath);} catch (Exception e1) {e1.printStackTrace();}// 实例化一个硬盘文件工厂,用来配置上传组件ServletFileUploadDiskFileItemFactory dfif = new DiskFileItemFactory();// 设置上传文件时用于临时存放文件的内存大小,这里是5M.多于的部分将临时存在硬盘dfif.setSizeThreshold(1024 * 1024 * 5);// 设置存放临时文件的目录dfif.setRepository(new File(tempPath));// 用以上工厂实例化上传组件ServletFileUpload sfu = new ServletFileUpload(dfif);// 设置最大上传尺寸sfu.setSizeMax(MAX_SIZE);// 从request得到 所有 上传域的列表List fileList = null;try {fileList = sfu.parseRequest(request);} catch (FileUploadException e) {// 处理文件尺寸过大异常if (e instanceof SizeLimitExceededException) {//System.out.println("导入文件大小不能超过1M");out.println(showMsg("导入文件大小不能超过1M!"));return;}logger.error(e.getMessage(),e);}// 没有选择上传文件if (fileList == null || fileList.size() == 0) {//System.out.println("请选择导入文件");out.println(showMsg("请选择导入文件"));return;}// 得到所有上传的文件Iterator fileItr = fileList.iterator();// 循环处理所有文件while (fileItr.hasNext()) {FileItem fileItem = null;String path = null;double size = 0;// 得到当前文件fileItem = (FileItem) fileItr.next();// 忽略简单form字段而不是上传域的文件域(<input type="text" />等)if (fileItem == null || fileItem.isFormField()) {continue;}// 得到文件的完整路径path = fileItem.getName();// 得到文件的大小size = fileItem.getSize();// 得到去除路径的文件名String t_name = path.substring(path.lastIndexOf(File.separator) + 1);// 得到文件的扩展名(无扩展名时将得到全名)String t_ext = t_name.substring(t_name.lastIndexOf(".") + 1);if (!"xls".equalsIgnoreCase(t_ext)) {out.println(showMsg("请使用正确的电话号码模版文件导入!"));break;}//生成文件名SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSSS");String newname = sdf.format((new Date()).getTime());t_name = newname + RandomStringUtils.randomNumeric(3);// 保存的最终文件完整路径,保存在e盘upload目录下String u_name = filePath + t_name + "." + t_ext;String u_size = "";try {// 保存文件fileItem.write(new File(u_name));if (size > 1024 * 1024)u_size = (float) Math.round(size * 100 / (1024 * 1024)) / 100 + "MB";elseu_size = (float) Math.round(size * 100 / 1024) / 100 + "KB";//System.out.println("文件名:" + t_name + "上传完成。文件大小:" + u_size);out.println(showMsg("导入文件加载完毕,正在解析,请稍候..."));POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(u_name));HSSFWorkbook workBook = new HSSFWorkbook(fs);try {HSSFSheet sheet = workBook.getSheetAt(0);int rows = sheet.getPhysicalNumberOfRows();rows = 3001; //1万行数据if (rows > 0) {sheet.getMargin(Sheet.TopMargin);List<MobileListDto> list = new ArrayList<MobileListDto>();for (int j = 1; j < rows; j++) {  //从第2行开始HSSFRow row = sheet.getRow(j);if (row == null) {continue;}int cells = row.getLastCellNum(); // 是获取最后一个不为空的列是第几个if (cells < 1){out.println(showMsg("电话号码文件格式不符合要求!"));break;}HSSFCell cell0 = row.getCell(0); //姓名列HSSFCell cell1 = row.getCell(1); //手机号码列// System.out.println(cell.getRichStringCellValue());MobileListDto mld = new MobileListDto();String rname = "";String rmobile = "";if (cell0 != null){switch (cell0.getCellType()) { case Cell.CELL_TYPE_STRING: rname = cell0.getRichStringCellValue().toString(); break; case Cell.CELL_TYPE_NUMERIC: rname = new DecimalFormat("0").format(cell0.getNumericCellValue()); break;}} else {rname = "";}if (cell1!=null) {switch (cell1.getCellType()) { case Cell.CELL_TYPE_STRING: rmobile = cell1.getRichStringCellValue().toString(); break; case Cell.CELL_TYPE_NUMERIC: rmobile = new DecimalFormat("0").format(cell1.getNumericCellValue()); break;}} else {rmobile = "";}rmobile = checkMobile(rmobile);if ("".equals(rname)){rname = "未知";}//System.out.println(rname +"--"+rmobile);// 手机号不为空 且 都是数字号码if (!"".equals(rmobile) && NumberUtils.isNumber(rmobile)){mld.setcName(rname);mld.setcMobile(rmobile);list.add(mld);}}// 去除重复list = removeDuplicateWithOrder(list);if (list != null && !list.isEmpty()) {//System.out.println("开始json");//若list不为空,则将其转换成JSON对象,并存入jsonArray中  JSONArray jsonArray = JSONArray.fromObject(list);   //下面就是把存有查询结果的JSON对象返给页面  //System.out.println(jsonArray);out.println("<script type=\"text/javascript\">parent.rtnList("+jsonArray+");</script>");}out.println(showMsg("共成功导入" + String.valueOf(list.size())+"个手机号码!"));}out.flush();out.close();delFile(u_name);} catch (Exception e) {out.println(showMsg("电话号码文件解析出错!"));delFile(u_name);logger.error(e.getMessage(),e);}} catch (Exception e) {out.println(showMsg("电话号码文件导入出现异常!"));delFile(u_name);logger.error(e.getMessage(),e);}}}}private void checkPath(String filepath) throws Exception {File file = new File(filepath);if (!file.exists() || !file.isDirectory()) {file.mkdirs();}}


0 0
原创粉丝点击