0

ここ数日間、ある問題で立ち往生しており、困惑しています。したがって、このフォームには 2 つのファイル アップロード入力があり、3 つのボタンには create、cancel、populate の値があります。ユーザーはファイルを参照して選択し、送信された値がアクション メソッドに設定されている [アップロード] ボタンを押します。ファイルを保存し、ステート マシンの yield などを使用してデータを解析する静的クラスと、いくつかの json シリアル化を使用して、ファイルを appdata に保存します。 /uploads folder.cancel を押すと、いくつかの機能を実行し、create を押すと、データを解析せずに保存します。すべてのボタン入力は、このページの同じアクション メソッドに送信されます。サーバー上の私のテスト環境では、すべてがローカルマシンで完全に機能し、populate ルーチンが実行されていないようです。try catch とログを例外テーブルに追加しましたが、何も機能しません。テスト環境でデバッグできません。解析は言うまでもなく、ユーザーがファイルを選択して入力を押した場合、最初にファイル形式が正しい形式であるかどうかを確認し、無効な形式を添付して例外をスローしようとしますが、それをキャッチしません。今面白いのは、同じアクションメソッド内で保存ボタンをクリックすることです。無効なファイルを添付すると、エラー処理がエラーをキャッチします。私はただ困惑しています。提案してください!!私のエラー処理はエラーをキャッチします。私はただ困惑しています。提案してください!!私のエラー処理はエラーをキャッチします。私はただ困惑しています。提案してください!!

 <legend>Enter a new Run Log Entry</legend>
            @using (Html.BeginForm("Create", "RunLogEntry", FormMethod.Post, new { enctype = "multipart/form-data" }))
            {

                @Html.ValidationSummary(true)
                <div class="exception">@(ViewBag.ErrorMessage)</div>
                <div class="bodyContent">
                    <span class="leftContent">Load List File (Select): </span><span class="rightContent">
                        <input type="file" name="file" id="file1" style="width: 500px" />
                    </span>
                </div>
                if (Model.LoadListStoredFileName != null)
                                   {
                <div class="bodyContent">
                    <span class="leftContent">Attached Load List: </span><span class="rightContent">
                        @Html.ActionLink(Model.LoadListStoredFileName, "Download", new { @file = Model.LoadListStoredFileName })
                    </span>
                </div>
                                   }
                <div class="bodyContent">
                    <span class="leftContent">Output File (Select): </span><span class="rightContent">
                        <input type="file" name="file" id="file2" style="width: 500px" />
                    </span>
                </div>
                if (Model.OutputStoredFileName != null)
                                   {
                <div class="bodyContent">
                    <span class="leftContent">Attached Output: </span><span class="rightContent">
                        @Html.ActionLink(Model.OutputStoredFileName, "Download", new { @file = Model.OutputStoredFileName })
                    </span>
                </div>
                                   }
                <div class="bodyContent">
                    <span class="leftContent">Import Files: </span>
                    <button name="submit" class="art-button" type="submit" value="Populate" style="width: 100px">
                        Upload</button>
                    <button name="submit" class="art-button" type="submit" value="Remove" style="width: 100px">
                        Remove</button>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Operator")
                    </span><span class="rightContent">
                        @Html.DropDownList("OperatorID", String.Empty)
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Run ID")
                    </span><span class="rightContent">[Generated] </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Run Start Date / Time")
                    </span><span class="rightContent">
                        @Html.EditorFor(model => model.RunDate)
                        &nbsp;
                        @Html.DropDownList("Hour", ListHelpers.HourList())
                        :
                        @Html.DropDownList("Minute", ListHelpers.Minute15List())
                        &nbsp;
                        @Html.DropDownList("AMPM", ListHelpers.AMPMList())
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("System")
                    </span><span class="rightContent">
                        @Html.DropDownList("SystemID", String.Empty)
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Run Type")
                    </span><span class="rightContent">
                        @Html.DropDownList("RunTypeID", String.Empty)
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Run Description")
                    </span><span class="rightContent">
                        @Html.TextAreaFor(model => model.RunDescription, new { style = "width: 600px; height=30px" })
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Assay Performance Issues")
                    </span><span class="rightContent">
                        @Html.DropDownList("AssayPerformanceIssues1", ListHelpers.YesNoList())
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Tests/Cycles Requested")
                    </span><span class="rightContent">
                        @Html.EditorFor(model => model.SPTestsRequested)
                    </span>
                </div>

                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Tests/Cycles Completed")
                    </span><span class="rightContent">
                        @Html.EditorFor(model => model.SPTestsCompleted)
                    </span>
                </div>

                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Run Status")
                    </span><span class="rightContent">
                        @Html.DropDownList("RunStatusID", String.Empty)
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Assay")
                    </span><span class="rightContent">
                        @Html.ListBoxFor(model => model.SelectedAssayIDs, new MultiSelectList(RunLog.Domain.Lists.GlobalList.AssayListItems(), "ID", "Name", Model.SelectedAssayIDs))
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Error Code")
                    </span><span class="rightContent"><span id="ChildDialogLink" class="treeViewLink">Click
                        here to Select Error Codes</span>
                        <br />
                        <span id="ErrorCodeDisplay" style="cursor: pointer; text-decoration: underline;">@(Model.ErrorDescription)</span>
                        @Html.HiddenFor(model => model.ErrorDescription)
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Service Entry Request")
                    </span><span class="rightContent">
                        @Html.DropDownList("ServiceRequest", ListHelpers.YesNoList())
                    </span>
                </div>
                <div class="bodyContent">
                    <span class="leftContent">
                        @Html.Label("Problem Description")
                    </span><span class="rightContent">
                        @Html.TextArea("ProblemDescription", new { style = "width: 600px; height: 30px" })
                    </span>
                </div>
                <p>
                    <input id="LogType" type="hidden" value="Run" />
                    <input id="ID" type="hidden" value="0" />
                    @if (Model.ExitCode == "1")
                    {
                        @Html.Hidden("ExitCode", Model.ExitCode)
                    }
                    else
                    {
                        <input id="ExitCode" type="hidden" value='0' />
                    }
                </p>
                @Html.HiddenFor(model => model.MaxReplicateId)
                @Html.HiddenFor(model => model.MinReplicateId)
                @Html.HiddenFor(model => model.OutputFileName)
                @Html.HiddenFor(model => model.OutputStoredFileName)
                @Html.HiddenFor(model => model.LoadListFileName)
                @Html.HiddenFor(model => model.LoadListStoredFileName)
                @Html.HiddenFor(model => model.MinTestCompletionDate)
                @Html.HiddenFor(model => model.MaxTestCompletionDate)
                <div class="bodyContent">
                    <span class="leftContent"></span><span class="rightContent">
                        <button name="submit" class="art-button" type="submit" value="Create">
                            Create</button></span>
                </div>
            }
        </fieldset>

