Ajax AsyncFileUpload Upload Control загрузить файл несколько раз - PullRequest
2 голосов
/ 01 января 2012

Я пытался разобраться в этом вопросе целый день, пока мне не повезло.У меня есть веб-форма, которая имеет некоторые элементы управления asp.net формы и два элемента управления AsyncFileUpload.Когда я загружаю изображение с помощью первого AsyncFileUpload1, оно загружает только одно изображение, а когда я загружаю второе изображение с помощью AsyncFileUpload2, оно загружает две версии одного и того же изображения.

Все сводится с ума, когда я нажимаю кнопку Сохранить, чтобы сохранить данныеЗатем он загружает еще 3 версии изображений всего 6 или более.Я попробовал другой способ и, наконец, сдался.

Пример кода в HTML-файле

     <script type = "text/javascript">
         function uploadComplete(sender) {
             // $get("<%=lblImageUploadMessage1.ClientID%>").innerHTML = "File Uploaded Successfully";
             // $get("<%=lblImageUploadMessage2.ClientID%>").innerHTML = "File Uploaded Successfully";
             clearContents();
             clearContents2();

         }
         function uploadError(sender) {
             // $get("<%=lblImageUploadMessage1.ClientID%>").innerHTML = "File upload failed. only Image files are allowed";
             // $get("<%=lblImageUploadMessage2.ClientID%>").innerHTML = "File upload failed. only Image files are allowed";
             clearContents();
         }
</script>
<script type = "text/javascript">
    function clearContents() {
        var span = $get("<%=AsyncFileUpload1.ClientID%>");
        var txts = span.getElementsByTagName("input");
        for (var i = 0; i < txts.length; i++) {
            if (txts[i].type == "text") {
                txts[i].value = "";
            }
        }
    }
    function clearContents2() {
        var span = $get("<%=AsyncFileUpload2.ClientID%>");
        var txts = span.getElementsByTagName("input");
        for (var i = 0; i < txts.length; i++) {
            if (txts[i].type == "text") {
                txts[i].value = "";
            }
        }
    }

    window.onload = clearContents;
</script>   

       <div class="row">
            <asp:Label ID="lblPageTitleE" CssClass="txtLabel" runat="server" Text="Page Title (E) :"></asp:Label>
            <asp:TextBox ID="txtPageTitleE" runat="server" CssClass="txtbox700"></asp:TextBox>
            <asp:RequiredFieldValidator ID="RFVPageTitleE" runat="server" ErrorMessage="*" 
                ControlToValidate="txtPageTitleE" ValidationGroup="atpAddNewPage"  CssClass="validation"></asp:RequiredFieldValidator>
       </div>
       <div class="row">
            <asp:Label ID="lblPageTitleA" CssClass="txtLabel" runat="server" Text="Page Title (A) :"></asp:Label>
            <asp:TextBox ID="txtPageTitleA" runat="server" CssClass="txtbox700"></asp:TextBox>
            <asp:RequiredFieldValidator ID="RFVPageTitleA" runat="server" ErrorMessage="*" 
                ControlToValidate="txtPageTitleA" ValidationGroup="atpAddNewPage"  CssClass="validation"></asp:RequiredFieldValidator>
       </div>

  <!-- Image Control --> 
           <div class="row">
                <asp:Label ID="lblBannerImageE" CssClass="txtLabel" runat="server" Text="Banner Image (E) :"></asp:Label>
    <asp:AsyncFileUpload  OnClientUploadError="uploadError" OnClientUploadComplete="uploadComplete"
    runat="server" ID="AsyncFileUpload1"  UploaderStyle="Modern" CompleteBackColor="White"
    UploadingBackColor="#336699" ThrobberID="imgLoader" OnUploadedComplete="AsyncFileUpload1_UploadedComplete" CssClass="AFU2" Width="400px" />

                <asp:Label ID="lblImageUploadMessage1" CssClass="imgLabel" runat="server" Text=""></asp:Label>
                <asp:Image ID="imgLoader" runat="server" ImageUrl="~/images/ajax-loader-small.gif" />
           </div>
           <div class="row">
                <asp:Label ID="lblBannerImageA" CssClass="txtLabel" runat="server" Text="Banner Image (A) :"></asp:Label>
                <asp:AsyncFileUpload  OnClientUploadError="uploadError" OnClientUploadComplete="uploadComplete"
                runat="server" ID="AsyncFileUpload2"  UploaderStyle="Modern" CompleteBackColor="White"
                UploadingBackColor="#336699" ThrobberID="imgLoader2" OnUploadedComplete="AsyncFileUpload2_UploadedComplete" CssClass="AFU2" Width="400px" />
                <asp:Label ID="lblImageUploadMessage2" CssClass="imgLabel" runat="server" Text=""></asp:Label>
                <asp:Image ID="imgLoader2" runat="server" ImageUrl="~/images/ajax-loader-small.gif" />
           </div>
  <!-- Image Control --> 

