Когда я получаю доступ к своему ashx, например download.ashx? Id = 18, он получает файл, но затем, когда появляется диалоговое окно сохранения, он хочет, чтобы я сохранил download.ashx, а не файл, который я сохранил в базе данных (позволяетскажем, mypdf.pdf) Если вы откроете файл загрузки, он откроется в Visual Studio и на самом деле ничего полезного не показывает.Что вызывает это, я пробовал во многих браузерах и на многих машинах, и все это делает то же самое?
Спасибо
string id = ctx.Request.QueryString["id"];
string name = null;
string mime = null;
SqlConnection con = new SqlConnection(CONN);
SqlCommand cmd = new SqlCommand("DownloadActivityFile", con);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@aid", id);
byte[] afile = null;
try
{
con.Open();
SqlDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
mime = reader["ActivityFileMIME"].ToString();
ctx.Response.ContentType = mime;
afile = (byte[])reader["ActivityFile"];
name = reader["ActivityFileName"].ToString();
}
ctx.Response.Buffer = false;
ctx.Response.ContentType = mime;
ctx.Response.AddHeader("content-disposition", string.Format("attachment; {0}", name));
ctx.Response.Clear();
ctx.Response.BinaryWrite(afile);
ctx.Response.End();
}
catch (Exception e)
{
ctx.Response.Write(e.ToString());
}
finally
{
con.Close();
}