我正致力于开发简单的Drag& amp;使用Visual Studio 2013和AjaxControlToolkit v15.0删除多个文件上传器。我有AjaxFileUpload控件,但我注意到浏览器上只显示一个文件
另外,我发现OnUploadComplete事件没有触发。我通过在事件中插入警报来测试事件,并且它也没有运行,上传的文件也没有显示在项目或数据库表中。
这是我的代码:
.aspx文件
<form id="form1" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server">
</asp:ScriptManager>
<div align="center">
<asp:AjaxFileUpload ID="AjaxFileUpload1" runat="server" MaximumNumberOfFiles="10" OnUploadComplete="File_Upload" Width="500px" Mode="Auto" />
</div>
</form>
.aspx.cs文件
protected void File_Upload(object sender, AjaxFileUploadEventArgs e)
{
SqlConnection con = new SqlConnection(abc);
try {
string filename = Path.GetFileName(e.FileName);
string strDestPath = Server.MapPath("~/Documents/");
SqlCommand cmd = new SqlCommand("INSERT INTO upload (name, path) VALUES(@FileName, @FilePath)");
cmd.Parameters.AddWithValue("@FileName", filename);
cmd.Parameters.AddWithValue("@FilePath", "Documents/" + filename);
con.Open();
cmd.ExecuteNonQuery();
con.Close();
//Save file to project
AjaxFileUpload1.SaveAs(@strDestPath + filename);
}
catch (Exception er)
{
Response.Write("<script language='javascript'> alert(' problem');</script>");
}
finally { con.Close(); }
}
的web.config
<system.web>
<compilation debug="true" targetFramework="4.5">
<assemblies>
<add assembly="System.Design, Version=4.0.0.0, Culture=neutral, PublicKeyToken=B03F5F7F11D50A3A"/>
<add assembly="System.Web.Extensions.Design, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
</assemblies>
</compilation>
<httpHandlers>
<add verb="*" path="AjaxFileUploadHandler.axd" type="AjaxControlToolkit.AjaxFileUploadHandler, AjaxControlToolkit"/>
</httpHandlers>
<httpRuntime targetFramework="4.5"/>
</system.web>
<system.webServer>
<validation validateIntegratedModeConfiguration="false"/>
<handlers>
<add name="AjaxFileUploadHandler" verb="*" path="AjaxFileUploadHandler.axd" type="AjaxControlToolkit.AjaxFileUploadHandler, AjaxControlToolkit"/>
</handlers>
</system.webServer>
任何解决方案?
答案 0 :(得分:0)
我的工作:我创建了一个名为&#34; data-upload-type&#34;的数据属性。在所有AjaxFileUpload控件上并将其设置为类型的名称(我用来知道如何处理文件的上传类型)。然后我设置客户端调用以获取该值并设置具有相同值的cookie。 cookie是在服务器端函数上接收的,我根据收到的值进行分支。
这是一个例子:
这是我常见的客户端开始上传:
function StartUpload(sender, args) {
var t = $(sender._element).attr('data-upload-type');
document.cookie = 'upload-type=' + $(sender._element).attr('data-upload-type') + ';';
}
我的页面代码丢弃了一个ajaxcontrols:
<asp:AjaxFileUpload ID="afuUploader1" runat="server" OnClientUploadStart="StartUpload" OnUploadComplete="UploadComplete" OnClientUploadComplete="UploadComplete" data-upload-type="UploadType2" / >
然后在您的服务器端上传呼叫,只需检查Response.Cookies(&#34; upload-type&#34;)。像魅力一样工作!