Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
 Аватар для werymag
26 / 11 / 1
Регистрация: 20.05.2015
Сообщений: 216

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

23.01.2023, 15:58. Показов 3059. Ответов 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
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,427
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
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,427
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
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,427
24.01.2023, 13:36
werymag, чтобы поддерживать корректную клиент-серверную архитектуру, веб-приложение писать не обязательно. У вас мог быть сервер любой природы (WebAPI, gRPC, WCF, etc...).

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

Цитата Сообщение от werymag Посмотреть сообщение
надо использовать сторонние сервисы с последующей передачей файла или получением ссылки.
Вот эти сторонние сервисы и должны были быть вашим серверным приложением. Теперь вам придётся пилить такой сервер)
0
 Аватар для Andrey-MSK
3354 / 2240 / 388
Регистрация: 14.08.2018
Сообщений: 7,574
Записей в блоге: 4
24.01.2023, 13:44
Цитата Сообщение от werymag Посмотреть сообщение
Да.
Прямое соединение с СУБД делают только в корпоративных (внутренних) сетях, где доступ к сети происходит через сервер авторизации предприятия. Во всех других случаях СУБД прячут от мира.
0
Эксперт .NET
 Аватар для Usaga
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,427
24.01.2023, 13:45
Andrey-MSK, в корпоративных сетях тоже прячут.
0
 Аватар для Andrey-MSK
3354 / 2240 / 388
Регистрация: 14.08.2018
Сообщений: 7,574
Записей в блоге: 4
24.01.2023, 13:47
Цитата Сообщение от Usaga Посмотреть сообщение
в корпоративных сетях тоже прячут.
Если в сеть нельзя попасть снаружи, то смысл прятать. Хотя всякое бывает
0
Эксперт .NET
 Аватар для Usaga
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,427
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
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,427
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
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,427
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
3354 / 2240 / 388
Регистрация: 14.08.2018
Сообщений: 7,574
Записей в блоге: 4
01.02.2023, 11:44
Цитата Сообщение от werymag Посмотреть сообщение
что я должен создавать объект Unit of Work для каждой операции
Dependency Injection есть для сервисов. Но смотрите, контекст EF будет жрать память при интенсивной работе...
0
 Аватар для IamRain
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,233
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
Ответ Создать тему
Новые блоги и статьи
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru