我们正在尝试将我们的代码从一段时间前编写的 ASP.NET 迁移到 ASP.NET Core 2.0。
这段代码在 SQL Server 中存储文档并检索它。
***Original Code:***
protected void btnUpload_Click(object sender, EventArgs e)
{
foreach (HttpPostedFile postedFile in multipleUpload.PostedFiles)
{
string filename = Path.GetFileName(postedFile.FileName);
string contentType = postedFile.ContentType;
using (Stream fs = postedFile.InputStream)
{
using (BinaryReader br = new BinaryReader(fs))
{
byte[] bytes = br.ReadBytes((Int32)fs.Length);
string constr = ConfigurationManager.ConnectionStrings["ab"].ConnectionString;
using (SqlConnection con = new SqlConnection(constr))
{
string query = "insert into ftr_UploadMultiple (name,contentType,data) values (@Name, @ContentType, @Data)";
using (SqlCommand cmd = new SqlCommand(query))
{
cmd.Connection = con;
cmd.Parameters.AddWithValue("@Name", filename);
cmd.Parameters.AddWithValue("@ContentType", contentType);
cmd.Parameters.AddWithValue("@Data", bytes);
con.Open();
cmd.ExecuteNonQuery();
con.Close();
我们确实尝试了以下代码,它只在数据库中存储了 0 个字节:关于此的任何建议都应该非常有帮助。
我们在 ASP.NET Core 2.0 中的代码
if (file.Length > 0)
{
using (var stream = new
FileStream(filePath, FileMode.Create))
{
await file.CopyToAsync(stream);
using (BinaryReader br = new BinaryReader(stream))
{
byte[] bytes = br.ReadBytes((Int32)stream.Length);
string constr = "<Connection String";
using (SqlConnection con = new SqlConnection(constr))
{
string query = "insert into ftr_UploadMultiple (data) values (@Data)";
using (SqlCommand cmd = new SqlCommand(query))
{
cmd.Connection = con;
cmd.Parameters.AddWithValue("@Data", bytes);
con.Open();
cmd.ExecuteNonQuery();
con.Close();
我特意删除了结尾的 }
。此外,由于 Response.Binarywrite()
在 ASP.NET Core 2.0 中不可用,因此在下载已上传的文件时面临问题。
调用CopyToAsync
将字节从上传文件复制到文件流后,文件流的位置在末尾。当您随后尝试从文件流中读取时,您只会读取末尾的空字节,从而导致读取 0 个字节。
最简单的解决方案是在阅读之前添加以下内容:
stream.Position = 0;
但是,除非您确实需要也将文件写入文件系统,否则这只是无关紧要的工作。最好将上传文件的流复制到 MemoryStream
,然后简单地使用 ToArray
从中获取字节:不需要额外的读取器。
我是一名优秀的程序员,十分优秀!