2012-09-18 50 views
0

服務器sidecode如何同時使用AsyncFileUpload

protected void UploadComplete(object sender, AjaxControlToolkit.AsyncFileUploadEventArgs e) 
{ 
    rlativepath =GeneratePrefixFileName() + AsyncFileUpload1.PostedFile.FileName; 
    databasepath = "~/Image/" + rlativepath; 
    filePath = Request.PhysicalApplicationPath + "image\\"+rlativepath; 
    AsyncFileUpload1.SaveAs(filePath); 
} 

客戶端代碼來獲得服務器端的重命名在客戶方的文件名

<script type="text/javascript"> 

function upLoadStarted() { 
    $get("imgDisplay").style.display = "none"; 
} 
function showConfirmation(sender, args) { 
    var txt = document.getElementById('<%=statusoutput.ClientID %>'); 
    var img = document.getElementById('<%=statusoutput.ClientID %>'); 
    txt.value = "Upload Successful"; 

    var imgDisplay = $get("imgDisplay"); 
    imgDisplay.src = "ajaxupload.jpg"; 
    imgDisplay.style.cssText = "height:100px;width:100px"; 
    var img = new Image(); 
    img.onload = function() { 
     imgDisplay.style.cssText = "height:100px;width:100px"; 
     imgDisplay.src = img.src; 
    }; 
    <%# UploadFolderPath1+=rlativepath %> 
    img.src = "<%=ResolveUrl(UploadFolderPath1) %>"+ args.get_fileName(); 
    alert(img.src); 
    var imagedescrip = $get("imagedescrip"); 
    imagedescrip.style.cssText = "visibility:visible;"; 
    } 

aspx頁面:

<asp:ScriptManager ID="ScriptManager1" runat="server"> 
    </asp:ScriptManager> 
     content of page 
    FNever increase, beyond what is necessary, the number of entities required to explain anything." William of Ockham (1285-1349) 
    <asp:AsyncFileUpload ID="AsyncFileUpload1" runat="server" OnUploadedComplete="UploadComplete" ThrobberID="imgLoader" OnClientUploadStarted="upLoadStarted" UploaderStyle="Modern" OnClientUploadComplete="showConfirmation" 
    Width="400px" CompleteBackColor="White" UploadingBackColor="#CCFFFF"></asp:AsyncFileUpload> 
    <input type="text" id="statusoutput" runat="server" readonly="readonly" tabindex="-1000" style="border:0px;background-color:transparent;" /> 
    <asp:Image ID="imgLoader" runat="server" ImageUrl="ajaxupload.jpg" Height="100px" Width="100px" /> 

    <img id = "imgDisplay" alt="" src="" style = "display:none;height:100px;width:100px"/> 

我使用AsyncFileUpload爲上傳文件,在將文件保存在服務器上之前,我重命名所選文件。我怎樣才能在客戶端獲得這個新的文件名?現在我的問題是我沒有得到與客戶端side.how args.get_filename()重命名文件名?

回答

3

添加HiddenField控件到窗體:

<asp:HiddenField runat="server" ID="UploadedPathHiddenField" /> 

重寫UploadComplete如下方法:

protected void UploadComplete(object sender, AsyncFileUploadEventArgs e) 
{ 
    var fileName = GeneratePrefixFileName() + System.IO.Path.GetFileName(e.FileName); 
    var relativePath = "~/Image/" + fileName; 
    var filePath = Server.MapPath(relativePath); 
    AsyncFileUpload1.SaveAs(filePath); 
    ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "filePath", "top.$get(\"" + UploadedPathHiddenField.ClientID + "\").value = '" + ResolveClientUrl(relativePath) + "';", true); 
} 

之後,你可以得到保存的圖像的路徑showConfirmation方法:

var src = $get("<%= UploadedPathHiddenField.ClientID %>").value;