С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
 Аватар для Fatmarmelad
34 / 10 / 2
Регистрация: 20.02.2016
Сообщений: 1,613

В MVC данные не должны проверяться в модели?

03.09.2021, 20:28. Показов 775. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
День добрый!
На просторах интернета прочитал, что при создании приложения MVC, данные не должны проверяться в модели, а проходить через модель должны только уже проверенные данные, которые должны проверяться в контроллере.
Что по этому поводу считает официальная наука?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.09.2021, 20:28
Ответы с готовыми решениями:

Создайте страницу для вычисления тригонометрических функций. Вводимые пользователем данные должны проверяться.
Создайте страницу (рис. 1) для вычисления тригонометрических функций. Вводимые пользователем данные должны проверяться немедленно после...

В поле данные не должны превышать значения другого поля и должны быть не менее 0
У меня в задаче магазин и нужно добавить в таблицу поле с кол-вом товара на складе. Условие: кол-во товара не должно превышать кол-во...

Должны ди в ER модели бд быть ID?
напр.

5
321 / 189 / 78
Регистрация: 04.10.2016
Сообщений: 809
04.09.2021, 10:47
в mvc нет строгой реализации бизнес-логики. где то в контроллере, где то в моделях, где то в немодельных структурах. все остальное зависит от архитектуры и "фанатиков личного подхода к реализации".
1
1306 / 998 / 232
Регистрация: 01.10.2018
Сообщений: 3,874
04.09.2021, 11:01
Цитата Сообщение от Fatmarmelad Посмотреть сообщение
Что по этому поводу считает официальная наука?
В общем правильно. Модели составляют функции, реализующие основной функционал. Нагружать их чрезмерными проверками нерационально.
1
 Аватар для sad67man
2603 / 1507 / 689
Регистрация: 23.08.2015
Сообщений: 3,814
04.09.2021, 14:23
Fatmarmelad, С точки зрения науки операция описывается в отдельном классе, и вне зависимости от того, какие данные в нее передают, она должна всегда отрабатывать корректно - либо выполняется полностью, либо кидает исключение. Всевозможные проверки описывают в value-object-ах и запросами к БД. При таком подходе получается что валидация в контроллере на самом деле необязательна.

В контроллере делаются простые проверки ввода, в случае если валидация не прошла - отдается список ошибок со статусом 422. При неудачной выполнении операции перехватывают исключение из предметной области (DomainException) отдают сообщение со статусом 409.

Можно идти на компромиссы и опускать некоторые проверки, учитывая что они были уже произведены в контроллере.

Все зависит от того какой подход вы выберете, в свою очередь выбор подхода зависит от целесообразности и сложности бизнес логики. Не стоит стрелять пушкой по воробьям, если сущность довольно простая - то выбирайте простые решения.
2
 Аватар для tarasalk
1992 / 1216 / 440
Регистрация: 13.06.2013
Сообщений: 4,115
04.09.2021, 18:53
Цитата Сообщение от Fatmarmelad Посмотреть сообщение
что при создании приложения MVC, данные не должны проверяться в модели, а проходить через модель должны только уже проверенные данные, которые должны проверяться в контроллере.
Формулировка не очень хорошая. Вот что значит непроверенные данные? Допустим я могу легко проверить в контроллере что в переменной лежит число, а не строка. А если нужно проверить что элемент с таким ID существует в БД то как я это из контроллера сделаю? Если из контролера вызвать метод модели, который проверяет наличие записи в БД, это считается проверкой в контроллере или в моделе?
В общем много вопросов.

Я вижу это так. Кейс с регистрацией пользователей. Юзер может зарегистрироваться сам, а также его может создать админ. В коде это может быть два контроллера и модель. В каждом из этих частей кода будут свои проверки. Например для саморегистрации проверка капчи, для админа наличие роли админ, а в моделе проверка что юзера с такой почтой в базе нет.
1
 Аватар для sad67man
2603 / 1507 / 689
Регистрация: 23.08.2015
Сообщений: 3,814
05.09.2021, 23:18
Цитата Сообщение от tarasalk Посмотреть сообщение
Если из контролера вызвать метод модели, который проверяет наличие записи в БД, это считается проверкой в контроллере или в моделе?
Нужно понимать, что тут идет речь о слоях.

Слой контроллера парсит запрос, к нему относится и роутер и все-возможные посредники. Проверка прав доступа, и первичная валидация ввода данных. После того, как он точно определил какую операцию пользователь пытается выполнить управление передается в модель.

Модель - это все, что касается бизнес логики. Это отражение реального мира, но не полностью - а ровно на столько, чтоб программа решала задачу. Именно поэтому она называется моделью - моделью предметной области.

После выполнения операции мы уже формируем ответ.

Контроллер относится лишь к пользовательскому интерфейсу. И несмотря на то, что поток исполнения идет от контроллера к модели. Модель важнее и не должна зависеть от контроллера, более того должна защищаться от него.

Если вы делаете проверку такого рода прямо в контроллере.

PHP
1
2
3
4
5
6
7
8
9
10
public function actionRegistration()
{
    //...
    
    if ($this->users->hasByEmail($email)) {
       ... 
    }
    
    ...
}
То получается, что часть бизнес логики вытекает наружу - в контроллер. И даже в этом случае не имеет значения где вы это написали и какой метод вызвали. Проверка на уникальность определенно относится к бизнес логике. Отношение того или иного участка кода к тому или иному слою не зависит от того где вы его написали, но лучше это разделение выражать более явно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.09.2021, 23:18
Помогаю со студенческими работами здесь

Сохранить данные в бинарный файл, после чего данные должны отобразиться на консоли
Задача в том,чтобы сохранить данные в бинарный файл(data.bin),после чего,данные должны отобразиться на консоли.После закрытия консоли и...

MVC: где должны быть кнопки и элементы управления, исходя из этой идеи?
MVC где должны быть кнопки и элементы управление исходя из этой идеи. ? типа ответ юзера идёт в контроллер, а как он может идти если все...

Привести к модели MVC
Приобщаюсь к MVC. Скрипт выводит на главной странице список статей из БД с кратким (обрезанным) содержанием. Функцию обрезания текста...

Spring MVC атрибуты модели
Добрый день! Работаю со Spring MVC, допустим есть два метода в классе контроллера: @RequestMapping(value = "/",...

MVC- грамотная реализация модели
Здравствуйте! Осваиваю ООП+MVC, брал пример из http://habrahabr.ru/post/150267/ Хочу научиться вести порядок у себя в классах, по всем...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru