Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216

Прогресс загрузки файлов в базу данных (Entity Framework +PostgreSQL)

23.01.2023, 15:58. Показов 3201. Ответов 45

Студворк — интернет-сервис помощи студентам
Храню файлы (до 10 мб) в базе данных в виде бинарного массива (понимаю, что правильно хранить на вебсервере со ссылками, но пока не хочется заморачиваться)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  
 
 public class ItemTb
    { 
        ...
        public virtual ICollection<FilesDB> Files { get; set; } = new List<FilesDB>();
        ...
    }    
    
    
    public class FilesTb
    {
        ...
        public byte[] File { get; set; }
        ...
    }
И возник вопрос, как отображать прогресс отправки файлов. Есть ли какая-то хитрость, которая позволит это сделать.
Просто в некоторых местах интернет может быть плохим или нестабильным и хотелось бы понимать, как идет прогресс отправки файла.

Пока из мыслей только разбивать файлы на части и отправлять их частями на сервер. Но выглядит как-то костыльно.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.01.2023, 15:58
Ответы с готовыми решениями:

Entity Framework не создает базу данных
Здравствуйте. возникла какая-то непонятная проблема. работал с проектом в visual studio (база создавать через code first entity framework),...

Базу данных создает,но не таблицу. Entity Framework
public ActionResult Index(ToDoItem _item) { ToDoItem item = new ToDoItem() { Name = &quot;fgdfgv&quot;, Description =...

Entity Framework добавление обьекта в базу данных
Имеется такой обьект: public class Document { public Document(string title, bool withSections) { Title = title; ...

45
 Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216
24.01.2023, 11:37  [ТС]
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от Andrey-MSK Посмотреть сообщение
А в пакете с арендой СУБД нету разве FTP/HTTP сервера?
Всё своё, родное (IP и сервер)

Цитата Сообщение от Рядовой Посмотреть сообщение
Ну я бы это сделал на asp net core
Спасибо, подумаю над этим.
Цитата Сообщение от HF Посмотреть сообщение
Куда заливать последовательно? В БД?
Ну а куда же.
Цитата Сообщение от HF Посмотреть сообщение
Чего тут я не так понял? Парень хочет в БД заливать файл последовательно, за 10 заходов
Не хочу, просто описал как пример того как костыльно можно получить прогресс отправки файла в БД.

В целом ответ я получил:
Получить текущий прогресс отправки данных в БД в лоб нельзя, надо использовать сторонние сервисы с последующей передачей файла или получением ссылки.
Осталось выбрать сторонний инструмент для отправки и скачивания файлов.
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,553
24.01.2023, 13:04
werymag, какой ещё "сторонний сервис"? У вас на сервер файлы как попадают?
0
 Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216
24.01.2023, 13:12  [ТС]
Цитата Сообщение от Usaga Посмотреть сообщение
werymag, какой ещё "сторонний сервис"? У вас на сервер файлы как попадают?
Методом Insert бинарного массива (используя EF) из клиента на локальной машине.
Или вы про буфер/оперативную память/транзакцию сервера? Тут не силен как это реализовано внутри сервера PostgreSQL.
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,553
24.01.2023, 13:22
werymag, т.е. у вас клиенты напрямую к серверу СУБД обращаются?
0
1152 / 860 / 263
Регистрация: 30.04.2009
Сообщений: 3,603
24.01.2023, 13:26
жесть ...
0
 Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216
24.01.2023, 13:29  [ТС]
Цитата Сообщение от Usaga Посмотреть сообщение
werymag, т.е. у вас клиенты напрямую к серверу СУБД обращаются?
Да. Это не веб приложение, если что.
Какие ещё вы предложите варианты?
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,553
24.01.2023, 13:36
werymag, чтобы поддерживать корректную клиент-серверную архитектуру, веб-приложение писать не обязательно. У вас мог быть сервер любой природы (WebAPI, gRPC, WCF, etc...).

И он здесь нужен. Во-первых, вы базу выставили в сеть. А это дыра в безопасности. Во-вторых, вы потеряли контроль над происходящим. И уже столкнулись с тем, что такой контроль вам нужен.

Цитата Сообщение от werymag Посмотреть сообщение
надо использовать сторонние сервисы с последующей передачей файла или получением ссылки.
Вот эти сторонние сервисы и должны были быть вашим серверным приложением. Теперь вам придётся пилить такой сервер)
0
 Аватар для Andrey-MSK
3367 / 2253 / 388
Регистрация: 14.08.2018
Сообщений: 7,624
Записей в блоге: 4
24.01.2023, 13:44
Цитата Сообщение от werymag Посмотреть сообщение
Да.
Прямое соединение с СУБД делают только в корпоративных (внутренних) сетях, где доступ к сети происходит через сервер авторизации предприятия. Во всех других случаях СУБД прячут от мира.
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,553
24.01.2023, 13:45
Andrey-MSK, в корпоративных сетях тоже прячут.
0
 Аватар для Andrey-MSK
3367 / 2253 / 388
Регистрация: 14.08.2018
Сообщений: 7,624
Записей в блоге: 4
24.01.2023, 13:47
Цитата Сообщение от Usaga Посмотреть сообщение
в корпоративных сетях тоже прячут.
Если в сеть нельзя попасть снаружи, то смысл прятать. Хотя всякое бывает
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,553
24.01.2023, 13:53
Andrey-MSK, смысл в централизованной, инкапсулированной бизнес-логике и правах доступа клиентов.
0
 Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216
24.01.2023, 14:06  [ТС]
Цитата Сообщение от Usaga Посмотреть сообщение
А это дыра в безопасности.
Да и хрен с ним пока. Там не будет конфиденциальных данных, из опасностей там только падение сервера.
Да и не уверен, что серверное приложение написанное без должного опыта (коего у меня пока нет), будет надежнее системы аутентификации встроенной в PostgreSQL.

Но буду разбираться. Есть ли готовые решения?

Цитата Сообщение от Usaga Посмотреть сообщение
У вас мог быть сервер любой природы (WebAPI, gRPC, WCF, etc...).
Почитаю, что там.
Хотелось бы что-то что можно запихать в докер вместе с PostgreSQL.

Добавлено через 31 секунду
Цитата Сообщение от Usaga Посмотреть сообщение
правах доступа клиентов.
А роли в БД для этого использовать - плохой тон?
0
1152 / 860 / 263
Регистрация: 30.04.2009
Сообщений: 3,603
24.01.2023, 14:39
werymag, у вас прям строка подключения каждый раз строится с указанием логина и пароля конкретного пользователя?
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,553
24.01.2023, 14:41
werymag, да, плохой тон. В основном из-за никакущей гибкости.
1
 Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216
24.01.2023, 17:53  [ТС]
Цитата Сообщение от nicolas2008 Посмотреть сообщение
werymag, у вас прям строка подключения каждый раз строится с указанием логина и пароля конкретного пользователя?
На текущий момент я над этим думаю, пока с голым PostgreSQL думаю сделать так:
1. Через строку с пользователем/ролью с назначенными правами подключаюсь к БД.
2. Создаю видимость аутентификации конкретного пользователя (проверить - есть ли такой пользователь и совпадает ли хеш его пароля в моей, доступной для текущей роли только для чтения таблице Users ).

В данном случае безопасность особой роли не играет, пароли нужны чисто что бы левый человек не зашел и не испортил все данные.
То есть если у клиента есть доступ определённого уровня, то технически он имеет доступ ко всем данным этого уровня.

Очевидно, что это неправильно, но что ещё можно сделать не создавая своё серверное приложение? На текущем этапе мне хотелось бы отложить эту часть.

Добавлено через 2 часа 33 минуты
О сервер восстал). И ещё вопрос, получается при использовании бекенд сервера я не смогу использовать EF? Если так, то это крайне грустно, так как он радикально упрощал работу.
0
 Аватар для Рядовой
1524 / 914 / 329
Регистрация: 17.05.2015
Сообщений: 3,438
24.01.2023, 19:33
Цитата Сообщение от werymag Посмотреть сообщение
И ещё вопрос, получается при использовании бекенд сервера я не смогу использовать EF? Если так, то это крайне грустно, так как он радикально упрощал работу.
Ваш ef переезжает на серверное приложение, которое и будет писать в бд. А библиотеку классов можете сделать общей для клиента и сервера
1
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,553
25.01.2023, 08:55
Цитата Сообщение от Рядовой Посмотреть сообщение
А библиотеку классов можете сделать общей для клиента и сервера
Только Христа ради, не делайте общие классы сущностей EF'а. Заведите отдельные DTO для обмена между клиентом и сервером. Если серверное приложение будет сделано на базе WebAPI (HTTP), то можно подтянуть в него Swagger, который позволит сгенерировать клиент по метаданным сервера и даже не шарить никакие библиотеки классов DTO. Но это опционально.
0
 Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216
01.02.2023, 11:26  [ТС]
Раз все умные уже тут и вопрос в продолжении темы (дабы не множить сущности). Подскажите.

(Речь о клиенте, не о сервере)
Допустим я хочу связать клиентское приложение с контролами WebApi через патернн Repository.
Если у меня несколько десятков сильно разных таблиц, получается, что для каждого из них я вынужден делать свой репозиторий? По идее можно собрать их используя паттерн Unit of Work, но всё равно как-то громоздко получается. Часть из них будут реализованы через обобщения, но всё равно будет много сущностей.
Так же видел утверждение, что контекст подключения должен существовать одну бизнес операцию, то есть получается - что я должен создавать объект Unit of Work для каждой операции?

Оптимально ли? Правилен ли такой подход?

Тут нюанс ещё в том, что мне надо использовать ещё и локальную БД на клиенте, для сохранения данных с сервера.

Добавлено через 4 минуты
Ну и в целом, конечно, мозг ломает, у меня между действием "нажать на кнопку в приложении" и "запросить данные в БД" чуть ли не десяток абстракций вырисовывается...
0
 Аватар для Andrey-MSK
3367 / 2253 / 388
Регистрация: 14.08.2018
Сообщений: 7,624
Записей в блоге: 4
01.02.2023, 11:44
Цитата Сообщение от werymag Посмотреть сообщение
что я должен создавать объект Unit of Work для каждой операции
Dependency Injection есть для сервисов. Но смотрите, контекст EF будет жрать память при интенсивной работе...
0
 Аватар для IamRain
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,234
01.02.2023, 13:12
Цитата Сообщение от werymag Посмотреть сообщение
что я должен создавать объект Unit of Work для каждой операции?
Вы сейчас не о том думаете. Чтобы отображать прогресс, можно слать файл по веб-сокету, обратно по сокету слать условные каждые 5% прогресса.
По-завершению закачки EF, на стороне сервера делает вставку перенесенных данных и после SaveChanges() отправляет финальный ProgressReport в 100%. Примерно так.

Добавлено через 9 минут
Можно и кастомные бинарные протоколы на голых сокетах использовать (вывод прогресса, возможность докачки при обрыве связи), но судя по характеру вопроса, это вам реализовывать сильно дольше. Поэтому вебсокеты/SignalR - само то.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.02.2023, 13:12
Помогаю со студенческими работами здесь

Условие при загрузки связанных данных Entity Framework Code First
Добрый день, господа, возник такой вопрос: Имеются классы контекста Entity Framework C# Code First Персона public class person ...

Entity framework не добавляет новое значение в базу данных
Всем привет, делаю возможность добавления в друзья у себя на сайте. У меня есть база, в которой хранятся друзья. С колонками UserId,...

Создать базу данных на SQLite через entity framework
Добрый день, задача по коду (code first) создать базу данных на SQlite через entity framework, можете подсказать как правильно это сделать?...

Entity Framework. Добавление данных в базу из текстового файла
Имеем кнопку, при нажатии на которую таблица должна заполняться из текстового файла: protected void AddButton_Click(object sender,...

Изменить базу данных с MySQL на SQLite в проекте с Entity Framework code first
Добрый день, подскажите пожалуйста: Имеется проект C# приложение windows form с entity framework code first на борту. Entity использует...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
40
Ответ Создать тему
Опции темы

Новые блоги и статьи
[golang] Алгоритм «Хак Госпера»
alhaos 17.05.2026
Алгоритм «Хак Госпера» Хак Госпера (Gosper's Hack) — алгоритм нахождения следующего по величине числа с тем же количеством установленных бит. Придуман Биллом Госпером в 1970-х, опубликован в. . .
Рисование бинарного древа до 6-го колена на js, svg.
russiannick 17.05.2026
<svg width="335" height="240" viewBox="0 0 335 240" fill="#e5e1bb"> <style> <!]> </ style> <g id="bush"> </ g> </ svg> function fn(){ let rost;/ / высота древа let xx=165,yy=210,w=256;
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов, содержащихся в реализации модуля. По-умолчанию все члены модуля доступны: module Foo let x = 10 let boo () = printfn "boo" . . .
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции. <!DOCTYPE html> <html lang="ru"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible". . .
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru