من پروژم را با asp.net core 3.1 نوشتم که لازم است فایل های پیوست در دیتابیس ذخیره بشه جدول طراحی شده به صورت زیر است
کد دانلود فایل به شکل زیر است
//[post]
public async Task<IActionResult> Download(long? id)
{
var newsAttach = await _context.NewsAttach.FindAsync(id);
if (newsAttach == null )
{
return RedirectToAction("Error", "Home", new { errorMessage = " فایلی ضمیمه نشده است." });
}
return File(newsAttach.AttachFile, newsAttach.FileType, newsAttach.AttachTitle);
}
ولی با خطای زیر مواجه میشم در اینجا فایل من با فرمت png بوده.
FormatException: The header contains invalid values at index 0: '.png'
بنظرم بهتره که خود فایل رو در دیتابیس مستقیم ذخیره نکنید. مگر اینکه حجم فایلهاتون کمتر از 256 کیلوبایت باشه و تعدادش هم کم باشهو چون ذخیره فایل در دیتابیس بعد از مدتی بشدت حجم دیتابیس شما رو افزایش میده و سرعت رو پایین میاره. بهتره فایلهای پیوست در روت سایت ذخیره بشه و برای دانلود هم از همون روت سایت اقدام کنید. در این حالت فقط نام فایل در دیتابیس ذخیره میشه.
اما در هر صورت کدهای ذخیره تصویر در دیتابیس و نمایش اون رو براتون قرار میدم.
برای تبدیل تصویر به آرایه و ذخیره اون در دیتابیس میتونید از کدهای زیر استفاده کنید.
کدهایی که در کنترلر باید بنویسید:
public byte[] ImageUploaded { get; set; }
public async Task HandleSelection(IFileListEntry[] files)
{
var file = files.FirstOrDefault();
if (file != null)
{
var ms = new MemoryStream();
await file.Data.CopyToAsync(ms);
ImageUploaded = ms.ToArray();
}
}
در کدهای بالا تصویر شما تبدیل به یک آرایه باینری می شود و در ImageUploaded ذخیره می شود. شما کافیست آرایه ImageUploaded را در دیتابیس ذخیره کنید.
برای تبدیل آرایه باینری به تصویر هم میتونید از کد زیر استفاده کنید.
string ConvertImageToDisplay(byte[] image)
{
if (image != null)
{
var base64 = Convert.ToBase64String(image);
var finalString = string.Format("data:image/jpg;Base64,{0}", base64);
return finalString;
}
return "";
}
تاریخ :
1403/08/29
- ساعت :
07:15:00 PM
- بازدید :
79
- پاسخ :
0
|
تاریخ :
1403/08/18
- ساعت :
10:40:00 AM
- بازدید :
111
- پاسخ :
0
|
تاریخ :
1402/07/23
- ساعت :
04:01:00 PM
- بازدید :
1034
- پاسخ :
1
|
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
430
- پاسخ :
1
|
تاریخ :
1402/08/16
- ساعت :
10:38:00 AM
- بازدید :
1356
- پاسخ :
1
|
تاریخ :
1398/08/17
- ساعت :
01:27:00 AM
- بازدید :
4800
- پاسخ :
1
|
تاریخ :
1403/07/27
- ساعت :
03:21:00 PM
- بازدید :
216
- پاسخ :
1
|
تاریخ :
1403/07/26
- ساعت :
09:00:00 PM
- بازدید :
117
- پاسخ :
0
|
تاریخ :
1403/05/16
- ساعت :
09:57:00 AM
- بازدید :
397
- پاسخ :
2
|
تاریخ :
1403/06/25
- ساعت :
11:39:00 PM
- بازدید :
568
- پاسخ :
1
|
تاریخ :
1401/02/24
- ساعت :
02:17:00 PM
- بازدید :
2013
- پاسخ :
1
|
تاریخ :
1403/08/29
- ساعت :
07:15:00 PM
- بازدید :
79
- پاسخ :
0
|
تاریخ :
1403/08/18
- ساعت :
10:40:00 AM
- بازدید :
111
- پاسخ :
0
|
تاریخ :
1402/07/23
- ساعت :
04:01:00 PM
- بازدید :
1034
- پاسخ :
1
|
تاریخ :
1403/05/30
- ساعت :
09:22:00 AM
- بازدید :
430
- پاسخ :
1
|
تاریخ :
1402/08/01
- ساعت :
06:25:00 PM
- بازدید :
931
- پاسخ :
1
|
تاریخ :
1402/08/16
- ساعت :
10:38:00 AM
- بازدید :
1356
- پاسخ :
1
|
تاریخ :
1398/08/17
- ساعت :
01:27:00 AM
- بازدید :
4800
- پاسخ :
1
|
تاریخ :
1402/09/08
- ساعت :
07:34:00 PM
- بازدید :
1161
- پاسخ :
1
|
تاریخ :
1402/09/21
- ساعت :
11:10:00 PM
- بازدید :
599
- پاسخ :
1
|