flex前端代码:

<?xml version="1.0" encoding="utf-8"?>
<s:BorderContainer xmlns:fx="http://ns.adobe.com/mxml/2009"
   xmlns:s="library://ns.adobe.com/flex/spark"
    xmlns:mx="library://ns.adobe.com/flex/mx"
    width="100%" height="100%" xmlns:component="com.boco.mis.nwcfgdm.component.*"
    creationComplete="init()">

<fx:Script>
<![CDATA[

    import com.adobe.net.URI;

    private var file: FileReference;

    private function init(): void{
        Security.allowDomain("*");
        file = new FileReference();
        file.addEventListener(ProgressEvent.PROGRESS, onProgress);
        file.addEventListener(Event.SELECT, onSelect);
    }

    private function upload(): void{
        file.browse();
    }
    private function onSelect(e: Event): void{
        Alert.show("上传 " + file.name + " (共 "+Math.round(file.size)+" 字节)?",
        "确认上传",
        Alert.YES|Alert.NO,
        null,
        proceedWithUpload);
    }

    private function proceedWithUpload(e: CloseEvent): void{
        if (e.detail == Alert.YES){
      //采用http向后台发送请求
        var uri:URI = new URI(Application.application.url);

        //获得服务端的ip
        var authority:String = uri.authority;

        //获得服务端的端口号

        var port:String = uri.port;
        var request: URLRequest = new URLRequest("http://"+authority+":"+port+"/nwcfgdm/fileUploadServlet");
        try {
          file.upload(request);
        } catch (error:Error) {
          trace("上传失败");
        }

    }
}
//显示进度条
      private function onProgress(e: ProgressEvent): void
      {
        var u:Upload = Upload(PopUpManager.createPopUp(this.parentApplication.parent,Upload,true));
        PopUpManager.centerPopUp(u);
        var proc: uint = e.bytesLoaded / e.bytesTotal * 100;
        u.bar.setProgress(proc, 100);
        u.bar.label= "当前进度: " + " " + proc + "%";
        if(proc == 100){
          u.lbProgress.text="上传完成,正在导入数据...";
          var importDateEvt:ImportDataEvent = new ImportDataEvent();
          CairngormEventDispatcher.getInstance().dispatchEvent(importDateEvt);
        }
}

java代码部分:(是一个servelt)

  

public class FileUploadServlet extends HttpServlet {

  //这里我采用log的形式记录异常信息

    private static final Logger log = LoggerFactory
    .getLogger(NwcfgdmService.class);

    //自定义路径,盘符建议用

     private String uploadPath ="D:"+File.separator+"opt"+File.separator+"BOCO"+File.separator ";

    private static final long serialVersionUID = 1L;

    private int maxPostSize = 100 * 1024 * 1024;

    public FileUploadServlet() {
      super();
    }

    public void destroy() {
      super.destroy();
    }

    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

       //防止标题中还有中文字符是出现乱码
        request.setCharacterEncoding("UTF-8");
        response.setContentType("text/html; charset=UTF-8");
        DiskFileItemFactory factory = new DiskFileItemFactory();
        factory.setSizeThreshold(4096);
        ServletFileUpload upload = new ServletFileUpload(factory);
        upload.setSizeMax(maxPostSize);
        try
        {
          List fileItems = upload.parseRequest(request);
          Iterator iter = fileItems.iterator();
          while (iter.hasNext())
          {
          FileItem item = (FileItem) iter.next();
            if (!item.isFormField())
          {
            String name = item.getName();
            // System.out.println(name);
           try
          {
            item.write(new File(uploadPath+name ));
          }
          catch (Exception e)
          {
            e.printStackTrace();
            log.error("书写文件出现异常",e);
          }
        }
      }
    }
      catch (FileUploadException e)
    {
      e.printStackTrace();
      log.error("上传文件出现异常",e);

    }
}

      public void doPost(HttpServletRequest request, HttpServletResponse response)
              throws ServletException, IOException {
        doGet(request, response);
       }

      public void init() throws ServletException {
        // Put your code here
      }

}

web.xml中的配置:

<servlet>
  <servlet-name>FileUploadServlet</servlet-name>
  <servlet-class>nwcfgdm.FileUploadServlet</servlet-class>
</servlet>
<servlet-mapping>
  <servlet-name>FileUploadServlet</servlet-name>
  <url-pattern>/fileUploadServlet</url-pattern>
</servlet-mapping>

flex+java实现文件的上传的更多相关文章

  1. java客户端文件的上传和下载

    java客户端文件的上传和下载 //上传 public JTable upload(String id){ JTable table=new JTable(); System.out.println( ...

  2. Java WEB ----- 文件的上传

    最近学到的web阶段的文件的上传,就想记录一下,帮助自己复习以及帮助大家学习,一般我都会把上传的文件存到服务器中的web-inf 下面,因为这样用户不会直接访问到,我们存到数据库的一般都是路径.这里没 ...

  3. java实现文件的上传和下载

    1. servlet 如何实现文件的上传和下载? 1.1上传文件 参考自:http://blog.csdn.net/hzc543806053/article/details/7524491 通过前台选 ...

  4. java实现文件的上传与下载

    (一)文件的上传:在这一部分,我要将execl文件的内容上传到数据库中,完成这一功能.需要分为两步: 1:将文件上传到tomcat下 文件格式如下: 2:读取execl表中的内容到数据库中 首先:下载 ...

  5. Java中文件的上传与下载

    文件的上传与下载主要用到两种方法: 1.方法一:commons-fileupload.jar  commons-io.jar apache的commons-fileupload实现文件上传,下载 [u ...

  6. java大文件分块上传断点续传demo

    第一点:Java代码实现文件上传 FormFile file = manform.getFile(); String newfileName = null; String newpathname =  ...

  7. java实现文件夹上传

    文件上传下载,与传统的方式不同,这里能够上传和下载10G以上的文件.而且支持断点续传. 通常情况下,我们在网站上面下载的时候都是单个文件下载,但是在实际的业务场景中,我们经常会遇到客户需要批量下载的场 ...

  8. Java多级文件夹上传

    javaweb上传文件 上传文件的jsp中的部分 上传文件同样可以使用form表单向后端发请求,也可以使用 ajax向后端发请求 1.通过form表单向后端发送请求 <form id=" ...

  9. Java实现文件的上传下载(含源代码和jar包)

    1.需要使用的jar包 链接:https://pan.baidu.com/s/1IaxQRSwfzxDpe4w4JiaEKw 提取码:xwtz 2.如果想实现文件的下载,需要创建一张表,表的结构为 i ...

随机推荐

  1. Bag of mice(CodeForces 148D )

    D. Bag of mice time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...

  2. cl.exe

    http://blog.csdn.net/happyanger6/article/details/7589016

  3. linux sort 命令详解

    sort是在Linux里非常常用的一个命令,管排序的,集中精力,五分钟搞定sort,现在开始! 1 sort的工作原理 sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按AS ...

  4. linux 一些命令

    1.查看cpu个数 cat /proc/cpuinfo |grep "physical id" |sort | uniq |wc -l 2 2.查看cpu逻辑个数 cat /pro ...

  5. js中获得当前时间是年份和月份

    js中获得当前时间是年份和月份,形如:201208       //获取完整的日期 var date=new Date; var year=date.getFullYear();  var month ...

  6. [Js]碰撞运动

    描述:撞到目标点弹回来(速度反转) 一.无重力的漂浮div var div1=document.getElementById("div1"); var iSpeedX=6; var ...

  7. js基础之DOM

    一.创建子节点 发帖在顶部显示: var oBtn = document.getElementById('btn1'); var oUl = document.getElementById('ul1' ...

  8. C#解析Json(多方法解析Json 一)

    解析:{'id':'4028d80858053bed0158053ef7a50001','sl':0.0,'sfyfz':'0','zwjyzsbh':'1000001600000018'} 1.新建 ...

  9. 向MySql中插入中文时出现乱码

    这个因为字符集编码问题.在连接字符串中加上CharSet=gbk

  10. javascript photo1