Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Каркас для разработки приложений. Ваше мнение
Форумы портала PHP.SU » » CMS и фреймворки » Каркас для разработки приложений. Ваше мнение

Страниц (1): [1]
 

1. shum0531 - 29 Июня, 2014 - 17:42:55 - перейти к сообщению
Доброго времени суток! Этой темой, скорее всего опросом, я хочу узнать, сколько программистов будут солидарны с моей идеей или же нет. И по чему.

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

В итоге каркас получился менее 100 строк кода (Радость подсчитал и сам улыбнулся ) + 1 таблица как часть системы(каркаса)
CODE (SQL):
скопировать код в буфер обмена
  1. CREATE TABLE IF NOT EXISTS `page_sity` (
  2.   `id` int(11) NOT NULL AUTO_INCREMENT,
  3.   `name_url` varchar(255) NOT NULL,
  4.   `linck_name` varchar(255) NOT NULL,
  5.   `parent_id` int(11) NOT NULL DEFAULT '0',
  6.   `level` int(11) NOT NULL DEFAULT '1',
  7.   `sort` int(11) NOT NULL DEFAULT '0',
  8.   `id_module` varchar(255) DEFAULT NULL,
  9.   `id_table` int(11) NOT NULL,
  10.   `table_name` varchar(255) NOT NULL
  11.   PRIMARY KEY (`id`)
  12. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8;

Логика заключается в следующем
Берем массив из URL (Моменты касаемо безопасности это я опущу, тут они не к чему), то есть адрес /news/hlebnye-kroshki равен array ( 0 => 'news', 1 => 'hlebnye-kroshki', ), далее из массива генерируем sql запрос
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT l2.* FROM page_sity AS l2
  2. LEFT JOIN page_sity AS l1 ON l1.id = l2.parent_id AND l1.name_url = 'news'
  3. WHERE l2.name_url = 'hlebnye-kroshki' AND l1.parent_id = '0';

Для тех кто не понял: этот запрос вернет из таблицы строку где name_url = 'hlebnye-kroshki'. При этом если соблюдена иерархия news>hlebnye-kroshki
Вот и закончилась основа каркаса ))))))

Что мы получили из таблицы?
id - понятно
name_url - сегмент адресной строки относящийся к текущей странице
linck_name - название страницы или title
parent_id и level - idродительской страницы и уровень вложенности
id_module - список модулей установленных на данную страницу (верхние, нижние, основное.. меню, новости, статьи галереи, каталоги, карточки товаров.......)
id_table и table_name - id и имя таблицы где брать данные (новости, статьи галереи.......) А так же имя таблицы соответствует имени подключаемого html шаблона

примерные затраты шаред-хостера для такой системы 352.30 Кб / 0.0049 сек / 9 запросов. система отработала: 3 разных расположения меню, меню каталога товаров, 2 html блока (реклама), хлебные крошки, контент новости, комментарии к новости.

Из ООП в системе один объект синглтон для базы данных. Все остальные вспомогательные классы со статическими методами, сама система (каркас) написан в процедурном стиле.

P.S. Как то компактно получилось))). Если что то не понятно спрашиваете. И главное, Ваше мнение если поняли логику.
2. caballero - 29 Июня, 2014 - 21:42:05 - перейти к сообщению
Цитата:
В итоге каркас получился менее 100 строк кода

угу, и пользы получилось столько же
3. DelphinPRO - 30 Июня, 2014 - 08:38:06 - перейти к сообщению
где каркас-то? Улыбка что оценивать?
4. Zuldek - 30 Июня, 2014 - 09:30:00 - перейти к сообщению
shum0531 пишет:
И главное, Ваше мнение если поняли логику.

Мнение такое, что вы заного открыли паттерн, уже лет 6 используемый всеми популярными фреймворками.
5. shum0531 - 30 Июня, 2014 - 09:56:41 - перейти к сообщению
Народ, Вы больны патернами и фреймфорками. Я не говорю что это плохо, их надо знать, но и ленится то же не стоит. Ведь php, насколько я знаю один из простейших языков программирования и фреймворки, в большинстве проектов просто, просто в них не нуждаются.
Zuldek пишет:
о вы заного открыли паттерн, уже лет 6 используемый всеми популярны

Подскажите плиз название патерна данной реализации!

И ни кого не смутило, что в данной логике все завязано на одной таблице? То бишь, говорить языком фреймворков, таблица является маршрутизатором(хранит в себе ВСЕ url адреса приложения) и контроллером.
Здесь если программисты, которые делают проекты на фреймворках, только когда это реально необходимо?
6. Contr - 30 Июня, 2014 - 10:03:03 - перейти к сообщению
Так и знал, что эта тема - жирный троллинг
7. Ch_chov - 30 Июня, 2014 - 10:30:56 - перейти к сообщению
shum0531, кроме фреймворков есть еще микрофреймворки.
8. LIME - 30 Июня, 2014 - 10:44:09 - перейти к сообщению
я что-то подобное встретил на первой работе в b[ самописной cms
и потому знаю что спросить))
что делать если нужен url не из 2ух составляющих а из 1 или 3-4-5 ? и с каждым из них должны быть гет-параметры?
а если гет-параметр нужен не в конце урл а в середине?
типа /goods/moloko/in-cart
/goods/telefon/in-cart
были такие заморочки от SEOшников
(Добавление)
выход:
типа matherialized path
храни шаблон urla в таблице
как бы тебе твое решение ни казалось красивым это не так))
9. shum0531 - 30 Июня, 2014 - 11:03:31 - перейти к сообщению
LIME пишет:
я что-то подобное встретил на первой работе в b[ самописной cms
и потому знаю что спросить))
что делать если нужен url не из 2ух составляющих а из 1 или 3-4-5 ? и с каждым из них должны быть гет-параметры?
а если гет-параметр нужен не в конце урл а в середине?
типа /goods/moloko/in-cart
/goods/telefon/in-cart
были такие заморочки от SEOшников
(Добавление)
выход:
типа matherialized path
храни шаблон urla в таблице
как бы тебе твое решение ни казалось красивым это не так))


Не совсем понятна цель изъятия данных из начала адресной строки или середины.
Вот генерация sql запроса, на существование и целостности url и возвращении результата
PHP:
скопировать код в буфер обмена
  1. function page_sity_sql($url_array)
  2. {
  3.         $shv_url_count = count($url_array);
  4.         $select = "SELECT l{$shv_url_count}.* FROM page_sity AS l{$shv_url_count} \r\n";
  5.         for($left_join = '', $i = 1; $i < count($url_array); $i++)
  6.         {
  7.                 $left_join = "LEFT JOIN page_sity AS l".$i." \r\n".
  8.                 "ON l".$i.".id = l".($i+1).".parent_id \r\n".
  9.                 "AND l".$i.".name_url = '".$url_array[$i-1]."' \r\n".$left_join;
  10.         }
  11.         return $select.$left_join."WHERE l".$shv_url_count.".name_url = '".$url_array[$shv_url_count-1]."' \r\n".
  12.         "AND l1.parent_id = '0';";
  13. }

Если я Вас правильно понял, нужна возможность получения всей цепочки, а не только последнего сегмента?
Тогда все просто, строку SELECT l{$shv_url_count}.* генерируем не в начале функции, а в цикле, как и выборка. Тем самым, мы получает либо все данные либо ни чего, если нарушена логика.
10. Zuldek - 30 Июня, 2014 - 11:25:24 - перейти к сообщению
вата Улыбка

 

Powered by ExBB FM 1.0 RC1