I have ASP MVC app, MS SQL and C#. I download a file to MS SQL, then I upload the file from DB. After this the file become unreadable. I can't understand what happens. Below code, which returns the file to client.
public string CreateFile(HttpPostedFileBase file)
{
string stream_id = String.Empty;
try
{
int size = file.ContentLength;
string name = file.FileName;
string contentType = file.ContentType;
byte[] bytes = new byte[size];
file.InputStream.Read(bytes, 0, size);
string constr = ConfigurationManager.ConnectionStrings["PokrovConnectionString"].ConnectionString;
using (TransactionScope ts = new TransactionScope())
{
using (SqlConnection con = new SqlConnection(constr))
{
string query = "DECLARE @MyTableVar TABLE (stream_id uniqueidentifier);"
+ "INSERT INTO Files(name, file_stream) OUTPUT INSERTED.stream_id INTO @MyTableVar VALUES(@name, @file_stream);"
+ "SELECT TOP (1) @Identity = stream_id FROM @MyTableVar;";
using (SqlCommand cmd = new SqlCommand(query))
{
cmd.Connection = con;
cmd.Parameters.Add("@name", SqlDbType.VarChar).Value = Path.GetFileName(file.FileName);
cmd.Parameters.Add("@file_stream", SqlDbType.VarBinary).Value = bytes;
SqlParameter idParam = cmd.Parameters.Add("@Identity", SqlDbType.NVarChar, 1000);
idParam.Direction = ParameterDirection.Output;
con.Open();
cmd.ExecuteNonQuery();
con.Close();
stream_id = (string)idParam.Value;
}
}
ts.Complete();
}
}
catch { }
return stream_id;
}
public FileContentResult GetFile(Guid stream_id, string contentType = "application/octet-stream")
{
SqlDataReader rdr;
byte[] fileContent = null;
string mimeType = "";
string fileName = "";
string connect = onfigurationManager.ConnectionStrings["PokrovConnectionString"].ConnectionString;
bool success = false;
using (var conn = new SqlConnection(connect))
{
var qry = "SELECT file_stream, name, file_type FROM Files WHERE stream_id = @stream_id";
var cmd = new SqlCommand(qry, conn);
cmd.Parameters.AddWithValue("@stream_id", stream_id);
conn.Open();
try
{
rdr = cmd.ExecuteReader();
if (rdr.HasRows)
{
rdr.Read();
fileContent = (byte[])rdr["file_stream"];
mimeType = rdr["file_type"].ToString();
fileName = rdr["name"].ToString();
}
success = true;
}
catch
{
return null;
}
}
if (success == true)
{
FileContentResult newFile = new FileContentResult(fileContent, contentType);
newFile.FileDownloadName = fileName;
return newFile;
}
return null;
}