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. AES加密 16进制与二进制转换

    import java.security.Key; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax ...

  2. ODBC错误处理

    ODBC 中的错误处理 ODBC 中的错误是使用来自每个 ODBC 函数调用的返回值和 SQLError 函数或 SQLGetDiagRec 函数的返回值进行报告的.SQLError 函数用于 ODB ...

  3. cisco VPN

    配置实例:公司在北京而分公司在上海,如果租用光纤业务费用会比较高,另外安全性也没有保证,特别是对内网的访问方面.我们要在总公司和分公司之间建立有效的VPN连接.具体网络拓扑如图1所示.北京路由器名为R ...

  4. linux系统设置静态IP 查看网卡配置文件

    http://jingyan.baidu.com/article/455a99508be7cda167277865.html vi /etc/sysconfig/network-scripts/ifc ...

  5. Js笔试题之返回只包含数字类型的数组

    如js123ldka78sdasfgr653 => [123,78,653] 一般做法 分析: 1.循环字符串每个字符,是数字的挑出来拼接在一起,不是数字的,就给他空的拼个逗号 2.将新字符串每 ...

  6. 把Angular中的$http变成jQuery.ajax()一样,可以让后台(php)轻松接收到参数

    最近接到一个手机项目,我决定用ionic + php + mysql来实现.ionic是一个前端框架,主要用于手机端,它融合了html5.css3.angularJS于一体,用起来很顺手. 开始构建项 ...

  7. 西天取经第一步——制作自己的HTML5游戏

    废话不说,直入主题:这是一个休闲益智类游戏,与愤怒的小鸟类似采用Box2dWeb引擎.再开发游戏之前,首先我要把Box2dWeb给总结一下方便以后调用 大家可以在http://code.google. ...

  8. 二模 (5) day2

    第一题: 有 N 个人顺时针围在一圆桌上开会,他们对身高很敏感. 因此决定想使得任意相邻的两人的身高差距最大值最小. 如果答案不唯一,输出字典序最小的排列,指的是身高的排列.N<=50 解题过程 ...

  9. Quartz之主方法运行

    import static org.quartz.JobBuilder.newJob; import static org.quartz.TriggerBuilder.newTrigger; impo ...

  10. 分享第一次使用ProcessOn心得

    最近朋友推荐了我一款在线作图工具ProcessOn,感受使用了几天感觉确实很不错,在这里给大家分享一下! ProcessOn应该算的上是第一款完全免费在线作图工具,之前用过国外有类似的,不过都是付费的 ...