Ниже приведен пример кода .CS файла

В этом файле яЯ присваиваю каждому изображению уникальное имя, используя GUID и загрузку изображения. Код AsyncFileUpload выполняется несколько раз, и я не могу понять, что я так растерялся.

public partial class _Default : System.Web.UI.Page
{
    String BannerImageNameEn, BannerImageNameAr;



    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            //Session["BannerImageNameEn"] = "Null";
            //Session["BannerImageNameEn"] = "Null";
        }

    }

    protected void btnCreatePage_Click(object sender, EventArgs e)
    {
        BusinessLogic objBLAddNewPage = new BusinessLogic();

        Pages objPages = new Pages();

        objPages.PageNameEn = txtPageNameE.Text;
        objPages.PageNameAr = txtPageNameA.Text;
        objPages.PageTitleEn = txtPageTitleE.Text;
        objPages.PageTitleAr = txtPageTitleA.Text;
        objPages.PageDescEn = txtPageDescE.Text;
        objPages.PageDescAr = txtPageDescA.Text;
        objPages.PageKeywordEn = txtPageKeywordsE.Text;
        objPages.PageKeywordAr = txtPageKeywordsA.Text;
        objPages.PageBodyEn = CKEditorPageBodyE.Text;
        objPages.PageBodyAr = CKEditorPageBodyA.Text;
        objPages.PageLinkPositionNo = int.Parse(txtPageLinkPosition.Text);
        objPages.PageLayoutPosition = ddPageLayoutPosition.SelectedItem.Value.ToString();


        // Assign Name to Images 
        objPages.PageBannerImageEn = Session["BannerImageNameEn"].ToString();
        objPages.PageBannerImageAr = Session["BannerImageNameAr"].ToString();

        objPages.PageBannerLinkEn = txtBannerLinkEnglish.Text;
        objPages.PageBannerLinkAr = txtBannerLinkArabic.Text;

        objPages.PageWindow = ddPageWindow.SelectedItem.Value.ToString();
        objPages.PageActive = bool.Parse(ddPageActive.SelectedItem.Value.ToString());
        objPages.PageVisible = bool.Parse(ddPageHidden.SelectedItem.Value.ToString());

        objPages.PageCreateDate = Helper.GetUAEDateTime();
        objPages.PageUpdateDate = Helper.GetUAEDateTime();
        objPages.PageIPAddress = Request.ServerVariables["REMOTE_ADDR"];

        try
        {

            bool result;
            //result = objBLAddNewPage.CreateNewPage(objPages);
            result = false;

            if (result == true)
            {
                Response.Redirect("PageCreated.aspx");
            }
            else
            {

            }


        }
        catch (Exception ex)
        {
            //lblresult.Text = ex.ToString();
        }

    }

    protected void AsyncFileUpload1_UploadedComplete(object sender, AjaxControlToolkit.AsyncFileUploadEventArgs e)
    {
        try
        {
            String filePath = string.Empty;
            String CurrentGUID = Guid.NewGuid().ToString();

            if (AsyncFileUpload1.HasFile)
            {
                string filename = System.IO.Path.GetFileName(AsyncFileUpload1.FileName);
                System.IO.FileInfo f = new System.IO.FileInfo(AsyncFileUpload1.PostedFile.FileName);
                int fileSize = Int32.Parse(System.IO.Path.GetFileName(e.FileSize));
                if (fileSize < 1024000) // 1 MB current size size in bytes 102400=100kb  512000 = 500kb
                {
                    if ((f.Extension.ToLower() == ".jpg") || (f.Extension.ToLower() == ".png") || (f.Extension.ToLower() == ".gif") || (f.Extension.ToLower() == ".jpeg"))
                    {

                        filename = CurrentGUID + f.Extension;
                        //string productGUID 
                        filePath = Server.MapPath("../ImageUploads/") + filename;
                        if (System.IO.File.Exists(filePath))
                        {
                            return;
                        }
                        else
                        {
                            //Upload files
                            AsyncFileUpload1.PostedFile.SaveAs(Server.MapPath("../ImageUploads/") + filename);


                 Session["BannerImageNameEn"] = filename.ToString();
                        string errMsg = "File Uploaded Successfully";

                        ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "size", "top.$get(\"" + lblImageUploadMessage1.ClientID + "\").innerHTML='" + errMsg + "';", true);
                        // ResizeImage(string OriginalFile, string NewFile, int NewWidth, int MaxHeight, bool OnlyResizeIfWider)
                        Helper.ResizeImage(filePath, filePath, 150, 80, true);

                    }
                    return;
                }

            }
            else
            {
                lblImageUploadMessage1.Text = "Only type .jpg, .png, .gif are allow";
                string errMsg = "File must be an Image type of .jpg, .png, .gif, .jpeg";
                //client-side error
                ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "size", "top.$get(\"" + lblImageUploadMessage1.ClientID + "\").innerHTML='" + errMsg + "';", true);
                return;
            }
        }
        else
        {
            //lblMesg.Text = "Only type .jpg, .png, .gif are allow";
            string errMsg = "File size is greater the 1MB";
            //client-side error
            ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "size", "top.$get(\"" + lblImageUploadMessage1.ClientID + "\").innerHTML='" + errMsg + "';", true);
            return;
        }
    }
    catch (Exception ex)
    {
    }
}

