FileUpload внутри DetailsView: HasFile всегда false - PullRequest
8 голосов
/ 21 апреля 2011

Прежде всего, я НЕ пользуюсь UpdatePanel - похоже, это обычная проблема, но я даже не знал, что было, до того, как погуглил эту проблему.

У меня есть DetailsView, пытающийся загрузить файл и вставить имя файла в базу данных.Проблема в том, что HasFile всегда оказывается ложным!Есть идеи, что я сделал не так?

C #:

public partial class DocManager : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!(System.Convert.ToBoolean(Session["Admin"])))
            Response.Redirect("Index.aspx");
    }

protected void DetailsView1_ItemInserting(object sender, DetailsViewInsertEventArgs e)
{
    FileUpload fu1 = (FileUpload) DetailsView1.FindControl("FileUpload1");
    if (fu1 == null)
    {
        e.Cancel = true;
        StatusLabel.Text = "Could not find file upload";
    }
    if (fu1.HasFile)
    {
        try
        {
            string filename = Path.GetFileName(fu1.FileName);
            fu1.SaveAs(Server.MapPath("~/Docs/") + filename);
            StatusLabel.Text = "Upload status: File uploaded!";
            e.Values["FileName"] = filename;
        }
        catch (Exception ex)
        {
            StatusLabel.Text = "Upload status: The file could not be uploaded. The following error occured: " + ex.Message;
        }

    }
    else
    {
        e.Cancel = true;
        StatusLabel.Text = "No file uploaded";
        return;
    }

    DropDownList dd1 = (DropDownList)DetailsView1.FindControl("DropDownList2");
    DropDownList dd2 = (DropDownList)DetailsView1.FindControl("DropDownList4");
    e.Values["Type"] = dd1.SelectedValue;
    e.Values["MeetingID"] = dd2.SelectedValue;

}

protected void DetailsView1_ItemEditing(object sender, DetailsViewInsertEventArgs e)
{
    FileUpload fu1 = (FileUpload)DetailsView1.FindControl("FileUpload2");
    if (fu1 == null)
        e.Cancel = true;
    if (fu1.HasFile) {
        try
        {
            string filename = Path.GetFileName(fu1.FileName);
            fu1.SaveAs(Server.MapPath("~/Docs/") + filename);
            StatusLabel.Text = "Upload status: File uploaded!";
            e.Values["FileName"] = filename;
        }
        catch (Exception ex)
        {
            StatusLabel.Text = "Upload status: The file could not be uploaded. The following error occured: " + ex.Message;
        }
    }
    else
        e.Cancel = true;

    DropDownList dd1 = (DropDownList)DetailsView1.FindControl("DropDownList1");
    DropDownList dd2 = (DropDownList)DetailsView1.FindControl("DropDownList3");
    e.Values["Type"] = dd1.SelectedValue;
    e.Values["MeetingID"] = dd2.SelectedValue;

}

}

Единственное, что в PageLoad - это проверка того, что пользователь вошел в систему правильнобольше ничего не должно быть запущено до этого.

Сама форма:

<asp:DetailsView ID="DetailsView1" runat="server" Height="50px" Width="125px" 
    AutoGenerateRows="False" DataSourceID="Docs" DefaultMode="Insert"
     OnItemInserting="DetailsView1_ItemInserting"
     OnItemEditing="DetailsView1_ItemEditing"
    >
    <Fields>
        <asp:BoundField DataField="Documents.Title" HeaderText="Title" 
            SortExpression="Documents.Title" />
        <asp:TemplateField HeaderText="Type" SortExpression="Type">
            <EditItemTemplate>
                <asp:DropDownList ID="DropDownList1" runat="server">
                    <asp:ListItem Selected="True" Value="Presentation">Presentation</asp:ListItem>
                    <asp:ListItem Value="Handout">Handout</asp:ListItem>
                    <asp:ListItem Value="Minutes">Minutes</asp:ListItem>
                    <asp:ListItem Value="Agenda">Agenda</asp:ListItem>
                    <asp:ListItem Value="Other">Other</asp:ListItem>
                </asp:DropDownList>
            </EditItemTemplate>
            <InsertItemTemplate>
                <asp:DropDownList ID="DropDownList2" runat="server">
                    <asp:ListItem Selected="True" Value="Presentation">Presentation</asp:ListItem>
                    <asp:ListItem Value="Handout">Handout</asp:ListItem>
                    <asp:ListItem Value="Minutes">Minutes</asp:ListItem>
                    <asp:ListItem Value="Agenda">Agenda</asp:ListItem>
                    <asp:ListItem Value="Other">Other</asp:ListItem>
                </asp:DropDownList>
            </InsertItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label3" runat="server" Text='<%# Bind("Type") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="MeetingID" SortExpression="MeetingID">
            <EditItemTemplate>
                <asp:DropDownList ID="DropDownList3" runat="server" DataSourceID="Meetings" 
                    DataTextField="Title" DataValueField="MeetingID">
                </asp:DropDownList>
            </EditItemTemplate>
            <InsertItemTemplate>
                <asp:DropDownList ID="DropDownList4" runat="server" DataSourceID="Meetings" 
                    DataTextField="Title" DataValueField="MeetingID">
                </asp:DropDownList>
            </InsertItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label1" runat="server" Text='<%# Bind("MeetingID") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="FileName" SortExpression="FileName">
            <EditItemTemplate>
                <asp:FileUpload ID="FileUpload2" runat="server" />
            </EditItemTemplate>
            <InsertItemTemplate>
                <asp:FileUpload ID="FileUpload1" runat="server" />
            </InsertItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label2" runat="server" Text='<%# Bind("FileName") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:CommandField ShowEditButton="True" ShowInsertButton="True" />
    </Fields>
</asp:DetailsView>

ETA: вся форма:

<asp:Content ID="Content2" ContentPlaceHolderID="mainContent" Runat="Server">
<h1>Document Manager</h1>

<h2>Existing Documents</h2>
<asp:GridView ID="GridView1" runat="server" AllowSorting="True" 
    AutoGenerateColumns="False" DataSourceID="Docs"
    OnRowDeleting="GridView1_RowDeleting"
    DataKeyNames="DocID" BackColor="White" BorderColor="#E7E7FF" 
    BorderStyle="None" BorderWidth="1px" CellPadding="3" GridLines="Horizontal">
    <AlternatingRowStyle BackColor="#F7F7F7" />
    <Columns>
        <asp:BoundField DataField="Documents.Title" HeaderText="Title" 
            SortExpression="Documents.Title" />
        <asp:BoundField DataField="FileName" HeaderText="FileName" 
            SortExpression="FileName" />
        <asp:BoundField DataField="Type" HeaderText="Type" SortExpression="Type" />
        <asp:BoundField DataField="Meetings.Title" HeaderText="Meeting" 
            SortExpression="Meetings.Title" />
        <asp:CommandField ShowDeleteButton="True" ShowSelectButton="True" />
        <asp:HyperLinkField DataNavigateUrlFields="FileName" Text="Download" />
    </Columns>
    <FooterStyle BackColor="#B5C7DE" ForeColor="#4A3C8C" />
    <HeaderStyle BackColor="#4A3C8C" Font-Bold="True" ForeColor="#F7F7F7" />
    <PagerStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" HorizontalAlign="Right" />
    <RowStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" />
    <SelectedRowStyle BackColor="#738A9C" Font-Bold="True" ForeColor="#F7F7F7" />
    <SortedAscendingCellStyle BackColor="#F4F4FD" />
    <SortedAscendingHeaderStyle BackColor="#5A4C9D" />
    <SortedDescendingCellStyle BackColor="#D8D8F0" />
    <SortedDescendingHeaderStyle BackColor="#3E3277" />
</asp:GridView>
<h2>Add New</h2>
<asp:DetailsView ID="DetailsView1" runat="server" Height="50px" Width="125px" 
    AutoGenerateRows="False" DataSourceID="Docs" DefaultMode="Insert"
     OnItemInserting="DetailsView1_ItemInserting"
     OnItemEditing="DetailsView1_ItemEditing"
    >
    <Fields>
        <asp:BoundField DataField="Documents.Title" HeaderText="Title" 
            SortExpression="Documents.Title" />
        <asp:TemplateField HeaderText="Type" SortExpression="Type">
            <EditItemTemplate>
                <asp:DropDownList ID="DropDownList1" runat="server">
                    <asp:ListItem Selected="True" Value="Presentation">Presentation</asp:ListItem>
                    <asp:ListItem Value="Handout">Handout</asp:ListItem>
                    <asp:ListItem Value="Minutes">Minutes</asp:ListItem>
                    <asp:ListItem Value="Agenda">Agenda</asp:ListItem>
                    <asp:ListItem Value="Other">Other</asp:ListItem>
                </asp:DropDownList>
            </EditItemTemplate>
            <InsertItemTemplate>
                <asp:DropDownList ID="DropDownList2" runat="server">
                    <asp:ListItem Selected="True" Value="Presentation">Presentation</asp:ListItem>
                    <asp:ListItem Value="Handout">Handout</asp:ListItem>
                    <asp:ListItem Value="Minutes">Minutes</asp:ListItem>
                    <asp:ListItem Value="Agenda">Agenda</asp:ListItem>
                    <asp:ListItem Value="Other">Other</asp:ListItem>
                </asp:DropDownList>
            </InsertItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label3" runat="server" Text='<%# Bind("Type") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="MeetingID" SortExpression="MeetingID">
            <EditItemTemplate>
                <asp:DropDownList ID="DropDownList3" runat="server" DataSourceID="Meetings" 
                    DataTextField="Title" DataValueField="MeetingID">
                </asp:DropDownList>
            </EditItemTemplate>
            <InsertItemTemplate>
                <asp:DropDownList ID="DropDownList4" runat="server" DataSourceID="Meetings" 
                    DataTextField="Title" DataValueField="MeetingID">
                </asp:DropDownList>
            </InsertItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label1" runat="server" Text='<%# Bind("MeetingID") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField HeaderText="FileName" SortExpression="FileName">
            <EditItemTemplate>
                <asp:FileUpload ID="FileUpload2" runat="server" />
            </EditItemTemplate>
            <InsertItemTemplate>
                <asp:FileUpload ID="FileUpload1" runat="server" />
            </InsertItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label2" runat="server" Text='<%# Bind("FileName") %>'></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:CommandField ShowEditButton="True" ShowInsertButton="True" />
    </Fields>
</asp:DetailsView>
<asp:AccessDataSource ID="Docs" runat="server" 
    DataFile="~/App_Data/Database1.accdb" 
    DeleteCommand="DELETE FROM [Documents] WHERE [DocID] = ?" 
    InsertCommand="INSERT INTO [Documents] ([Title], [Type], [FileName], [MeetingID]) VALUES (@Title, @Type, @FileName, @MeetingID)" 
    SelectCommand="SELECT Documents.DocID, Documents.Title, Documents.FileName, Documents.Type, Meetings.Title, Documents.MeetingID FROM 
    (Documents LEFT OUTER JOIN Meetings ON Documents.MeetingID = Meetings.MeetingID)" 
    UpdateCommand= "UPDATE [Documents] SET [Title] = ?, [Type] = ?, [FileName] = ?, [MeetingID] = ? WHERE [DocID] = ?">
    <DeleteParameters>
        <asp:Parameter Name="DocID" Type="Int32" />
    </DeleteParameters>
    <InsertParameters>
        <asp:Parameter Name="Documents.Title" Type="String" />
        <asp:Parameter Name="Type" Type="String" />
        <asp:Parameter Name="FileName" Type="String" />
        <asp:Parameter Name="MeetingID" Type="Int32" />
    </InsertParameters>
    <SelectParameters>
        <asp:SessionParameter Name="?" SessionField="UserID" />
    </SelectParameters>
    <UpdateParameters>
        <asp:Parameter Name="Title" Type="String" />
        <asp:Parameter Name="Type" Type="String" />
        <asp:Parameter Name="FileName" Type="String" />
        <asp:Parameter Name="MeetingID" Type="Int32" />
        <asp:Parameter Name="DocID" Type="Int32" />
    </UpdateParameters>
</asp:AccessDataSource>
<asp:Label ID="StatusLabel" runat="server" Text="Label"></asp:Label>
<asp:AccessDataSource ID="Meetings" runat="server" 
    DataFile="~/App_Data/Database1.accdb" 
    SelectCommand="SELECT [MeetingID], [Title] FROM [Meetings] WHERE ([AdminID] = ?)">
    <SelectParameters>
        <asp:SessionParameter Name="AdminID" SessionField="UserID" Type="Int32" />
    </SelectParameters>
</asp:AccessDataSource>

Я также редактировал в остальной части кода C #выше, это было не так долго

Элемент формы на главной странице:

<body style="background-color: rgb(231, 231, 255);height:100%;margin:0px;padding:0px">
<form id="form1" runat="server">

ETA: Я обнаружил проблему.Я использовал пустой текстовый файл в качестве теста - который читал как 0 байтов, вводя в заблуждение загрузчик файла, думая, что у него нет файла.Добавление текста в файл делает его отлично работающим.

Спасибо за помощь всем!

1 Ответ

8 голосов
/ 26 апреля 2011

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

Рассказ о том, почему файл размером 0 байт - это не то же самое, что никакой файл вообще, не должен выполняться в другом месте.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...