Now the controller action method as follows:

   [HttpPost]
        public ActionResult Create(RunLogEntry runLogEntry, String ServiceRequest, string Hour, string Minute, string AMPM,
                                     string submit, IEnumerable<HttpPostedFileBase> file, String AssayPerformanceIssues1)
        {

 if (submit == "Create")
            {


                    if (file.ElementAt(0) != null && !file.ElementAt(0).FileName.Contains("json"))
                    {
                        ModelState.AddModelError(string.Empty, "Please attach a valid .JSON file for Load List selection");
                    }

                    if (file.ElementAt(1) != null && !file.ElementAt(1).FileName.Contains("out"))
                    {
                        ModelState.AddModelError(string.Empty, "Please attach a valid .OUT file for Load List selection");
                    }

           }


if (submit == "Populate")
            {
try
{
if (file.Count() > 0)
    {
                        foreach (var modelValue in ModelState.Values)
                        {
                            modelValue.Errors.Clear();
                        }

                        if (file.ElementAt(0) != null && !file.ElementAt(0).FileName.Contains("json"))
                        {
                            ModelState.AddModelError(string.Empty, "Please attach a valid .JSON file for Load List selection");
                        }
                        else if (file.ElementAt(0) != null)
                        {
                            //If users are attaching another file, delete previous one
                            if ((System.IO.File.Exists(runLogEntry.LoadListStoredFileName)))
                                System.IO.File.Delete(runLogEntry.LoadListStoredFileName);

                            //Save LoadList File:
                            DateTime uploadDate = DateTime.Now;
                            string destinationPath = string.Format("{0}\\{1}\\{2}\\{3}\\", Server.MapPath("~/App_Data/uploads"), uploadDate.ToString("yyyy"), uploadDate.ToString("MMM"), uploadDate.ToString("dd"));
                            if (!Directory.Exists(destinationPath))
                                Directory.CreateDirectory(destinationPath);

}
}
4

1 に答える 1

0

アプリケーション(log4netなど)にロガーを追加し、ここで正確に何が起こっているかを監視します。同じ名前のタグがいくつかあります。それが何らかの副作用を引き起こす可能性はありますか?

于 2012-06-26T09:53:17.273 に答える