protected void AsyncFileUpload2_UploadedComplete(object sender, AjaxControlToolkit.AsyncFileUploadEventArgs e)
{
    try
    {
        String filePath = string.Empty;
        String CurrentGUID = Guid.NewGuid().ToString();
        if (AsyncFileUpload1.HasFile)
        {
            string filename = System.IO.Path.GetFileName(AsyncFileUpload1.FileName);
            System.IO.FileInfo f = new System.IO.FileInfo(AsyncFileUpload1.PostedFile.FileName);
            int fileSize = Int32.Parse(System.IO.Path.GetFileName(e.FileSize));
            if (fileSize < 1024000) // 1 MB current size size in bytes 102400=100kb  512000 = 500kb
            {
                if ((f.Extension.ToLower() == ".jpg") || (f.Extension.ToLower() == ".png") || (f.Extension.ToLower() == ".gif") || (f.Extension.ToLower() == ".jpeg"))
                {
                    filename = CurrentGUID + f.Extension;
                    //string productGUID 
                    filePath = Server.MapPath("../ImageUploads/") + filename;
                    if (System.IO.File.Exists(filePath))
                    {
                        return;
                    }
                    else
                    {
                        //Upload files
                        AsyncFileUpload2.PostedFile.SaveAs(Server.MapPath("../ImageUploads/") + filename);
                        Session["BannerImageNameAr"] = filename.ToString();
                        string errMsg = "File Uploaded Successfully";

                        ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "size", "top.$get(\"" + lblImageUploadMessage2.ClientID + "\").innerHTML='" + errMsg + "';", true);
                        // ResizeImage(string OriginalFile, string NewFile, int NewWidth, int MaxHeight, bool OnlyResizeIfWider)
                        Helper.ResizeImage(filePath, filePath, 150, 80, true);
                    }
                    return;
                }
            }
            else
            {
                lblImageUploadMessage1.Text = "Only type .jpg, .png, .gif are allow";
                string errMsg = "File must be an Image type of .jpg, .png, .gif, .jpeg";
                //client-side error
                ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "size", "top.$get(\"" + lblImageUploadMessage2.ClientID + "\").innerHTML='" + errMsg + "';", true);
                return;
            }
        }
        else
        {
            //lblMesg.Text = "Only type .jpg, .png, .gif are allow";
            string errMsg = "File size is greater the 1MB";
            //client-side error
            ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "size", "top.$get(\"" + lblImageUploadMessage2.ClientID + "\").innerHTML='" + errMsg + "';", true);
            return;
        }
    }
    catch (Exception ex)
    {
    }
}

}

Я просто хочуфункциональность, в которой я могу загрузить два изображения, присвоив им уникальное имя с помощью GUID и, наконец, такое же имя изображения вместе с другими данными формы в базе данных.

Я использую ASP.NET, C # 3.0 и Framework 4, Latestверсия Ajax, загруженная сегодня И мне нужно выполнить задание только в ASP.Net

...