Код, ранее реализованный в файле xls, сохраняет его в столбце таблицы, используя поток, который я использую тем же методом, но единственное изменение заключается в том, что сохраненный файл представляет собой файл типа xlsm или xlsx, который он сохраняет в столбец в базе данных
Когда я пытаюсь получить содержимое из базы данных и выбрасываю сохраненный файл xlsm или xlsx, я получаю сообщение об ошибке «Файл Excel обнаружил нечитаемый контент, вы хотите восстановить содержимое этой рабочей книги?»
Вот код для сохранения файла xlsm или xlsx
System.IO.Stream filestream = System.IO.File.Open(file, System.IO.FileMode.Open);
int fileLength = (int)filestream.Length;
byte[] input = new byte[fileLength];
filestream.Read(input, 0, fileLength);
string Sql = "insert into upload values(@contents)";
con.Open();
System.Data.SqlClient.SqlCommand c = new System.Data.SqlClient.SqlCommand(Sql, con);
c.Parameters.Add("@contents", System.Data.SqlDbType.Binary);
c.Parameters["@contents"].Value = input;
c.ExecuteNonQuery();
Для получения и отправки пользователю
SqlCommand comm = new SqlCommand("select contents from upload order by id desc", con);
SqlDataReader reader = comm.ExecuteReader();
int bufferSize = 32768;
byte[] outbyte = new byte[bufferSize];
long retval;
long startIndex = 0;
startIndex = 0;
retval = reader.GetBytes(0, startIndex, outbyte, 0, bufferSize);
while (retval > 0)
{
System.Web.HttpContext.Current.Response.BinaryWrite(outbyte);
startIndex += bufferSize;
if (retval == bufferSize)
{
retval = reader.GetBytes(2, startIndex, outbyte, 0, bufferSize);
}
else
{
retval = 0;
}
}