gpt4 book ai didi

c# - ASP.NET core 2.0 中如何处理上传的文件

转载 作者:太空宇宙 更新时间:2023-11-03 14:55:52 24 4
gpt4 key购买 nike

我们正在尝试将我们的代码从一段时间前编写的 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 从中获取字节:不需要额外的读取器。

关于c# - ASP.NET core 2.0 中如何处理上传的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49177508/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com