<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    溫馨提示:您的每一次轉(zhuǎn)載,體現(xiàn)了我寫(xiě)此文的意義!!!煩請(qǐng)您在轉(zhuǎn)載時(shí)注明出處http://m.tkk7.com/sxyx2008/謝謝合作!!!

    雪山飛鵠

    溫馨提示:您的每一次轉(zhuǎn)載,體現(xiàn)了我寫(xiě)此文的意義!!!煩請(qǐng)您在轉(zhuǎn)載時(shí)注明出處http://m.tkk7.com/sxyx2008/謝謝合作!!!

    BlogJava 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
      215 Posts :: 1 Stories :: 674 Comments :: 0 Trackbacks

    點(diǎn)我下載工程代碼
    由于項(xiàng)目需求,在處理文件上傳時(shí)需要使用到文件的異步上傳。這里使用Jquery Ajax File Uploader這個(gè)組件下載地址http://www.phpletter.com/download_project_version.php?version_id=6
    服務(wù)器端采用struts2來(lái)處理文件上傳。
    所需環(huán)境:
    jquery.js
    ajaxfileupload.js
    struts2所依賴的jar包
    及struts2-json-plugin-2.1.8.1.jar
    編寫(xiě)文件上傳的Action

    package com.ajaxfile.action;

    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileOutputStream;

    import org.apache.struts2.ServletActionContext;

    import com.opensymphony.xwork2.ActionSupport;

    @SuppressWarnings(
    "serial")
    public class FileAction extends ActionSupport {

        
    private File file;
        
    private String fileFileName;
        
    private String fileFileContentType;

        
    private String message = "你已成功上傳文件";
        
        
    public String getMessage() {
            
    return message;
        }

        
    public void setMessage(String message) {
            
    this.message = message;
        }

        
    public File getFile() {
            
    return file;
        }

        
    public void setFile(File file) {
            
    this.file = file;
        }

        
    public String getFileFileName() {
            
    return fileFileName;
        }

        
    public void setFileFileName(String fileFileName) {
            
    this.fileFileName = fileFileName;
        }

        
    public String getFileFileContentType() {
            
    return fileFileContentType;
        }

        
    public void setFileFileContentType(String fileFileContentType) {
            
    this.fileFileContentType = fileFileContentType;
        }

        @SuppressWarnings(
    "deprecation")
        @Override
        
    public String execute() throws Exception {
            
            String path 
    = ServletActionContext.getRequest().getRealPath("/upload");

            
    try {
                File f 
    = this.getFile();
                
    if(this.getFileFileName().endsWith(".exe")){
                    message
    ="對(duì)不起,你上傳的文件格式不允許!!!";
                    
    return ERROR;
                }
                FileInputStream inputStream 
    = new FileInputStream(f);
                FileOutputStream outputStream 
    = new FileOutputStream(path + "/"+ this.getFileFileName());
                
    byte[] buf = new byte[1024];
                
    int length = 0;
                
    while ((length = inputStream.read(buf)) != -1) {
                    outputStream.write(buf, 
    0, length);
                }
                inputStream.close();
                outputStream.flush();
            } 
    catch (Exception e) {
                e.printStackTrace();
                message 
    = "對(duì)不起,文件上傳失敗了!!!!";
            }
            
    return SUCCESS;
        }

    }
    struts.xml
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
    <struts>
        
    <package name="struts2" extends="json-default">
            
    <action name="fileUploadAction" class="com.ajaxfile.action.FileAction">
                
    <result type="json" name="success">
                    
    <param name="contentType">
                        text/html
                    
    </param>
                
    </result>
                
    <result type="json" name="error">
                    
    <param name="contentType">
                        text/html
                    
    </param>
                
    </result>
            
    </action>
        
    </package>
    </struts>    
    注意結(jié)合Action觀察struts.xml中result的配置。 

    contentType參數(shù)是一定要有的,否則瀏覽器總是提示將返回的JSON結(jié)果另存為文件,不會(huì)交給ajaxfileupload處理。這是因?yàn)閟truts2 JSON Plugin默認(rèn)的contentType為application/json,而ajaxfileupload則要求為text/html。
    文件上傳的jsp頁(yè)面

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding
    ="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
        
    <head>
            
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
            
    <title>Insert title here</title>
            
    <script type="text/javascript" src="js/jquery.js"></script>
            
    <script type="text/javascript" src="js/ajaxfileupload.js"></script>
            
    <script type="text/javascript">
        
    function ajaxFileUpload()
        {
            
            $(
    "#loading")
            .ajaxStart(
    function(){
                $(
    this).show();
            })
    //開(kāi)始上傳文件時(shí)顯示一個(gè)圖片
            .ajaxComplete(function(){
                $(
    this).hide();
            });
    //文件上傳完成將圖片隱藏起來(lái)
            
            $.ajaxFileUpload
            (
                {
                    url:'fileUploadAction.action',
    //用于文件上傳的服務(wù)器端請(qǐng)求地址
                    secureuri:false,//一般設(shè)置為false
                    fileElementId:'file',//文件上傳空間的id屬性  <input type="file" id="file" name="file" />
                    dataType: 'json',//返回值類(lèi)型 一般設(shè)置為json
                    success: function (data, status)  //服務(wù)器成功響應(yīng)處理函數(shù)
                    {
                        alert(data.message);
    //從服務(wù)器返回的json中取出message中的數(shù)據(jù),其中message為在struts2中action中定義的成員變量
                        
                        
    if(typeof(data.error) != 'undefined')
                        {
                            
    if(data.error != '')
                            {
                                alert(data.error);
                            }
    else
                            {
                                alert(data.message);
                            }
                        }
                    },
                    error: 
    function (data, status, e)//服務(wù)器響應(yīng)失敗處理函數(shù)
                    {
                        alert(e);
                    }
                }
            )
            
            
    return false;

        }
        
    </script>
        
    </head>
        
    <body>
            
    <img src="loading.gif" id="loading" style="display: none;">
            
    <input type="file" id="file" name="file" />
            
    <br />
            
    <input type="button" value="上傳" onclick="return ajaxFileUpload();">
        
    </body>
    </html>

     注意觀察<body>中的代碼,并沒(méi)有form表單。只是在按鈕點(diǎn)擊的時(shí)候觸發(fā)ajaxFileUpload()方法。需要注意的是js文件引入的先后順序,ajaxfileupload.js依賴于jquery因此你知道的。
    點(diǎn)我下載工程代碼

    posted on 2010-11-02 16:57 雪山飛鵠 閱讀(60654) 評(píng)論(11)  編輯  收藏 所屬分類(lèi): struts2js

    Feedback

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2012-04-17 20:08 藍(lán)水域
    謝謝  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2013-03-20 11:08 文秀
    非常感謝  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2013-03-23 14:03 so_fast
    非常感謝!  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件[未登錄](méi) 2013-03-28 13:55 kevin
    非常感謝,真的可以用  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2013-05-10 17:06 zwq
    如果我想發(fā)送文件
    同時(shí)在發(fā)送一些字符串到服務(wù)器,該怎么實(shí)現(xiàn)呢
    我現(xiàn)在能把文件發(fā)到服務(wù)器端了  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件[未登錄](méi) 2013-06-20 16:02
    真的很感激你啊,樓主好人啊!今天找了很多資料,一直糾結(jié)到底應(yīng)該使用什么框架來(lái)完成自己的ajax應(yīng)用。看到樓主的文章我豁然開(kāi)朗,決定使用jq。之前用過(guò)jq,感覺(jué)比較容易上手。  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2013-09-03 12:08 fsadf
    fdfaffaf  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2013-09-06 15:49 華仔
    請(qǐng)問(wèn)一個(gè)問(wèn)題啊,使用這個(gè)AjaxFileUpload.js 這個(gè)插件為什么會(huì)用到j(luò)query ajax 全局事件啦 按理說(shuō)它是一個(gè)form提交 根本就使用不到 ajax 全局事件啊 但是使用這種jQuery.event.trigger 事件的方式 。 這是為什么啊 ??? from 表達(dá)提交為什么會(huì)使用到 ajax 事件的全局事件。  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2014-04-27 15:31 shengyang
    thank you very much  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2014-08-02 23:05 qym19920
    用這個(gè)組件上傳的文件都是修改了文件的名字,怎么才能獲取上傳文件原來(lái)的名字,并且保存在服務(wù)端時(shí),名字不更改,我在FileLoadServelt中改了一下代碼,但是沒(méi)有獲取到原來(lái)文件的名字。。。。還請(qǐng)哪位知道的說(shuō)一下  回復(fù)  更多評(píng)論
      

    # re: jquery之a(chǎn)jaxfileupload異步上傳插件 2016-02-16 17:02 小蔣
    為什么我點(diǎn)擊“上傳”按鈕沒(méi)有作用?  回復(fù)  更多評(píng)論
      

    主站蜘蛛池模板: 久久免费公开视频| 色偷偷女男人的天堂亚洲网| 亚洲国产精品日韩| 国产一级做a爱免费视频| 日韩成人免费视频播放| 国产极品粉嫩泬免费观看| 国产成人免费全部网站| 免费日本黄色网址| 亚洲黄片毛片在线观看| 91麻豆国产自产在线观看亚洲| 亚洲一级片免费看| 亚洲精品卡2卡3卡4卡5卡区| 亚洲情XO亚洲色XO无码| 亚洲成熟xxxxx电影| 亚洲欧洲日产国产最新| 亚洲91精品麻豆国产系列在线| 久久亚洲精品国产亚洲老地址| 亚洲性色AV日韩在线观看| 日本黄页网址在线看免费不卡| 日韩在线视频播放免费视频完整版| 国产va免费观看| 免费在线看黄网站| 无码国产精品一区二区免费式直播 | 亚洲一区二区三区四区视频| 国产午夜亚洲精品| 黄色一级毛片免费看| 在线视频网址免费播放| 91成人在线免费观看| 成年男女男精品免费视频网站| 国产又粗又猛又爽又黄的免费视频 | 亚洲天堂免费在线| 蜜臀91精品国产免费观看| 精品亚洲视频在线观看| 亚洲一区二区三区首页 | 国内精品久久久久久久亚洲| 4444亚洲国产成人精品| 亚洲AV成人一区二区三区观看| xxxx日本在线播放免费不卡| 91精品国产免费入口| 波多野结衣久久高清免费| 中文字幕亚洲综合久久菠萝蜜|