0

Excel ワークブックをアップロードして処理する非常に単純な ASP.NET ページがあります。ASP.NET の AJAX ツールキットの AJAXFILEUPLOAD を使用します。マークアップは次のとおりです。

<%@ Page Title="" Language="C#" MasterPageFile="~/Site.Master" AutoEventWireup="true"
CodeBehind="ImportWorkbook.aspx.cs" Inherits="Timesheet.ImportWorkbook" %>

<asp:Content ID="Content1" runat="server" ContentPlaceHolderID="HeaderContentPlaceHolder">
<h1 class="topContent">
    Upload CPAS Timesheet Workbooks
</h1>
</asp:Content>
<asp:Content ID="Content3" ContentPlaceHolderID="RightContentPlaceHolder" runat="server">
<br />
<br />
<asp:HiddenField ID="tbTSID" runat="server" />
<asp:HiddenField ID="tbWorkbookPath" runat="server" />
<ajaxToolkit:AjaxFileUpload ID="AjaxFileUpload1" runat="server" AllowedFileTypes="xls,xlsx,xlsm"
    CssClass="dropdown" MaximumNumberOfFiles="1" OnUploadComplete="AjaxFileUpload1_UploadComplete" />
<br />
<br />
<asp:Panel ID="ProcessChoices" runat="server" >
    <br />
    <br />
    <p>
        Select how you want this workbook processed:</p>
    <br />
    <asp:RadioButtonList ID="rbChoices" runat="server" BorderStyle="Groove" BorderWidth="2px"
        BorderColor="Black" BackColor="Teal" Font-Names="Tahoma" Font-Size="10pt" ForeColor="White"
        Width="40%">
        <asp:ListItem Value="True" Selected="True">&nbsp Replace ALL Items in the Timesheet</asp:ListItem>
        <asp:ListItem Value="False">&nbsp Add Items from this Workbook to the Existing Timesheet Items</asp:ListItem>
    </asp:RadioButtonList>
    <br />
    <br />
    <asp:Button ID="btnValidate" runat="server" Text="Validate and Process" 
        BackColor="#B92217" ForeColor="White" BorderColor="#7C1810" 
        BorderStyle="Groove" Font-Names="Tahoma" onclick="btnValidate_Click" />
</asp:Panel>
</asp:Content>
<asp:Content ID="Content4" ContentPlaceHolderID="BottomSpanContentPlaceHolder" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server">
</asp:ScriptManager>
</asp:Content>

マスター ページと css ページは簡単で、書式設定のみです。

コードビハインドは次のとおりです。

 using System;
using System.IO;
using TimesheetUtilites;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using AjaxControlToolkit;

    namespace Timesheet
    {

    public partial class ImportWorkbook : System.Web.UI.Page
    {
        private const string HDriveLocation= "H:\\mtv\\secure\\Construction\\Access\\CPAS WorkArea\\TimesheetUploads\\";
        private string strWorkbookPath;    
        private int currTSID;

        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                if (Request.QueryString["ID"] != null)
                {
                    tbTSID.Value = Request.QueryString["ID"];            // Storing the Timesheet ID in a hidden Textbox                    
                }
            }
            else
            {
                if (!string.IsNullOrEmpty(tbWorkbookPath.Value))
                {
                    ProcessChoices.Enabled = true;
                }
            }
            int.TryParse(tbTSID.Value, out currTSID);
            strWorkbookPath = tbWorkbookPath.Value;
        }
        protected void AjaxFileUpload1_UploadComplete(object sender, AjaxFileUploadEventArgs e)
        {
            strWorkbookPath = HDriveLocation + Path.GetFileName(e.FileName);
            tbWorkbookPath.Value = strWorkbookPath;
            AjaxFileUpload1.SaveAs(strWorkbookPath);
            ProcessChoices.Enabled = true;
        }

        protected void btnValidate_Click(object sender, EventArgs e)
        {
            bool processOption;
            bool.TryParse(rbChoices.SelectedValue, out processOption);
            strWorkbookPath = tbWorkbookPath.Value;
            TimesheetUtilites.ImportTimesheet imp = new ImportTimesheet(currTSID, strWorkbookPath, processOption);       
        }
    }
}

私の問題は単純です。イベント ハンドラー「AjaxFileUpload1_UploadComplete」は正常に動作し、ファイルを瞬時にアップロードしますが、「btnValidate_Click」イベントを発生させると、「tbWorkbookPath.Value」が空の文字列になり、「ProcessChoices.Enabled」プロパティは機能しません。変化する。言うまでもなく、「アップロード完了」イベント ハンドラーは、このファイル パスをキャプチャする唯一の機会なので、何が間違っているのか途方に暮れています。

私はASP.NETに投稿しましたが、答えはありません。どこから始めればよいか、誰か教えてもらえますか?

4

3 に答える 3

0

これは、ページの初期化時にポストバックとリセットの間に保持されるように、ページのViewStateに保存する必要がある情報です。プライベート文字列メンバーを次のようなものに変更します。

private string strWorkbookPath {
    get {
        return this.ViewState["strWorkbookPath"];
    }
    set {
        this.ViewState["strWorkbookPath"] = value;
    }
}

ViewStateとは何かについての入門書が必要な場合は、MSDN:ViewStateを使用したWebフォームページ値の保存に関するこの記事を確認してください。少し古いですが、それでもViewStateが現在どのように動作するかの基本を伝えています。

于 2013-02-18T17:43:28.603 に答える
0

ページに runat="server" 属性を持つ隠しフィールドを配置し、以下のスクリプトを使用します。

<script type="text/javascript">
    function uploadComplete(sender, args) {
            var filename = args.get_fileName();
            $("#hiddden_field_id").val(filename);
    }
</script>

これで、イベントでイメージ名を取得する必要があります。

于 2013-02-18T17:32:13.123 に答える
0

ページがリロードされず、ajax 呼び出しであったため、非表示フィールドではなく、その値をセッションに保存してみてください。そのため、検証のためにボタンがクリックされると、実際には別のリクエストが行われますが、このページ オブジェクトの非表示フィールドの値と非表示フィールドはまだ空です。セッションでその値のジョブが完了したら、そこから削除するか、別の値に設定します。

于 2013-02-18T17:34:57.520 に答える