Здесь мы изучаем язык PHP (а также JS/CSS/HTML/SQL) и учимся делать сайты. Зачем? Кто-то хочет открыть стартап, кто-то заработать на лапшу быстрого приготовления, кому-то просто нечего делать.
ОП довольно занят, но постарается ответить на все вопросы. Также, ответы и решения задач можно поискать в архиве тредов phpclub.
Это тред и для начинающих. Слово "классы" у тебя ассоциируется только со школой, а в аттестате тройка по математике? Ты наш человек.
Предыдущий тред был тут: >>1785871 (OP) . Все старые треды есть в архиве: https://phpclub.tech/ (там есть поиск, можно искать решения и обсуждения задач).
С чего начать
Наши уроки по PHP собраны по адресу http://codedokode.github.io/phpbook (вас отредиректит на другой домен, не запоминайте его, он временный). Это учебник для изучающих с нуля. Там есть задачи, их нужно решать. Но если этот учебник тебе не нравится, можно читать любой другой. Или официальный мануал. Или все сразу.
Если не знаешь как решать, запости код и попроси подсказку или поищи задачу в архиве тредов.
Ты прошел весь учебник? Молодец, но это были лишь основы языка PHP. Вот что в идеале надо изучить еще: ООП, как работает веб-сервер, HTML/CSS, SQL, PDO, работа с таблицами в БД, работа с формами, MVC, git, composer, JS, фреймворки, автоматизированное тестирование. У нас есть задачи для изучения этого:
Параллельно стоит подучивать английский, на первых порах можно без него, но по мере развития придется все чаще сталкиваться с англоязычными статьями, так что лучше не откладывать. Читать можно news.ycombinator.com - это что-то вроде их хабра.
Также, у нас есть задачи которые позволят тебе изучить или подтянуть до нормального уровня знания JS/HTML/CSS/SQL. Решай их параллельно с задачами выше.
Оформляй код аккуратно!!! — например пропусти через phpformatter.com . Также, если ты пользуешься IDE вроде PhpStorm, Netbeans, Eclipse, то в них эта опция встроена, подробнее: https://gist.github.com/codedokode/8759492
У ОПа нет аккаунтов и групп вконтакте, в фейсбуке, в твиттере, все "пхп-треды" там поддельные.
Платиновые вопросы
- Почему PHP? Потому что вакансий море, и учить легко. - Сайт опять упал!!!!! — Не паникуй, а зайди на https://github.com/codedokode/phpbook, нажми зеленую кнопку Clone or Download -> Download ZIP, распакуй на рабочий стол и получи личную копию сайта, не требующую интернетов. - Что надо знать чтобы найти работу - разработчику: PHP, SQL, HTML/CSS, JS, ООП, Git, композер, MVC, фреймворк. Верстальщику - HTML/CSS, JS, jQuery. У нас в треде были люди, которые практически с нуля учились и смогли найти работу (ищи в архиве по слову "устроился"). - Что будут спрашивать на собеседовании если 0 опыта - гонять по теории, по официальному мануалу PHP, давать дурацкие задачки на переворачивание строк, гонять по SQL (транзакции, внешние ключи, напиши запрос), по JS (как сделать анимацию при нажатии кнопки), ну погугли, не ленись - Можно подробнее про поиск работы, собеседования - нет, ОП писать не будет, но может кто из анонов захочет рассказать. Поищите тред перезвонивших, а также раздел /wrk/ - Сколько времени надо изучать все это? - все зависит от тебя, но не меньше 6-8 месяцев - Нужен ли ООП, фреймворки, MVC, git, composer? — Да, однозначно. Посмотри любую вакансию.
Код должен быть аккуратным и оформлен, как принято. Потому, что другой человек, который будет смотреть твой код, вряд ли обрадуется, когда ему придется разбирать слипшиеся строчки, разбросанные в беспорядке скобки и написанные русскими словами названия переменных. Особенно плохо будет если это, например, код тестового задания, которое ты сделал, чтобы устроиться на работу. Если он будет неряшливым, это будет большой минус.
Вообще, в PHP долгое время не было единого стандарта оформления кода, все писали как попало и было много бардака, но сейчас дело лучше — есть рекомендации PSR-1 и PSR-12. Вот как надо оформлять код:
- переменные и функции пишутся с маленькой буквы, подчеркивание не используется, используется camelCase, пример: $x, $numberOfPeople, printResults() - Название функции начинается с глагола, в стиле «сделайЧтоТо» - не знаешь английский? Не беда, в 21 веке есть решение этой проблемы. Не пиши транслитом, открой лучше Гугл Транслейт и найди название для переменной там - в именах классов используется CamelCase, первая буква большая, «_» может использоваться - мы предпочитаем подстановку переменных вместо конкатенации строк: "I am $age years old" — хорошо, 'I am ' . $age . ' years old' — плохо из-за обилия точек и кавычек - мы используем для отступов 4 пробела (можно настроить редактор, чтобы при нажатии Tab он вставлял 4 пробела) - ставим тайп-хинты на аргументы функций, результат функций и поля классов
Вот ссылка на рекомендации PSR, где все это описано подробнее и даны примеры оформления:
Анон как правильно работать с фронтенд фреймворком на php фреймворке? Как и положено в nginx домашняя локация указана на www/html/web/project/index.php. index.php запускает php фреймворк, открывается контроллер, который собирает вьюху. Или не собирает?
>>1849281 Собирает в любом случае, просто в зависимости от архитектуры фронта эта вьюха может быть просто тег <main></main>, а все что внутри уже фронт добавляет. Но может и более-менее полную собирать. Еще фронт может полностью генерится на сервере изпользуя фронтенд фреймворк. Тогда бекэнд отдает полностью готовыю вью, но отрендерена она фронт фрейморком, а не бекэндом. Такое используют, например, когда хотят чтобы SPA индексировалось ботами поисковиков - ботам отдают полностью сгенерированую страницу с инфой, потому что скрипты они не запускают и обычная SPA страница для них будет пустая.
Прохожу гайд из шапки, пытаюсь решить задачу на форматирование текста (удаление лишних пробелов и т.д.) Но могу сделать так, чтобы все предложения начинались с большой буквы. Пытаюсь с помощью регулярки и preg_replace найти все первые буквы предложения, и применить к ним mb_strtoupper. Но она не применяется. Что я не так делаю? Или так вообще нельзя делать?
На меня тут в прошлый раз накинулись из-за того, что я хочу с C# перейти на PHP, но за пару дней тестов и чтения сравнений я пришел к тому, что чистый архитектурный код можно писать и на PHP, но единственный минус C# в том, что он менее производительный. Я прошу вас оценить не со стороны больших дядек, который C# выбирают просто потому что, а чисто по архитектуре, защищенности и быстродействию. Что лучше?
>>1849930 В двух словах PostgreSQL для кровавого тырпрайза, там есть всякие плюшки коих нет в MySQL, ну и всякая оптимизация, быстродействие и тп., но с другой стороны если нужно лезть в конфиги, то на PostgreSQL это боль, если нет DevOps который бы эту хуйню поддерживал, то лучше MySQL. С точки зрения разработчика почти не отличаются те же самые запросы, все тоже самое в общем и целом. А так можно нагуглить много разных статей на эту тему, лень с телефона печатать.
- с помощью preg_split разбить текст на массив предложений, в кажддом из них поднять регистр первой буквы, и склеить обратно в текст - использовать preg_replace_callback и в коллбеке поднять регистр буквы
Использовать preg_replace вместе с mb_strtoupper, чтобы это работало, невозможно.
Потому что программа выполняется по шагам. Если ты ставишь умножение перед циклом, то оно выполняется (с ошибкой, так как переменной $i еще не создано), результат записывается в $a и дальше она не меняется. С чего бы ей меняться, если дальше нет команд, которые бы это делали.
Выражение $a = $i * $i не значит, что "$a будет дальше автоматически обновляться при изменении $i". Нет, это команда: перемножь $i на $i и помести результат в $a. Если ты ставишь ее до цикла, то она выполняется один раз. Если внутрь цикла - то несколько раз, на каждом шаге цикла.
>>1849940 Дело совсем не в быстродействии. Есть стандарты SQL, а конкретные базы им следуют. Ну пытаются во всяком случае. SQL это внезапно тоже язык, который нужно учить. Представь что ты всю жизнь учил урезанную версию пхп, в которой, например, нет функций работы с массивами или json. Нахуй такой обрубок вообще нужен?
В предыдущем треде анон спрашивал банальный вопрос: Есть самописная борда, на борде есть треды, в тредах посты. Как выбрать последние n постов для каждого треда.
Удачи исполнить такое на MySql. Никаких нативных инструментов для этого нет. Только хаки и подзапросы по секунде. А на постгресе куча вариантов и все в соответствии со стандартом.
сап аноны, записался на курсы рнр, там задание "Составьте регулярные выражения для маскирования тегов HTML ", не могу понять что такое "маскирование", может кто знает
>>1849942 В том, что нет join'ов, данные любого формата можно хранить в json. Нет фиксированной структуры, не нужно заранее объявлять schema, просто берешь и работаешь без задней мысли.
>>1849573 Что тебе больше нравится, то и используй. Нравится ООП, используешь azure - бери C#. Нравится простота и дешевизна - бери PHP.
>>1849235 Бери Visual Studio Code, функции все те же, только бесплатный.
>>1849078 (OP) Как в рамках php решается проблема highload если асинхронности как таковой в пыхе нет и вызываемый файл-скрипт .php запускается для каждого поступившего обращения на сервер?
Как связаны асинхронность и highload? Я думаю, что никак, так что непонятно, зачем ты про нее вспомнил.
В highload PHP прекрасно распараллеливается на любое число машин. Благодаря синхронному коду писать на PHP удобнее и проще.
Хотя это на практике не очень нужно, так как реально highload приложений в мире очень мало. Мало кто может похвастаться миллионами одновременно заходящими на сайт или в приложение пользователями. Вконтакте, твиттер, инстаграм - это единицы, а у 99% сайтов такие объемы трафика никогда не будут.
>>1850391 >В том, что нет join'ов, данные любого формата можно хранить в json. Нет фиксированной структуры, не нужно заранее объявлять schema, просто берешь и работаешь без задней мысли. А в чем подводные?
>>1850578 >А в чем подводные? Да нет никаких подводных. Каждая БД работает в рамках своей задачи, под которую она разрабатывалась. Memcached/redis например хранят базу в оперативной памяти, поэтому их часто как прокладку для кеша используют. InfluxDB под временные ряды заточена (котировки акций например). Neo4j заточена под графы и отношения many-to-many (система рекомендации товаров например). Есть мультимодельные БД, которые сочетают в себе качества как реляционных БД, так и документоориентированных - например FaunaDB.
В MongoDB просто другая идеология, не размазывать данные по куче таблиц, а хранить данные в самих документах. Если у тебя много взаимосвязей между данными - к примеру ты строишь социальную сеть. Тут конечно лучше подойдет MySQL, заебешься в NoSQL моделировать отношения.
>>1850490 >Как в рамках php решается проблема highload если асинхронности как таковой в пыхе нет Асинхронности нет, но есть воркеры. В nginx ставишь worker_processes равное количеству ядер, например у тебя 4 ядра на сервере, значит ты ставишь worker_processes равное 4-м и сервер у тебя свободно обрабатывает 4 некешированных запроса одновременно. Это первый вариант.
Второй вариант - балансеры. Можно закупить 2-5-10-100 серверов и балансировать между ними нагрузку, если один из серверов занят, запрос автоматически переадресуется на другой сервер.
Третий вариант - кеширование. Ставиться memcached и время генерации страницы уменьшается до 20мс или около того.
>>1850490 Ах да, этот ваш JavaScript тоже не тру асинхронный язык. Асинхронность в нем достигается за счет использования Web API (написанных на плюсах) и механизма колбеков (в ноде за счет использования libuv, которая тоже написана на c++ между прочим). Это так, к слову...
Подскажите, пожалуйста, как сделать так, чтобы при нажатии на чекбокс, который находится в диве 1, менялся фон у h1 в диве 2? https://jsfiddle.net/fhw64m9v/ Если не туда написал, скажите плз куда написать?
https://2ch.hk/pr/res/1845843.html Это вообще нормально что опять зумерсике жс-пидоры что-то тявкают про пхп, хотя нихуя не шарят в матчасти? Пора им смачно так провести шершавым хуем по еблам
>>1850757 Для простых сайтов вообще заебись. Если у тебя тупо статьи по категориям/пользователи, то mongodb подойдет идеально. Это БД общего назначения, для особых случаев есть специализированные БД.
>>1850757 Просто у nosql немного своя атмосфера, не такая как у mysql/postgresql. Свои техники и приемы работы. Перекатышам можно забыть всё что они знали о реляционных дб и учить всё заново)
>>1851145 решить уравнение вида 1e4 1.1^n >= 1e6 https://www.wolframalpha.com/input/?i=1e4++1.1%5En+%3E%3D+1e6 с точки зрения _как_ решать - фигануть просто логарифм по основанию 1.1 - log_{1.1}(1e6/1e4)=48.31.. (что сходится с вольфрамом)
Сап, веб-макаки. Как можно редачить код в Вижуал Студио и сразу же выводить его на другое окно в этом же самом вижуал студио, чтобы каждый раз не запускать файл в браузере по новой?>>1849078 (OP)
Ебать, два часа думал как нужно написать решение задачи про мальчика с айфоном в кредит. Че то меня зацепила фраза автора о том что с первого раза мало кому удается решить ее и прям замотивирован был. На самом деле само решение образное в голове, пришло почти сразу, но как это все оформить и написать - пиздец просто. Спрашивать само решение здесь у анонов было как- стыдно..... хотя я был близок. Рад просто пиздец как
Всем привет. Собираюсь пустится в бэк разработку (столкнусь с разработкой впервые в принципе) и думаю какую IDE бесплатную можно взять. Ломаюсь между VsCode, SublimeText(но, говорят, там гемор с допами) и phpstorm (бесплатной версии, была же такая, да?..). Планирую за 6-7 месяцев пройти обучения в шапке и податься на джуна, потому хочу сразу начинать с какой-то нормальной IDE, а не notepad++. К тому же планирую винду полностью Linux заменить (опыт пользования есть), а потому кроссплатформенность тоже важна. Пытался статейки нагуглить, но всё херня какая-то. Заранее спасибо.
>>1851629 +добавлю ставил вскод чтоб просто посмотреть - вроде вполне сносно работало на убунте. Ставил одно расширение для пхп (у которого много скачиваний и рейтинг хороший) + хдебаг (не настраивал). интелисенс(автодополнение) норм работал навигация по коду норм консоль понравилась есть гайды по настройке вскод+хдебаг+докер думаю вполне можно работать/учиться
>>1851585 vscode на убунте норм, но для него нужно расширения ставить, я уже не помню какие я тогда нагуглил, не все адекватно работают. Если его настроить правильно и оперативки много, то для начала пойдет, у нас на работе даже некоторые в нем пишут. А так сам купил ключи к шторму и не парюсь.
Блэт, аноны, чет я затупил как мразь просто, нихуя нагуглить не могу. Как в базу с помощью sql запроса вставить дату полученную из строки? Дата - "2020-11-10Т10:44:06.333Z" - это дата expires сессии для куки. Одна либа генерит такую. Первое - что значат цифры и буква после точки - .333Z? Второе - я инсертом не понимаю как правильно ткнуть эту дату в базу в поле с типом DATATIME. Юзал str_to_date функцию - но не получается. Как првильно это сделать? Вообще я чет нихуя не понимаю в sql датах
>>1851929 самофикс - дата прекрасно втсавляется как строка '2020-11-10Т10:44:06.333Z', я чет сам себя перемудрил. Вставлял эту строку в VALUES ( DATETIME('2020-11-10Т10:44:06.333Z') ) Хотя если юзать DATE('2020-11-10Т10:44:06.333Z') - в базу вставится значение - но только год-месяц-день
Решаю задачу из гайда про размен. Разобрался как выдавать минимальное количество купюр. Но это работает только если количество купюр достаточно много в банкомате. Как тогда рассматривать случай, когда каких то купюр в дефиците И их не хватит для минимальной последовательности.
>>1851560 Можешь не спрашивать, вбивай условия задачи в гугл и там будет решенная задачка. Большинство задач, ну как бэ явно с нуля решить очень сложно для вкатывальщика, поэтому автор не лукавил.
Фишка Mongo не в том, что в ней можно вкладывать одни сущности в другие (можно, но ты об этом пожалеешь). Каждую сущность надо хранить отдельно. Те, кто пишут, скорее всего на практике с этим не сталкивались. Никто в здравом уме не будет засовывать статьи внутрь категории, а будет использовать связи.
Mongo просто лучше мапится на объекты. Если ты не начинающий, то ты скорее всего напрямую не работаешь ни с Mongo, ни c MySQL. А используешь ODM/ORM. Для мапинга объектов на хранилище SQL подходит хуже (так как мы делаем сложное преобразование из объектов в SQL-запросы), а Mongo - лучше (так как мы сразу преобразовываем объект в JSON и засовываем в хранилище). Добавление нового поля, например, реализуется добавлением одного поля в объекте. Не требуется делать миграций.
С другой стороны, если надо вручную выбрать какие-то данные, SQL позволяет сделать это быстро, а вот с Mongo придется писать громоздкий JSON. То есть SQL лучше подходит для использования человеком, а MongoDB - приложением.
Джойнов там нет, потому что связи реализуются на уровне ODM (object to document mapper) вроде Доктрины. Также, схемы нет в Монго, но она реализуется на уровне приложения.
Монго - это не значит, что мы вручную пишем туда JSON и устраиваем свалку. Обычно используют ODM для взаимодействия с монго, иначе получится бардак.
Если купюр меньше, чем требуемая сумма, надо выдавать соответствующее сообщение. Если одной купюры мало, но других много, то надо выдавать ими.
В жадном алгоритме ты идешь от больших купюр к маленьким и берешь по максимуму каждой купюры (но так, чтобы это было не больше остатка выдаваемой суммы и не больше имеющегося запаса купюр).
Аноны, наткнулся вот на такой сайтец с самообучением начальным по пхп. Вопрос, сильно ли он отличается от того что тут автор залил? Ибо он мне больше зашел чем тот который в закрепе поскольку там есть возможность сразу проверить решение задачи а не лопатить гугол или тут доебывать анонов. Столкнулся просто с проблемой что пример кода который я копирую в кодпэд - не воспроизводится.... Я понимаю что там немного другое оформление нежели у автора треда, но энивей, хотел узнать что все таки лучше
>>1852164 Не, попробую объяснить на примере, что есть скажем купюры 5 - 2 шт 10- 1шт 20 - 1шт
Если я хочу получить 40, то минимальное количество купюр будет 2 по 20. Но в наличии то у меня только одна двадцатка. И в реальности я должен выдать 20+10+5+5, что не является минимальным количеством в идеальном случае, но минимально возможное в действительности. Вопрос в том, в каком месте кода это надо учитывать и как обрабатывать?
Жадный алгоритм это учитывает. Ты движешься от больших купюр к маленьким и каждой берешь по максимуму. То есть вначале алгоритм рассматривает купюры по 20:
- хотелось бы выдать: 40/20 = 2 шт - в наличии: 1 шт - потому берем 1 шт по 20
Невыданный остаток = 20. Переходим к купюре по 10:
- хотелось бы выдать: 20/10 = 2 шт - в наличии: 1 шт - потому берем 1 шт по 10
>>1852163 >Джойнов там нет, потому что связи реализуются на уровне ODM (object to document mapper) вроде Доктрины В анус себе замаппь свою доктрину. Зачем мне маппить объекты на базу? Чтобы он мне под каждый класс делал новую коллекцию? А может я хотел сделать одну коллекцию а-ля single table design? Без соплей разберусь как мне моделировать мою базу.
>Обычно используют ODM для взаимодействия с монго, иначе получится бардак. Обычно используют ODM такие дауны как ты. Которые и перднуть не могут без лишних абстракций.
>>1852287 я тут не профессионал далеко. сам только вкатываюсь но в пхп сначала а потом уже верстку подхвачу как плюс минус пхп основы освою. ну, подрочить теги наверно все равно придется т.к. хтмл/ксс все таки язык со своим синтаксисом и какие-то основы знать энивей придется. но это чисто мнение очередняры, папки мб не согласятся и че то другое посоветуют. жди
>>1852288 сам вкатываюсь только, и чем дальше в php, тем все больше понимаю что верстка(на деле не так сложно учить) + хотя бы основы JS просто обязательно надо знать будет
>>1852277 >Аноны сеньоры, расскажите как вкатиться верстальщиком Тру сеньоры никогда бы не посоветовали становиться верстальщиком in the first place. Верстальщик - это низшее звено в пищевой цепи, самая ебаная, низкопробная и низкооплачиваемая специальность. Наподобие дворника или разнорабочего на стройке. Верстают HTML только те, кто ничего больше делать не умеет. Если ты хочешь получать зарплату больше, чем только на сиги и пивас, я бы советовал приобрести больше навыков, чем только знание HTML/CSS.
>хоть на кусок хлеба заработать себе Если ты себя не ценишь - никто тебя ценить не будет. Если просишь на кусок хлеба, тебе и дадут ровно кусок хлеба. Потому что ты сам себе назначил такую цену. Никто тебе не скажет, "сорри, чувак, но ты стоишь 100 тысяч как минимум". Скажешь 10 тысяч, тебе десятку и назначат.
>>1852277 Почему в php треде спрашиваешь? По вопросу - берёшь и верстаешь без задней мысли, лендинг сверстай, потом многостраничник, настрой всякие вебпаки и сасы что бы удобней было. В процессе гуглишь нужные тебе теги и как это лучше сделать. Потом пиздуешь на фрилас верстать лендосы за 2к)
Сделал задачу про Grammar Nazi, хочу теперь от тебя узнать где я тут обсренькался и как пишут регулярки нормальные люди. Еще никак не мог понять как работает preg_replace и эти $0 и $1, но методом проб, ошибок и гугления что-то смог намутить, еще не всегда понимаю где нужны круглые скобки, а где нет.
пикрелейтед челибос у которого плавится мозг от регулярок
>>1853412 Знаете, в мере вокруг столько негатива, все кругом грязное, а хочется чего-то светлого, я хочу рассказать вам о Битриксе. Вы бы хотели пустить Битрикс в свой дом?
P.S. обязательно нужно практиковаться P.S. #2 Вёрстка и JS связаны https://learn.javascript.ru/ P.S. #3 возможно не стоит сильно углубляться в специфические моменты(сложные css-анимации), а то долго будешь учиться до получения первого оффера
Пиздец, я дошел до функций и охуел просто. Я искренне пытался вникать в каждый этап, решая задачки но это же пиздец какой то с этими ебучими массивами и циклами. Столько всего нужно держать в голове чтобы понимать когда и как использовать эти приколы. Только я плюс минус запомню как работают массивы так потом появляются ебучие циклы И ВСЕ ЭТО НАДО КОМБИНИРОВАТЬ. Массив в массиве, цикл в цикле, еще и миллион этих ебаных функций. Я просто охуеваю. Неужели я один такой бездарный даун которому так сложно в погромирование?
>>1854007 Это ты еще до регулярок не дошел, у меня тоже было много проблем с циклами в первое время, но регулярки это просто пиздец. В любом случае, я заметил что постепенно любую задачу можно решить, мне понадобилось несколько раз дропать учебник на длительное время (2-3 месяца), чтобы хоть как-то продвинуться, сейчас нахожусь на главе "Повторим?". Главное не сдавайся, анон, и не скипай задачи. Если уже окончательно на курс перешёл, то потом как пройдешь, вернись к задачам из учебника.
Спасибо оп, за проделанную работу. Очень приятно и понятно читать сайт обучалку. Но я тут же стопорнулся на второй задачке с командой mt_rand, погуглив понял что нужно вбить в неё два числа, минимальное и максимальное. Жаль ты не сказал это в уроке.
>>1854186 Понял принял. Таки осилил следующую задачку про кости с компуктером. На самом деле выглядит все как в школе с вижуал бейсик. Прямо чувствую как извилины напрягаться начинают, лел.
Набросал я простую страничку для рассчёта кредита как в задаче. Задал несколько строк в форме, для передачи параметров в файл php.
Но все это выводит у меня в новой странице простым тексом. Как сделать что после рассчёта данные выводились (добавлялись) на ту же страницу с вводом данных? Я так понимаю как минимум надо использовать метод post?
Я тут как-то спрашивал, как запилить йобу по генерации пдф-файлов на основе ехcel таблицы, но как тупой гуманитарий не смог разобраться с построчным чтением данных из первоначального файла.
Поэтому вопрос к анону за сколько деняк он взялся бы за это дело.
Собственно на начальном этапе я вижу это вот как: 1) Есть табличка excel (или csv-файл, как тут советовал анон, не принципиально) со столбцами "ФИО, адрес, номер телефона, сумма в рублях" мб еще 1-2 столбца 2) Табличка загружается в веб-приложение 3) Для каждой строки генерируется пдф-файл и сохраняется на сервере для дальнейшего скачивания (или еще лучше весь этот пак качается зип-архивом, например) ??? PROFIT
Анончик тут писал, что это лучше всего сделать через wkhtmltodpf. В html-шаблоне время от времени нужно будет редактировать 1-2 абзаца (в начале и в конце файла).
Напишите, плиз, за сколько бы запилили такую хуйню?
>>1854232 Вопрос времено решил тем, что в файле php выполняется функция с аргументами из гета и после дублируется весь код страницы с дополнительными строками в которых отображается результат выполнения функции php. Но это слишком тупо и в лоб чтобы быть правильным решением. Прошу совета бывалых. Если важно, то сервер использую встроенный в php
>>1854297 Я не понял. Ты используешь хтмл файл, который отправляет запрос на сервер и уже средствами пыхи генерируешь такую же страничку но уже через пхп? Если да, то бы почему не сделать одну точку входа, которая смотрит, был ли пост запрос и выводит результат
>>1854492 Да, я тоже сейчас подумал о чем то похожем, использовать файл php с функцией и разметкой. Чисто ради интереса, а как из пыхи добавлять в другой файл хтмл новые теги? Или чтобы они становились видимыми по условию из результатов в файле пыхи
Когда делается поиск в тексте по регулярке, запоминается, какие части регулярки совпали с какой частью текста. $0 - это весь текст, с которым совпала регулярка. $1 - это текст, с которым совпали первые круглые скобки в регулярке, $2 - вторые и так далее.
Например, если дан текст "кот и мышь" и регулярка /к(.(.))/u то $0 = "кот", $1 = "от", $2 = "т". Эти значения ты можешь использовать в строке для замены в preg_replace. А если ты просто проверяешь текст на соответствие регулярке с помощью preg_match, то она заполняет массив этими значениями.
Это из-за того, что не очень удачно продумана регулярка для а/но без запятой. Вообще, регулярки, ищущие отсутствие чего-то писать сложнее, так как регулярка в первую очередь заточена под поиск наличия каких-то символов.
Я бы добавил \b вокруг слов а, но, чтобы регулярка не принимала любые слова, которые содержат в себе эти буквы.
- чтобы применить квантификатор вроде звездочки или плюса не к одной букве, а к группе: сравни (абв)+ и абв+ - чтобы сгруппировать перечисляемые через | варианты: сравни (а|б|в)где и а|б|вгде - чтобы "захватить" часть найденной строки и использовать позже как $1, $2 итд.
Ну в этом и суть программирования: из простых элементов, как из кирпичиков, собирается сложная программа. Реальные приложения могут содержать 100 000 строк кода, так что тренируйся пока на простых программах. Надо научиться писать и читать код с циклами, массивами и функциями, на автомате.
- если форма заполнена и отправлена, то взять данные, посчитать результат, вывести его - вывести форму
При таком подходе ты отправляешь форму на ту же самую страницу. То есть у тебя один скрипт, например, calc.php и делает расчет, и выводит форму.
Смешивать HTML-шаблон и логику на PHP считается дурным тоном, потому лучше сделать так, чтобы вначале шла вся логика, а в конце - только HTML-шаблон с подстановкой переменных:
- естьРезультат = false - если форма заполнена и переданы ее данные, то посчитать результат и присвоить переменной естьРезультат=true ----- конец логики, начало шаблона---- - если естьРезультат, то вывести его - вывести форму
Аноны, немного такой вопрос: По работе пилю приложуху. Она простая - slim + sql. Вот допустим есть таблица "событие", она связана с другими таблицами. И когда условно в контроллере я беру выборку по "событиям" - мне нужно так же куча связанной инфы с выборкой "событий" из разных других таблиц. Я делаю просто - sql запрос с кучей объединений.
Но вот у меня такой вопрос, допустим "событие" связанно с таблицей "статья". И для "события" и для "статьи" у меня есть классы отдельные, т.е. модели. Возникла мысль. Не получается ли что когда я в контроллере запросом выбираю все события , а так же связанную инфу, из других таблиц( для которых есть отдельные классы-модели) одним запросом с объединениями - нарушаю принцип единой ответственности? Не должен ли я в методах модели "события" получать инфу о связанных с этой моделью "статьям" - вызывая для этого соответствующие методы модели "статьи"? Т.е. класс "события" работает только с таблицой "события", а класс "статья" - касается только таблицы "статья". А как реализовывать транзакции? Передавать объект коннекта из одного метода класса в метод класса другого объекта? Допустим для того что бы одномоментно в нескольких таблицах insert-ы реализовать.
Вопрос про трекинг времени для тестов в задаче на тестхаб. Как у меня получилось: когда юзер открывает тест с вопросами, то создается сессия с датой старта, а потом при сдаче эта дата сверяется с дедлайном теста. А что делать, если, допустим, юзер открыл тест, а потом закрыл браузер и не стал отправлять ответы? Я думаю просто написать скрипт для крона, который будет запускаться каждые 30 минут, чекать все сессии с тестами на время и если дедлайн истек, то ставить отрицательные оценки. Норм решение или как-то по-другому лучше сделать?
>>1854641 > в методах модели "события" получать инфу о связанных с этой моделью "статьям" как-то так > класс "события" работает только с таблицой "события", а класс "статья" Если так получается то лучше сделать попростому (тоесть так). У тебя простые модели которые замаплены на бд с помощью ORM. Но структура таблиц бд может быть не очень удобна (так как к ним свои требования не связаные с бизнес логикой). Тогда у тебя слой моделей (domain model) которые преставляют бизнес-логику так как ее удобно сделать. Этой слой использует уже нижний слой простых ORM моделей. Ну или делает какие-то выдроченые зщапросы к бд если требования к производительности.
Я все ещё пытаюсь написать нормальную страницу для рассчёта кредита в браузере. Благодарю за вчерашнюю помощь. Прочитал ещё раз гайд от ОПа про шаблоны и поптылася реализовать на работе. Результаты на пике.(на работе код не могу скинуть, сори) Пик 1. Скрипт пыхи который получает из гета входные данные и обрабатывает их, после подключает шаблон хтмл Пик 2. Собственно сам шаблон хтмл, куда вставляются результаты работы скрипта Пик 3. Что вижу в браузере. Вопрос в правильном ли я направлении иду? Где косяки и что лучше делать по другому?
ОП, запрашиваю проверку задачи про Shift. 3 дня пыхтел и каком кверху написал регулярки, все вроде работает, но я не понимаю почему, например, если вместо двух вопросов идущих подряд написать 3, то скрипт все равно корректно работает. Ну и как можно было сократить код и есть ли у меня тут явные ошибки.
>>1854872 >if ($creditBalance <= 5000) У тебя ; стоит после закрывающей скобки, поэтому условие перестает работать и в переменную $monthlyPayment попадает большое число.
>>1854922 >Вопрос в правильном ли я направлении иду? Где косяки и что лучше делать по другому?
Для начала нормально. Теперь этот код разбить на функции, чтобы не писать exit(); а просто при выполнении условий вызывать функции. Шаблон луче тоже сделать php, если обратиться к нему напрямую, то в браузере будет виден весь код. Ну и вместо if elseif elseif в шаблоне попробуй switch case. Еще не понятно зачем фильтровать выводимый результат, он же у тебя float там не может быть символов которые ты пытаешься отфильтровать при помощи htmlspecialchars(). Фильтровать нужно входные данные, что собственно у тебя и сделано.
Можно теперь попробовать ajax, когда отправка идет без перезагрузки страницы.
Либо если с фронтом тяжело, то можно попробовать ООП, эту логику перенести в отдельный класс и уже его дергать из твоего скрипта создать экземпляр класса передав в конструктор входные параметры, вызвать метод расчета, если он нам вернул true, вызвать методы которые вернут месяцы и полную стоимость и передать в шаблон, если false то вызвать метод с ошибками и передать в шаблон. Короче сделать отдельную "коробочку" которая все считает и которую можно применить в других местах без модификации. Для начала будет тяжело и непонятно, но на работе чаще всего придется именно так и делать в ООП. Пытайся смотреть в ту сторону.
На счёт свитча, я изначально хотел сделать, но не понял как использовать конструкцию типа <?php switch: ?> <?php case 1: p> <?php case 2: p> <?php endswitch; ?>
Надо ли тут вставлять break и в каком формате? Типо <?php switch: ?> <?php case 1: p> <?php break; ?> <?php case 2: p> <?php break; ?> <?php endswitch; ?>
>>1854979 Да в твоем случае break; обязательно, у тебя будут выполнятся все остальные условия, то есть пойдет в следующий case и до тех пор пока не будет break
Аноны, вкатываюсь веб из дезигна (делал различную графику и анимацию + монтаж. афтер/премьер,вегас) Так вот при изучении основ из учебника в закрепе, столкнулся с задачами на шифрование и понял что не получается у меня применить то что я уже изучил, сразу сходу. Не лучше ли после изучения основ начать смотреть какие-то видосы где автор учит простейшим процессам написания кода, повторять за ним, пытаться вникать в то что он пишет, разбираться в этом и таким образом набивать руку а потом уже пытаться самому что то делать/решать задачи? Просто в дезигне именно по такой методике я обучался. Изучаешь теорию > повторяешь за автором практику применения каких-то плагинов, эффектов > потом имея уже какое-то представление начинаешь повторять популярные эффекты по гайдам с ютуба параллельно вникая как это делает > а потом уже набив руку ты можешь что-то самостоятельно свое делать. Ну подойдет ли такая методика в изучении веба? Допустим я тупой и не могу в задачки сразу после теории. Могу ли я сначала изучить всю теорию, потом по гайдам писать код, вникая в него, а потом уже набив руку делать что-то свое и пытаться решать уже задачки?
>>1854922 Зачем ты выводишь пустой абзац в первом случае в шаблоне? Убери лишний р тег Перегруппируй пыху, сделай по типу
если условие 1 работа с переменными 1; если условие 2 работа с переменными 2; иначе работа с переменными 3;
вывести шаблон;
Тебе посоветовали использовать функции, но имхо тут довольно однообразный код, я не вижу в них смысла, всё и так прекрасно читается
Будет лучше, если код будет подставлять в инпуты значения из пост запроса. Позже можешь потыкать в аякс, анон выше прав
И как придирка, переменные должны быть названы так, чтобы и без поясняющих комментариев другим было всё понятно. Что за cosma? Что именно perMonth? Любой мало мальский код ревью ты не пройдёшь. Чуть позже рекомендую почитать psr стандарты и кодить согласно им, например, у нас всё оформляется по psr-12.
>>1855266 >Допустим я тупой и не могу в задачки сразу после теории Я сам как вкатывающийся (и мягко говоря не самый умный, на лету не схватываю, думаю долго), все же посоветую тебе просто долго и упорно пытаться их самому решить, никуда не подглядывая, кроме теории в учебнике и официального мануала. Если уж совсем невмоготу, то спроси непонятные тебе моменты в треде. Я заметил, что лучше начинаешь мыслить и ориентироваться в коде, изучая основы языка именно путем решения задач (самостоятельно или почти самостоятельно).
Вопрос: как в Laravel-проекте грамотно создать файл index.php, чтобы сайт работал?
Сап, ПХПеч! Я изучаю фреймворк Laravel, уже часовой гайд просмотрел, в принципе тренировочный проект работает через "php artisan serve". А я хочу обыграть ситуацию, если мне надо сбросить проект с локалки на реальный сервер и чтобы сайт работал с реального сервера. Тут возник ступор с файлом index.php — его нет.
Тем не менее, в корне есть файл startup.php, который подгружает всё с собой. Я его переименовал на index.php и это частично сработало: при переходе на сайт slonik.com/ сайт грузится, но при переходе на slonik.com/reviews, slonik.com/about и т.п. вылетает ошибка 404.
>>1854872 https://ideone.com/E54kEA Как-то так? >>1854943 А в чем разница писать ; после { или до? На что это влияет? Если бы ты это не сказал я бы вообще не понял. Я вообще искал ошибку в переменных, думал они где-то не так стоят.
>>1855587 >>1855596 У меня апач (openserver). В корень поставил файл .httaccess прописав DirectoryIndex public/index.php но это не помогло, по-прежнему заходит только на slonik.com/, а на остальных путях выдаёт 404
>>1854778 >>У тебя простые модели которые замаплены на бд с помощью ORM. ORM - это можно назвать то, как у меня мои модели "замаплены" на таблицы в базе? Так то я никаких либ типа eloquent не юзаю. >>Тогда у тебя слой моделей (domain model) Где почитать подробнее про эти "слои", и как их реализовывать в приложении? Не оч понимаю, может книгу какую?
У меня контроллер, в нем должно быть много разных данных подтягиваться из разных таблиц. И выводиться в шаблон. Для каждой таблицы своя модель. по идее нужно все это от контроллера как то абстрагировать, но я придумать как не могу пока И вот все эти модели я подгружаю через конструктор этого контроллера типа так public function __construct(){ //допустим $this->authors = new AuthorsModel() } Это по идее противоречит вообще инверсии зависимостей. Но в контроллер добавлять все эти классы через конструктор new Controller(...) - как то диковато.
В слиме есть контейнер зависимостей - но не пихать же в него все модели?
Мне бы как прмиер какое то хорошее приложение на слим, или ларавел - где все эти слои и организация кода видны правильно. Что бы один раз на примере понять как нужно делать.
> Не должен ли я в методах модели "события" получать инфу о связанных с этой моделью "статьям" - вызывая для этого соответствующие методы модели "статьи"?
Если это все усложняет, то не стоит так делать. Мы же придерживаемся принципа разделения ответственности не из религиозных соображений, а чтобы с кодом было проще работать.
В ORM это решается за счет прокси-классов и ленивой загрузки. То есть, когда ты просишь событие - тебе возвращают объект события, а внутри него вместо массива связанных статей прокси-коллекция. Когда ты обращаешься к ней, чтобы прочитать статьи, она подгружает их из БД и возвращает соответствующие объекты.
> А как реализовывать транзакции?
По идее, классы для работы с таблицами все должны использовать одно и то же соединение с БД, и соответственно, транзакции должны работать сами собой. Например, так:
Желательно после отправки формы подставлять введенные значения в поля, чтобы поля не очищались.
Значения в $_GET могут отсутствовать и это вызовет предупреждения (которые у тебя почему-то не выводятся, зря ты их отключил). Надо либо проверять явно, что они есть (if (isset($_GET['x])) либо использовать ??: $a = floatval($_GET['x] ?? 0);
Точка с запятой обозначает конец команды. То есть в случае
if ($x > 0) ; { .... }
if заканчивается на точке с запятой, и блок в фигурных скобках рассматривается просто как блок команд, который выполняется всегда, независимо от условий в if.
В случае с if, точку с запятой можно было бы писать после закрывающей скобки } , но это не требуется и потому никто так не пишет.
ORM - это когда у тебя есть класс, объект которого соответствует одной строке в таблице (а поля объекта соответствуют колонкам), и ORM занимается тем, что сохраняет/загружает эти объекты из БД.
Вроде:
class User { private $email; private $username; ... }
"Модель" - это обычно объект вроде того, что написано выше. Который представляет собой одну сущность из БД (а не всю таблицу). У тебя не AuthorsModel а AuthorsRepository, или AuthorsDataGateway (смотри паттерн Table Data Gateway).
> В слиме есть контейнер зависимостей - но не пихать же в него все модели?
А по слоистой архитектуре подскажешь что почитать? И лучше с живым примером. А то я в "в общем" почитал, а по факту мне явно нужно из контроллера все эти классы по которым я из БД данные получаю куда то наверх абстрагировать, типа слой приложения что ли. В контроллере же еще какая то логика выполняется. Я вообще зачатки это абстракции обозначил - вывел отдельный класс. Но пока не понимаю как правильно.
>>1855565 >>1856251 У меня таки получилось деплойнуть ларавель-сайт из локалки в продакшн-сервак. Скопировал .htaccess из public-директории в корень, немного подправил пару строк и заработало.
Аноны, я вот уже очень близок к уровню знаний с которыми можно спокойно искать работу, но недавно понял, что РАБотать я совсем не хочу. Планирую начинать двигаться в сторону фриланса. Посоветуйте что учить для успешного поиска заказов на фрилансе? Тяжело ли вкатится туда пхп новичку без опыта? Хватает ли там достойных заказов или же придется всю жизнь говнякать один вордпресс?
>>1849078 (OP) Правильно понимаю, что в PHP нельзя просто взять и отдать данные на запрос? В ноде например можно прослушивать порт, принимать с него запросы и отправлять ответы. В Go тоже самое. Наверное почти в каждом языке так. Как в PHP такое сделать? Мне нужно просто слушать порт и кидать туда респонсы.
>>1856527 Разве не ясно написано? Ты писал hello web на node.js, go? Создается хендлер, принимающий запрос и отправляющий ответ. Создается функция листенер, которая слушает порт и передает соединение с клиентом хендлеру. Код привести для примера? В PHP же все не так, верно? Я не могу нагуглить такой же пример на PHP. Ну вот нету их. Почему то сразу обработка форм. Мне она накой не нужна. В любом языке, на котором можно писать веб-приложения, в доке есть пример простого сервера с одним общим хендлером. Есть такое в PHP?
>>1856475 >Посоветуйте что учить для успешного поиска заказов на фрилансе? Тяжело ли вкатится туда пхп новичку без опыта? Хватает ли там достойных заказов или же придется всю жизнь говнякать один вордпресс? Еще ни дня не говнякал, а уже планы на всю жизнь? Ну откуда вы беретесь? Сделай хоть 10 заказов, хоть на вордпрессе, денег поднимешь, почувствуешь фриланс, опыта наберешься, потом жужжи про всю жизнь.
>>1856533 Если ты про асинхронный реалтайм, типа например ты хочешь чат сделать, то причём тут вообще язык программирования? Это не нод.js и не go тебе это делает, а протокол WebSocket. Следовательно какая разница на каком языке будет использоваться тот или иной протокол?
>>1856540 >Если ты про асинхронный реалтайм, типа например ты хочешь чат сделать, то причём тут вообще язык программирования? Это не нод.js и не go тебе это делает, а протокол WebSocket. Ну ты даешь, какие вебсокеты, обычный http.
>Вообще всё зависит от задачи. Что в моем описании задачи не ясно написано? Похоже у тебя пхп-деформация. На других языках писал? Я могу код привести если надо. Надо?
>>1856540 >Если ты про асинхронный реалтайм Что ты под этим понимаешь? Полнодуплексную связь? Так не подходит, написал же, что одна функция слушает порт, а другая обрабатывает запрос. Короче функция листенер это сервер. Другая это хендлер, обычный обработчик http запросов.
>>1856533 >> Создается хендлер, принимающий запрос и отправляющий ответ. В первую очередь в ноде создается объект net.Server - который и представляет собой твой вэб сервер висящий в памяти, если угодно. В пхп не так - модель выполнения другая. Вэб сервер там отдельно - аппач, нгникс или встроенные в пхп вэб-сервер. Два отдельных запроса в пхп не связанны друг с другом никак, нет никакого глобального лексического окружения в котором видны эти оба ззапроса.
>>1856541 > Создается хендлер, принимающий запрос и отправляющий ответ. Любой сайт так работает.
>Создается функция листенер, которая слушает порт и передает соединение с клиентом хендлеру. Любой сайт так работает.
Начни лучше с базовых основ для начала, потому что ты видимо не понимаешь как работает интернет) Поизучай HTTP, TCP, как реализованы сервера, сети. Создаёшь сервер, ложишь туда пхп-файл - всё, можешь принимать реквесты, отправлять респонсы.
>>1856540 Нагуглил как черес сокеты сделать. Полстраницы кода. Еще и цикл нужен. Слишком много кода, это же PHP, язык для веба, не Си ведь чтобы строку в браузер по сокетам отдавать.
В PHP доке легаси пример со встраиванием <?php echo '<p>Привет, мир!</p>'; ?> в тело html документа. Еще нужно .php файл в директорию веб-сервера закинуть. Еще чтобы он отдавал адрес не http://localhost/hello.php, а http://localhost/ нужно в настройки сервера лезть. Такое не делать в 2020 году это еще хуже чем через сокеты, веб-разработка уровня 90-х.
>>1856547 >Нагуглил как черес сокеты сделать. Полстраницы кода. Еще и цикл нужен. Слишком много кода, это же PHP, язык для веба, не Си ведь чтобы строку в браузер по сокетам отдавать. Ничего не понял.
> Еще чтобы он отдавал адрес не http://localhost/hello.php, а http://localhost/ нужно в настройки сервера лезть. Почитай что такое ЧПУ, ООП. А лучше и не лезь в дебри, научись для начала просто запускать скрипт, складывать 2+2, выучи как привести к числу строку например. В ПХП всё лаконично, идеально, красиво, но до этого дорасти надо.
>>1856544 >В первую очередь в ноде создается объект net.Server - который и представляет собой твой вэб сервер висящий в памяти, если угодно. Ну да, он же листенер.
>>1856544 >В пхп не так - модель выполнения другая. Вэб сервер там отдельно - аппач, нгникс или встроенные в пхп вэб-сервер. Два отдельных запроса в пхп не связанны друг с другом никак, нет никакого глобального лексического окружения в котором видны эти оба ззапроса. А как же HTTP 1.1? В нем есть постоянные соединения. А, понял, запрос принял-отдал и умер? Но, есть же всякие fpm, они же позволяют держать соединение?
>>1856546 >Любой сайт так работает. Нет, в PHP так не работает. В PHP веб-сервер выполняет файл по запросу, а не отдельный хендлер, и отдает его выполненным браузеру, примерно так.
>>1856546 >Любой сайт так работает. Ну и как в PHP создать функцию сервера чтобы слушала рандомный порт? И чтобы не файл отдавал сервер в браузер, а выполнял определенный хендлер?
>Начни лучше с базовых основ для начала, потому что ты видимо не понимаешь как работает интернет) Поизучай HTTP, TCP, как реализованы сервера, сети. Лол, я то понимаю как работает интернет, а у тебя видимо php-деформация. Вы же привыкли, что для того чтобы строчку в браузер отдать, нужно внедрить php код в html страницу, в других языках такого нет.
>Создаёшь сервер, ложишь туда пхп-файл - всё, можешь принимать реквесты, отправлять респонсы. Ну да, то что я выше описал. Но не все сайты так работают, повторюсь, что в других языках по другому .Хорошо что PHP не был моим первым языком программирования. Я не хейтю его, просто эти особенности, они накладывают деформацию, а потом выясняется, что это только в php так.
<?php // AF_INET6 for IPv6 // IP $socket = socket_create(AF_INET, SOCK_STREAM, 0) or die('Failed to create socket!'); // '127.0.0.1' to limit only to localhost // Port socket_bind($socket, 0, 8080); socket_listen($socket);
for (;;) { // @ is used to stop PHP from spamming with error messages if there is no connection if ($client = @socket_accept($socket)) { socket_write($client, "HTTP/1.1 200 OK\r\n" . "Content-length: " . strlen($msg) . "\r\n" . "Content-Type: text/html; charset=UTF-8\r\n\r\n" . $msg); } else usleep(100000); // limits CPU usage by sleeping after doing every request } ?>
>>1856548 >В ПХП всё лаконично, идеально, красиво, но до этого дорасти надо. Лол, очень лаконично (лаконично - кратко), чтобы строку в браузер отдать нужно смешать php код c html кодом. А чтобы отдать на <хост>:<порт>, а не <хост>:<порт>/index.php нужно веб-сервер настраивать.
>>1856549 >>А как же HTTP 1.1? В нем есть постоянные соединения. А, понял, запрос принял-отдал и умер? Именно так. Постоянные соединения, типо сокетов - не для пхп. Есть фреймворки, но там это реализуется через боль.
>>1856551 >>Ну и как в PHP создать функцию сервера чтобы слушала рандомный порт? Сам скрипт пхп ничего не слушает. Слушает вэб-сервере на котором пхп исполняется. Короче если совсем грубо - пхп это надстройка над апачем или нгниксом, такая уж модель сложилась.
>>потом выясняется, что это только в php так. Ну фактически это вроде как единственный язык с такой моделью выполнения. У этого есть и плюсы и минусы, и море споров вокруг. Я лично недостаточно компетентный что бы тут какое то мнение иметь. Имеем то что имеем.
А так язык вполне полноценный, годное ООП, интерпретатор очень быстрый. Сейчас с 8 версией, с jit компиляцией - прям пиздец какой быстрый. Читал что каких то числодробильных тестах он с определенными условиями дает скорость чуть ли не как у с++. условный питон по скорости где то далеко в сраке. Преимущество пхп - это его на самом деле оч зрелое и компетентное комьюнити.
>>1856559 Это не так. Все что требуется от сервера - настроить его на единую точку входа - и сервер все запросы кидает на условный index.php. А там уже все как у людей, создаем объект приложения, роутинг, модели, контроллеры, представления и т.д.
В любом случае даже если на ноде пишешь - придется пердолиться с вэб-серверами - обратный прокси, статику отдавать, еще всякое.
>>1856564 >Именно так. Постоянные соединения, типо сокетов - не для пхп. Есть фреймворки, но там это реализуется через боль. Ты смешиваешь все в кучу. Сокеты с циклом можно, пример кода я привел. Постоянное соединение реализовано в HTTP 1.1, по идее должна быть реализация в PHP, позволяющая это использовать без написания сокет-соединения вручную. Ведь с базами данных есть постоянные соединения? Почему не сделали за 20 лет тоже самое для HTTP?
>Сам скрипт пхп ничего не слушает. Слушает вэб-сервере на котором пхп исполняется. Короче если совсем грубо - пхп это надстройка над апачем или нгниксом, такая уж модель сложилась. Почему же. Сервер необязателен. Можно же через сокеты, просто файл запускаешь php index.php и он уже слушает бесконечно и обрабатывает запросы Можно через встроенный сервер, встроенный сервер это обычный PHP скрипт. Но это не то, не идиоматично для современной веб-разработки.
>Ну фактически это вроде как единственный язык с такой моделью выполнения. У этого есть и плюсы и минусы, и море споров вокруг. Я лично недостаточно компетентный что бы тут какое то мнение иметь. Имеем то что имеем. >А так язык вполне полноценный, годное ООП, интерпретатор очень быстрый. Сейчас с 8 версией, с jit компиляцией - прям пиздец какой быстрый. Читал что каких то числодробильных тестах он с определенными условиями дает скорость чуть ли не как у с++. условный питон по скорости где то далеко в сраке. >Преимущество пхп - это его на самом деле оч зрелое и компетентное комьюнити. С этим не спорю. Вот и хочу попробовать как он по скорости. Может мне для поделок и сервер не понадобится на начальном этапе. Да и вообще так лучше пойму что как работает.
>>1856568 >Все что требуется от сервера - настроить его на единую точку входа - и сервер все запросы кидает на условный index.php. А там уже все как у людей, создаем объект приложения, роутинг, модели, контроллеры, представления и т.д. Ну я и говорю, во первых сервер нужен, во вторых настраивать его. Я в этом не силен и пока не охота ввязываться. Собственно как запускать без сервера я уже придумал. Либо через сокеты либо через встроенный сервер.
>>1856568 >В любом случае даже если на ноде пишешь - придется пердолиться с вэб-серверами - >обратный прокси, статику отдавать, еще всякое. В продакшене только. Нода и так справляется.
>>1856604 >На всяких shared хостингах V8JS вряд ли есть Сейчас shared хостинги дороже обходятся виртуальных серверов. Что означает 4X Распределённых ресурсов? Нормальный виртуальный хостинг от 400 руб./месяц, там эти самые 4X Распределённых ресурсов, а ближе к средненькому VPS можно взять от 200 руб./месяц.
>>1856621 >Вопрос остаётся открытым: как с помощью пыхи отдать клиенту отрендеренный в хтмл реакт? Ну подумой, как можно выполнить реакт без ноды? У тебя сервер или что? Можешь прикрутить саму ноду без расширения для php, но это сложнее будет.
>>1856624 >Линуксом пользовался? Клиентам от меня нужен код приложения, и ебаццо с V8JS буду не я, а сам клиент или какой-нибудь админ. А ебаццо с неведомой хуйнёй, которая ещё не факт, что заработает, не захочет никто (деплой нихуя не отлажен). Поэтому полагаться на V8JS нельзя.
P.S. Естественно, ни для чего нового пыха не используется. Однако в легаси-говно (вроде вордпресса или битрикса) могло бы быть полезно затащить SSR. Но пыха такая пыха...
>>1856632 >Клиентам от меня нужен код приложения, и ебаццо с V8JS буду не я, а сам клиент или какой-нибудь админ. А ебаццо с неведомой хуйнёй, которая ещё не факт, что заработает, не захочет никто (деплой нихуя не отлажен). На раз-два решается докером. Вот https://habr.com/ru/post/513682/
>>1856632 >P.S. Естественно, ни для чего нового пыха не используется. Однако в легаси-говно (вроде вордпресса или битрикса) могло бы быть полезно затащить SSR. Но пыха такая пыха... Кто сказал? Еще как используют. Разница какая, ну надо было бы к Go прикрутить V8, пришлось бы делать аналогичные телодвижения.
>>1856638 >На раз-два решается докером. Вот https://habr.com/ru/post/513682/ И получается тормозное говно. >Единственное что стоит здесь добавить — рендер может занимать достаточно долгое время
И, в любом случае, рядом с рабочими вордпрессами и битриксами никто не будет ставить неведомую хуйню вроде V8JS только ради SSR.
>>1856661 >нет единой канвы,как у пхп фреймворков Ну, для таких предъяв нужно хотя бы немного знать экосистему ноды. А в этой экосистеме уже давно есть NextJS и NestJS, которые позволяют писать горизонтально масштабируемые легко поддерживаемые веб приложения любой сложности. С другой стороны, пыха - это легаси-говно для написания немасштабируемых легаси-говномонолитов, которые при достижении определённых объёмов становится невозможно поддерживать.
>>1856665 >И получается тормозное говно. Измерял, пруфы есть? Конечно же ты выяснил, что это именно из-за докера? В 2020 от докера минимальный оверхед. Скорее php расширения написаные дегродами будут тормозить.
>И, в любом случае, рядом с рабочими вордпрессами и битриксами никто не будет ставить неведомую хуйню вроде V8JS только ради SSR. Так зачем ты вола ебешь с ssr? Или ты думал можно с помощью пары кликов к легаси гавну вордпресс и битрикс все что хочешь прикрутить?
>>1856672 Нет,не все.На пыхе ты сразу начинаешь писать бэк Когда единый дизайн со всем необходимым. Эко ноды-низко урваневое говно. А большой жс проэкт прям мечта перфикциониста? Через пару лет превратиться в нечитаемое говно
>>1856674 Но реальность такова что в пхп и ноде одни и те же лица. И в пхп и ноде код не поддерживают десятилетиями а переписывают, благо эти лица на рынке труда ценой пучок за пяток.
>>1856679 На пыхе кот тоже обычно сразу нечитаемое говно, причем со всеми сервисами, билдерами, фабриками, которые обычно используются не к месту, чистый карго культ.
>>1856679 Когда нужно сделать то, что php не умеет из коробки, начинается забивание гвоздей лопатой. У ноды экосистема очень развитая, если надо что-то нестандартное для всего есть уже либы, а в php если и есть что-то, то часто легаси. У тебя максималистское мышление. Всегда в крайностях. Пойми, что одним языком не решишь все задачи.
>>1856684 >Я ж тебе цитату автора той заметки про V8JS с хабра дал, на которую ты сослался. Я должен щас на слово ему верить? Мало ли что там он пишет. Может у него руки из жопы и он не смог по человечески все сделать, а может просто не делал толком ничего и не мерял, а просто воздух сотрясает.
Какой-то студент-двачер, который аж хелоуворлд написал на ноде - ворвался в тред и пытается видимо что-то высрать/доказать, да несёт полную чушь.
Иди срать в тред со своей нодой, зачем тебе PHP? Что, на ноде деньги не платят, ибо нахер никому она не всралась а PHP решает все веб-задачи, поэтому приходится таки PHP учить?)
Ты плохо гуглишь. Свое незнание ты не замечаешь, а сразу начинаешь придумывать несуществующие недостатки PHP. Задачу сформулировал плохо, что даже непонятно, какой протокол ты хочешь использовать.
Если тебе нужно принимать запросы по протоколу HTTP - то тебе не нужно руками открывать порт, в PHP уже встроен веб-сервер с роутингом. Просто кладешь файл index.php, запускаешь веб-сервер и index.php будет запускаться при поступлении запроса GET /. В нем ты отдаешь любой ответ, какой хочется.
Заметь, что в отличие от Ноды, не нужно возиться и устанавливать сторонние библиотеки, все встроено. В отличие от Ноды, не нужно перезапускать сервер, если ты поменял что-то в коде index.php.
Если нужно асинхронно, то либо переводи сокеты в неблокирующий режим, либо, что проще, используй библиотеки вроде ReactPHP.
И ноду не приводи в пример. Более ужасный язык, чем JS, трудно себе представить. Ничего, кроме нечитаемой лапши, на нем не пишут (по моему опыту взаимодействия с фронтенд-специалистами).
При этом каждый слой отвечает за что-то свое. Например, data source layer на картинке отвечает только за получение/сохранение данных из БД, domain model - за бизнес-логику, service layer - делает сложные операции, требующие совместной работы нескольких низлежащих классов.
Такая схема подразумевает использование ORM вроде Доктрины, без него отделить domain model от data source layer сложно.
В простом приложении тебе вполне хватит 2 слоев: слой контроллеров и слой сервисов с бизнес-логикой. В контроллере происходит контроль прав доступа, разбор пришедших от пользователя параметров, вызов нужных сервисов.
> а по факту мне явно нужно из контроллера все эти классы по которым я из БД данные получаю куда то наверх абстрагировать, типа слой приложения что ли.
Вообще непонятно, о чем речь и что ты называешь "слоем приложения".
В твоем первоначальном описании ничего про HTTP не было сказано, отсюда и непонимание, чего тебе нужно. Существует множество других протоколов, кроме HTTP.
Ты опять свою неграмотность выдаешь за недостатки PHP. Плохо гуглишь. Элементарно настройками веб-сервера можно перенаправить все запросы на один скрипт и в нем вручную маршрутизировать URL как угодно. В случае встроенного в PHP веб-сервера, например, скрипт маршрутизации просто указывается в командной строке: https://www.php.net/manual/ru/features.commandline.webserver.php
> Полстраницы кода. Еще и цикл нужен. Слишком много кода, это же PHP, язык для веба, не Си ведь чтобы строку в браузер по сокетам отдавать.
В ноде или Го без сторонних библиотек еще больше кода будет. В отличие от них, в PHP уже есть встроенный HTTP-сервер. А со сторонними библиотеками ты можешь поставить фреймворк вроде Slim и будет точно так же как и в ноде - с маршрутизацией и функциями-хендлерами.
> Но, есть же всякие fpm, они же позволяют держать соединение?
Неграмотность так и прет из тебя. PHP-FPM не поддерживает keepalive, так как работает по протоколу FastCGI, а не HTTP.
Keepalive реализует балансер вроде nginx, а на бекенд он прокидывает запросы по протоколу FastCGI. Опять, проблема в твоем незнании, ты не разбираешься как что устроено, но торопишься обвинить во всем PHP. На котором писать гораздо комфортнее чем на какой-нибудь Ноде, которая игнорирует кучу ошибок (вроде опечаток в имени свойства), у которой течет память, и в которой нет тайп-хинтов.
> Почему не сделали за 20 лет тоже самое для HTTP?
Потому что это никому не нужно. Keepalive терминируется на балансере вроде nginx. А дальше nginx он не идет, так как nginx обычно взаимодействует с бекендом через FastCGI, который - внезапно - основан на постоянном соединении. Неграмотность так и прет.
> Нода и так справляется. В PHP встроенный веб-сервер тоже справляется. А писать на PHP удобнее, чем на JS с его кучей недостатков и отсутствием тайп-хинтов.
Ну и идиотизм. Зачем вордпрессу реакт и SSR, если он свои страницы и так генерирует на сервере. Ты бы почитал, как SSR расшифровывается. Вордпресс прекрасно работает без всяких реактов, а ты пытаешься на ровном месте усложнить архитектуру без всякой выгоды. Чтобы вместо 20 Кб HTML, которые сразу отображаются на экране, тебе сервер отдавал заглушку, потом мегабайт-два тормозного реакта, а потом тот медленно делал кучу аякс-запросов для получения данных.
Ты ничего ни в архитектуре, ни в работе веб-приложений не понимаешь.
Выкинь свой реакт и переходи на серверный рендеринг и твой сайт будет грузиться в 10 раз быстрее.
Монолит это, наоборот, хорошо. В нем проще взаимодействие между модулями, не нужно городить API, не нужно городить оркестрацию и тащить докер, нет проблем с версионированием и совместимостью, проще отлаживать код. Монолит во всем лучше и удобнее микросервисов и работает без докера.
На микросервисы переходят не потому что они чем-то лучше, а от безвыходности, когда очень много кода и людей.
Микросервисы имеют смысл только в огромных командах и огромных приложениях, а когда средняя фирмочка из 10 человек пытается изображать из себя Гугл и пилит микросервисы по полтора человека на сервис, это выглядит как посмешище. Если они не осилили правильно разбить на модули и организовать монолит, у них и микросервисы выйдут такие же кривые и убогие, как и их монолит.
Как на твоей ноде можно вообще что-то писать, если там нет тайп-хинтов? Это же нечитаемая лапша выйдет, которую понять невозможно.
У тебя полный набор стереотипов и заблуждений в веб-разработке. Ты не понимаешь плюсов монолитных приложений в сравнении микросервисами, это автоматически обесценивает все твои рассуждения. Не видишь недостатков JS, которые просто бросаются в глаза. Скорее всего, ты просто пересказываешь чужое неграмотное мнение. Где-то прочел, что монолит и PHP это плохо, но сам не понимаешь ничего в архитектуре.
Причем он наверняка никогда не работал в команде и не видел чужого кода. Свой-то код всегда кажется понятным, даже если он написал как попало. Отправить бы его на проект на его любимой ноде хотя бы на 100 000 строк, и чтобы все было на асинхронном коде и промизах, и пусть он там попробует разобраться в получившейся нечитаемой лапше без тайп-хинтов.
>>1856954 > В отличие от них, в PHP уже есть встроенный HTTP-сервер. За Го ничего не скажу, но в ноде есть нативный объект net.httpServer - он и является вэб-сервером.
А вообще ты типа апологет пхп, но делаешь это как то странно, лучше вообще ничего не писать. Любому ясно что у всякой технологии есть +/-, и евангелистские споры удел людей которым заняться нечем. Единственно что факт - пхп точно не умрет, но вот ниша его... Я бы хотел что бы пхп перешел все таки из лиги языка для цмс. Хотя может этот выход его и погубит, а может как то на двух стульях усидит. Хз, время покажет, но пока что пхп точно не собирается помирать. Как впрочем и нода. Мне обе эти платформы нравятся, они в некотором роде противоречат друг-другу, и поэтому интересно изучать обе.
>>1856954 >В отличие от них, в PHP уже есть встроенный HTTP-сервер Бля, долбаеб. Если ты никогда не пхп не писал, так сиди и молчи. Нахуй ты рандомную хуйню пишешь? Какой-то веб сервер, какие-то настройки. Про что несет? Вообще охуеть.
>>1856405 .env уже закрыт от сторонних глаз и без .htacess (проверил), такшто тут фсьо харашо.
>если все через жопу любишь делать А если не через жопу делать, то как это выглядит?
Кстати, на офф сайте laravel есть статья о деплойменте своего проекта в продакшн сервер, но советы в статье - говно, ибо там пишут какую-то далёкую от реальности бесполезную ахинею
Привет анончики, хочу начать изучать PHP для фриланса, с чего начать уже понял. Вопрос такой: долго ли вкатываться и есть ли возможность после вката зарабатывать 30к на фрилансе?
>>1856487 слушать порт на пхп(без веб-сервера - сам пхп выступает как сервер) https://reactphp.org/ есть мнение что для таких задач лучше использовать golang/node.js/...
>>1856979 >сколько я не видел JS кода, написанного фронтендщиками - весь был убогая нечитаемая лапша с кучей сайд-эффектов Это говорит об изъянах JS? Ну OK, пусть это будет считаться аргументом. На PHP написано около 80% всех существующих сайтов, верно? PHP родился калекой, был очень простым в использовании, поэтому стал очень популярным среди необразованных кодеров, школьников, и им подобных, верно? Кто выходит написал большую часть этих 80% всея интернета? Эти самые необразованные кодеры, школьники, и им подобные. Их код не убогая лапша с кучей сайд-эффектов? Так что там получается, PHP еще хуже JS, так?
>Нету тайп-хинтов TypeScript, Flow, etc.
>Классы удогие Уточни.
>опечатка в имени поля объекта не выдает ошибки Линтер?
>>1856989 >Монолит это, наоборот, хорошо. В нем проще взаимодействие между модулями, не нужно городить API, не нужно городить оркестрацию и тащить докер, нет проблем с версионированием и совместимостью, проще отлаживать код. Монолит во всем лучше и удобнее микросервисов и работает без докера. > >На микросервисы переходят не потому что они чем-то лучше, а от безвыходности, когда очень много кода и людей. > >Микросервисы имеют смысл только в огромных командах и огромных приложениях, а когда средняя фирмочка из 10 человек пытается изображать из себя Гугл и пилит микросервисы по полтора человека на сервис, это выглядит как посмешище. Если они не осилили правильно разбить на модули и организовать монолит, у них и микросервисы выйдут такие же кривые и убогие, как и их монолит. Столько одностороннего бреда, что даже не хочется отвечать. Но попробую привести один пример. Фирмочка из 10 человек не может иметь кодовую базу в районе миллиона или более строк? Еще как может. Команды стартаперов из 2-5 человек создают рабочие комерчески успешные проекты, к примеру на Рельсах. Имея так мало рук, ограниченный бюджет и время, они конечно же используют по максимуму богатую экосистему Руби. Собирают большие системы из множества библиотек. Для них простота монолита уже не важна, встают вопросы поддержки кодовой базы и высокой производительности. Так как рук, денег и времени мало, они режут монолит на сервисы, используют контейнеры и оркестрацию, и по максимуму все автоматизируют. Да, приложение может в таком случае выглядеть переусложненным, но зато оно работает и способно поддерживаться и развиваться небольшой командой, принося при этом реальные деньги.
Для многих php-разработчиков такое конечно сложно понять, у них другие понятия в голове, и они решают немного другие задачи. Поэтому если ты из таких, подумай головой и осознай, что не бывает четко хорошо или плохо, бывают рабочие, приемлемые решения. У тебя все как то бинарно. Наверное потому, что ты не управлял командой, и не вел проектов самостоятельно неся на себе риски. Пока ты ходишь и ищешь кто не правильно в интернете пишет веб-приложения, другие создают успешные проекты.
>>1856954 >В отличие от них, в PHP уже есть встроенный HTTP-сервер. Чиво-чиво??? Лол, PHP язык-бомж, не умеющий работать с HTTP изначально, его научили спустя 20 лет засунув этот самый встроенный сервер. В то время как во многих языках из коробки можно использовать HTTP и многие другие протоколы безо всяких встроенных либо внешних веб-серверов. PHP это легаси, все время его существования из него пытаются сделать что-то нормальное, так как родился он калекой. В JS/Node/Deno - на данный момент одна из самых совершенных экосистем, наравне с .NET Core, Ruby (была самой совершенной долгое время, сейчас теряет позиции так как медленно развивается), Python. Да, JS родился недоношенным, но в него заложили неплохой фундамент и возможность дальнейшего развития. Сейчас почти любую проблему, которую ты озвучишь можно решить с помощью встроенных или сторонних инструментов. Один только Babel какие дает возможности, где еще такое есть?
>>1857130 >Долго ли вкатываться? От тебя зависит. Смотря какой бэкграунд, какие способности к обучению, какие возможности обучаться, то есть сколько времени на это тратить, насколько упорно заниматься.
>Есть ли возможность после вката зарабатывать 30к на фрилансе? На фрилансе можно столько зарабатывать из без PHP, например версткой.
>>1857130 Я уже 3 года вкатываюсь блядь. С ноля научился фактически. Сейчас на нодеголая нода или экспресс, на пхпслим/ларавел могуч чет написать, на ларе что то типа магаза. JS в браузере естественно могу. В SQL умею. Работаю в гос-шараге - пишу для БД скрипты в основном. ЗП - унылая. Пока учился, да и сейчас 70% времени трачу на хуиту. Не умею искать заказы - так как овощ по жизни.
Так что поверь - уровень твоих практических навыков на пхп - будут в контексте заработка далеко не первой проблеймой. Я за три года так и не заставил себя дисциплинированно работать.
>>1857457 >Работаю в гос-шараге - пишу для БД скрипты в основном. ЗП - унылая. Зачем тебе на пыню работать, если нужно на Запад? Уволься и начни изучать PHP-фреймворк+базовые основы фронтенда под его, а так-же learn english.
>>1857402 Если ты такой умный и якобы что-то утверждаешь по ПХП, то сначала покажи-ка нам свой гит. Не надо балаболить, ты пришёл учиться пхп - сиди и учись у старших, что ты споришь с профессионалами?
>>1857130 >долго ли вкатываться От тебя зависит. В среднем думаю 1-3 года, как и в любой работе. >есть ли возможность после вката зарабатывать 30к на фрилансе? Как работал - так и заработал. Будешь ~160 часов в месяц работать - будешь зарабатывать 30к.
Основная причина того, что я за километр обхожу js говно - это то, что оно руководствуется хайпом, а не мозгами. Каждый ебаный год оно тащит новые ебаные паттерны, всё написано хуй пойми как, и когда пытаешься им объяснить что они творят дичь они дружно начинают кукарекать про современные подходы.
Сколько они дрочили сраные коллбеки? 8 лет? Только недавно до долбоебов дошло, что это брат близнец ибаного goto.
>>1857391 >Это говорит об изъянах JS? Об изъянах js просто ОРЕТ тот факт, что на динамический мать его язык из года в год накручивают компилируемые в него, лол.
TypeScript - луч света в темном царстве говна, но даже ему не под силу до конца отбить вкус нативки.
>максимуму богатую экосистему Руби >создают рабочие комерчески успешные проекты >принося при этом реальные деньги. Блядь, что это я читаю? Стиль написания как у стартапера, который пытается втюхать лоху Руби, что ли? Втюхать собранный из говна и палок проект и съебаться раньше, чем он попросит его доработать?
>>1857531 хуелерн ингриш, ага. Еботеку я с чего буду платить? Я однажды уже ушел "вникуда", до сих пор хвосты разгребаю. А на той прошлой работе меж тем, пусть она условно it была, а к прогингу так вообще отношение никакого, ЗП стабильна, и стабильно растет. Просто я на той работе сдеградировал нахуй, до сих пор последствия имею. Впрочем если бы там остался - то вообще нихуя бы не добился и не изучил. Так что не зря ушел, в любом случае.
Вкатывальщику в современное прогроммирование нужно быть уже кабанчиком, пилить сови проекты, ходить по тусовочкам, заводить нужный знакомства и вообще суетиться. Программирование как манямечта-прибежище сыча - уже почти нигде не существует.
>>изучать PHP-фреймворк Я же пишу, я на ларавел/слим/ноде магазин написать могу или что то в духе, клиентский JS знаю. Немного могу в реакт - но мне он совсем не нравится. Но что бы вкотиться нужно подсакивать , и активно подскакивать. Не был бы овощем - давно бы на удаленке сидел.
>>1857535 >Сколько они дрочили сраные коллбеки? 8 лет? Только недавно до долбоебов дошло, что это брат близнец ибаного goto.
Не гони, вы в истерику какую то скатили тред. В ноде колбэки - это не маня выбор. Это естественная, и самая простая организация асинхронной модели выполнения в одном потоке. Потом доползли до промисов, а потом и до async/await. И что промисы, что асинк-авейт это по сути просто сахар над коллбэком, на сколько я знаю. В пхп естественно это не актуально, и особо не нужно. Нужно ждать ответ ввода/вывода - скрипт подождет спокойно. У всего свои плюсы и минусы
>>1857545 Так я понимаю, просто в том и суть, что работа сжирает время и силы. Есть работа - нету времени учить что-то ещё, нет работы - есть время, да жрать нечего и платить за хату)
Я лично понимаю что надо работать не больше 20 часов в неделю, иначе так за пару лет выгорю. А если у вкатывальщика того куча времени и никуда тратиться не надо, мамка кормит - это идеальное время для вката, если каждый день учиться проге.
>>1857557 >>А если у вкатывальщика того куча времени и никуда тратиться не надо, мамка кормит То такие в 99% в дотку ебашат, зона комфорта жи. >>просто в том и суть, что работа сжирает время и силы. У меня по условиям на данным момент оч хорошая работа, оч много свободного времени, и нагрузка релевантна моим задачам. И на этой работе я порою неделями на проебе, зона комфорта жи. Сейчас одно приложение на ноде накатал для конторы, и еще два на пхп на подходе. Просто платят реально мало, минус еботека и вообще залупа остается. И программирую я один, нет опыта от людей пищущих профессионально.
>>1855565 не был тут неделю, а такие эпики происходят. дристанул на всю борду. зря ты сразу во фреймворк полез, анонче. надо было че попроще для начала. а тут в ларавеле магии слишком многовато...
>>1857761 >зря ты сразу во фреймворк полез, анонче. надо было че попроще для начала Уже сделал магазин на Опенкарте, даже есть 2 продажи (полтора месяца в продакшне). Я там дохера всего руками правил, готовых модулей почти не ставил, дизайн сам верстал. Теперь хочу освоить что-то посерьёзнее, выбор пал на ларавель, ибо большое комьюнити и востребован.
>>1857990 Можешь на email написать, скину линк на магаз. Opencart вообще хорошая вещь для вкатывающихся, там файловая структура предельно понятная. Но бля, костылей потом в дизайне у меня лично дохера вышло. Вроде и норм работает, но некрасивый какой-то код.
>>1857998 В принципе можно и иагаз посмотреть, ном еня больше интересует другое - ты магаз написал для себя? Чем то торгуешь? просто у меня уже месяца три есть идея написать совй магаз, есть желание торговать начать, может с переходом в реал, арендой и всем таким.
Бля, я походу тупой, но не подскажите что надо сделать чтобы работать с базой данных через php? Я скачал с сайта oracle mysql-installer-community. Мне его надо просто поставить и из коробки все нормально заработает?
Я раньше вроде делал такое и получалось. А сейчас ну не идёт и всё тут. Может кто подскажет, как правилно, или даже даст пример рабочего конфига для Вордпресса?
>>1859152 Сам добил. После RewriteEngine On нужно было вставить RewriteCond %{HTTP:X-Forwarded-Proto} !https RewriteCond %{HTTPS} off RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301,NE] #Эта строчка делает мейджик, блеадь! Без неё админка вордпресса уходит в бесконечный редирект, а на самом сайте не подгружаются стили. #Для HTTPS, при совместном использовании nginx и apache апачу необходимо ЯВНО указать, что он должен #работать с HTTPS а не HTTP, если nginx принял соединение по HTTPS, а не HTTP SetEnvIf X-Forwarded-Proto https HTTPS=on
Какое же всё таки днище этот веб. У каждого сервера свои стандарты и всё это нужно как-то дружить.
>>1858368 >у меня уже месяца три есть идея написать совй магаз, есть желание торговать начать Зачем если можно стать партнером крупных магазинов и получать процент с продаж если кто перейдет с твоего сайта и сделает покупку?
>>1858772 В laravel есть scaffolding, чтобы ты мог быстро добавить bootstrap, vue.js, react... Прогугли: Livewire, Inertia. Раньше был laravel/ui (и сейчас есть)
Блять, есть какая нибудь нормальная инструкция как подключить к php на встроенный локальный сервер базу данных? типо тут это скачай, тут это напиши, тут такую команду отправь. Полдня пытаюсь разобраться и нихуя непонятно.
>>1859264 Хули там разбираться? Сервер бд сам по себе, пхп сам по себе. Поднимешь сервер и подключайся себе сколько влезет. Для даунов типа тебя делают сборочки готовые.
>>1859272 Я не хочу быть дауном и разобраться что и как. Я уже для простоты установил sqlite (db browser fir SQLite). Создал файл .bd Закинул этот файл в папку с другими своими тренировочными файлами пыхи. Запустил сервер в этой папке А чё дальше делать? Везде пишут типо надо просто пару функции написать, но у меня как будто сервере не знает что с БД делать. Есть подозрения что надо что-то менять в php.ini но я раскомментировал строки с sql и все равно нихуя не работает
>>1859277 Ты хочешь и административную часть досконально знать, и программистом быть. Забей на эти тонкие настройки, скачай opeserver и там уже все конфигурации прописаны
- тебе надо установить сервер MySQL. Он будет работать в фоне, и выполнять запросы клиентов. Установщик MySQL имеет графический интерфейс, так что команды выполнять не требуется. - на стороне PHP, чтобы он мог подсоединиться к MySQL, нужно установить либо расширение mysqli, либо pdo_mysql. В винде они скорее всего идут в комплекте с PHP, и для их подключения надо только прописать или раскомментировать строчку в php.ini (extension=xyz.dll)
Что касается SQLite, это встраиваемая (бессерверная) БД. Для нее устанавливать сервер не нужно. Она работает напрямую с файлами с данными. Достаточно только расширения Sqlite3 или pdo_sqlite. Они скорее всего тоже идут в комплекте с PHP, а если не идут, то можно их скачать и положить в папочку с расширениями. Опять же, включить их в php.ini и ты можешь работать с БД.
"db browser fir SQLite" - это всего лишь просмотрщик db-файлов, как я понимаю из названия.
Под виндой расширение - это dll-файл вроде php_mysql.dll. Часть расширений идет в комплекте с PHP (они в папочке ext), часть надо скачивать самостоятельно с сайта pecl: https://pecl.php.net/packages.php . В любом случае, чтобы расширение подключалось при запуске PHP, надо его прописать в php.ini. И перезапустить сервер.
Проверить список установленных расширений можно в консоли командой php -m или вызвав функцию phpinfo() в скрипте.
Задавай уточняющие вопросы, а то не очень понятно, что ты сделал, а что нет.
Доброго вечера, анончики. Я только встаю на путь программирования, начал заниматься по вашему учебнику, предварительно повторив HTML и CSS, хочу поинтересоваться, а в чем пишете коды вы, ну то есть, чтобы мне сразу привыкать и разобраться в серьезных редакторах или этих IDE и писать сразу там, даже когда учусь? Я вот скачал, который был указан в учебнике из шапки, но там похоже установка сложнее чем просто запустить экзешник, помогите немножко, пожалуйста.
Посоветуйте, пожалуйста, статьи или книги в которых есть пошаговое создание сайтов. В видео формате много контента, но мне больше по кайфу что-то учить под музыку, да и вообще по тексту учить проще и быстрее.
Сначала были те кому нужно было помочь с гуглением. Потом пришли те кто не смог установить иде. Закончилось теми кто не смог включить комп. У них вся вечность впереди. Аминь.
>>1859646 Пожалуйста. А теперь бесплатный совет. Основные навыки чтобы успешно вкатиться: 1 Умение самостоятельно гуглить искать информацию 2 Умение самостоятельно решать задачи 3 Умение разбивать большие задвачи на маленькие 4 Умение самостоятельно ставить задачи
Тебе надо установить MySQL сервер. Он управляет базой данных и выполняет запросы клиентов. Также, тебе нужно в PHP установить либо расширение mysqli, либо pdo_mysql (либо и то, и другое). Расширения скорее всего идут в комплекте с PHP. Расширения надо прописать в php.ini, как описано тут: https://www.php.net/manual/ru/install.pecl.windows.php
> Мне его надо просто поставить и из коробки все нормально заработает?
Скорее всего, потому что в винде есть WSL на такой случай. Хотя, непонятно, что делать пользователям Windows 7. Зачем помогать майкрософту и заставлять людей апгрейдиться на худшую версию с телеметрией и принудительными обновлениями с перезагрузками. Как можно этот хлам одобрять, не понимаю. Никакого уважения к пользователю. Унижают, как только могут.
У тебя там ошибка, что выражения внутри скобок должны иметь фиксированную длину, то есть "+" использовать нельзя. Можно использовать для разбиения строки такое выражение:
- до текущей позиции должен идти знак препинания (один). Это lookbehind assertion. - после текущей позиции не должно быть знаков препинания. Это lookahead assertion.
У тебя + лишний. Он тут никакого смысла не имеет, так как assertions не поглощают символы и не сдвигают позицию, и делать их повторение (с помощью +) бессмысленно.
Хочу познать симфони (делал задачи из шапки на слиме/ларе). Для себя вижу такие варианты: 1. ПопенСорс проекты на симфони. 2. Курсы (по типу symfony casts, youtube) 3. Придумать проект и писать ориентируясь на доку.
Спасибо пидорам из датастакса, которые писали модуль под пхп для их cassandra-драйвера. Мало того, что собранных пакетов под пхп свежее 7.1 нет, мало того, что пришлось компилировать их c++ драйвер под свежий опенссл, так у них еще и в макросах для компиляции пхп-драйвера ошибка.
>>1860259 Просто пхп слишком охуенен для этих устаревших технологий. Мы с почанами двадцать лет уже пилим одностраничные сайты и ни разу не понадобилась эта коксандра или кафка беспонтовая. Ты тоже не выебывайся, а ставь мускуль 5.6. Это проверенное временем решение.
Я файлообменник сделяль. Можно было бы еще много чего допилить, но времени мало, и хочется побыстрее потрогать ларавель. Гитхаб в теме. Демонстрацию посмотреть можно здеся: https://ru.files.fm/f/992rcsz2e
Мне нужно в одном методе изменить сразу несколько моделей ( которые представляют собой разные таблицы ), и сделать это транзакцией. Я ничего лучшего как передачи объекта подключения к БД по очереди в каждый нужный метод требуемой модели не придумал.
Типа так: $dbh = new PDO(...); $dbh->beginTransaction();
$model1 = new Model1; //по идее объект $dbh возвращать не особо нужно - объекты по ссылке передаются же. //или все таки нужно? $model1->method( $dbh );
$model2 = new Model2; $model2->method( $dbh );
$dbh->commit();
Думаю есть более удачные варианты такого расклада, может кто нибудь подскажет?
не могу понять, точнее не понял еще как пользоваться библиотекой пхп. Но как сделать, что бы скрипт начинал работать по кругу при определенном значении. В игре в кубики, хочу что бы скрипт по новой крутился при ничьей, какая команда?
>>1861344 >Почему первые две строки выводят >Deprecated: The behavior of unparenthesized expressions containing both '.' and '+'/'-' will change in PHP 8: '+'/'-' will take a higher precedence in on line 5 Обнови пыху раз оно у тебя вообще запускается
Скорее всего дело в приоритете операций, и у тебя сначала выполняется точка, а только потом плюс или минус. Расставь скобки явно, например, echo $a . " + " . $b . " = " . ($a + $b) . "<br>";
>>1860687 >хочется побыстрее потрогать ларавель Нахуя если у тебя там симфони? Ларавель по сути ничем не отличается. Хочешь нового и необычного попробуй Elixir & Phoenix. На нем можно писать асинхронные, паралелльные и распределенные приложухи без заморочек.
>>1861835 Опять крутишься как уж на сковородке. Как языком 3.14здеть так тут как тут, а как название книг написать вместо пустого 3.14здежа, так язык в жопу засунул. Несите следующего.
>>1861847 PHP 7 Zend Зандстра М про OOP Lopez A Php 7 и обязательно гугл ОФ доки херово подходят для полного нуля,но оч хороши,чтобы видеть ВСЕ возможности языка,которых нет в учебниках
Здравствуйте, подскажите, пожалуйста, где искать хорошего программиста с адекватной стоимостью услуг со знаниями laravel и ffmpeg ? Вконтакте в основном кидалы, на хабре написал восьмерым, прошло 5 дней и ни один ещё не посмотрел ТЗ и не назвал цену за работу. На фрилансе в основном команды и фирмы, которым надо заплатить больше, но в итоге всеравно основную работу будет делать один человек, а индусы вообще зажрались, ценники как будто они вечерами подрабатывают после работы в гугле. Я не жадный, просто не люблю переплачивать за одинаковую работу.
>>1861922 Имею опыт тестирования (Валидация/XSS) и исправления ларавеля, но конкретно на пыхе никогда не специализировался >не люблю переплачивать >прошло 5 дней Если нет каких-то душащих дедлайнов - могу взяться за символическую плату
Почему бы тебе не пойти на фриланс-сайт? Сформулируй четкое ТЗ, проверь портфолио и опыт исполнителя, попроси у него рекомендации и проверь их, работай с исполнителем через escrow ("безопасная сделка").
Также, на фрилансе ты можешь пройти по каталогу фрилансеров, отобрать подходящих и написать им лично.
На фрилансе большое число фрилансеров и есть конкуренция. Если они все просят больше, чем ты готов заплатить, значит такая реальная цена этой работы.
>>1854267 Описание задачи не полное, анон. Поэтому оценка навскидку может быть сильно, так, неверной. Сам функционал этой фичи пилится за пару дней максимум и выйдет в районе 3-4к. Но его ещё надо интегрировать в веб-сервис(тоже время+деньги), и вот тут уже ты никакой инфы не дал совсем. Что за сервис, на чём сделан? А если его нет, то надо и его писать, что встанет сильно дороже - считай с нуля делать.
Сортировка по убыванию Выведите идентификатор товара и сумму, потраченную на него, в отсортированном по убыванию этой суммы виде. Список платежей находится в таблице Payments. Для вывода суммы используйте псевдоним sum.
Я пишу SELECT good, unit_price AS sum FROM Payments ORDER BY sum DESC
Говорят, неверно. Может, они хотят, чтобы все покупки одинаковых товаров были просуммированы и уже суммы были отсортированы? Но в материале до этого ничего о сложении полей не было сказано.
>>1862318 >3 года Вот видишь, у тебя опыт есть, поэтому тебе достаточно доков, а тот чел наверное неопытный, поэтому книги, которые я посоветовал, Скляр, Котеров, ему как раз.
Кто-то работал с фрилансерами веб-дизайнерами? Где их можно искать, чтоыб норм было?Есть какие-то совета как дизайнеру тз писать, или там все уже при обсуждении определяется?
Анон, подскажи почему при добавлении бордера топ/бот в список li, он не обводит всю строку? Убрал буллеты лист стайл тайпом и поебать вообще, они как будто все равно присутствуют и мешают бордеру обвести всю строку... Час сижу пержу не могу понять блять. В гугле ниче полезного не нашел
Гайс, как понять свой реальный уровень и эффективность моей работы? Т.е если я отсобеседуюсь на мидла с зп 80+, могу ли я считать себя мидлом? Или если не выгнали - мидл и своих денег стою?
Агрегатные функции MIN и MAX Найдите самых старших членов семьи (используйте поле birthday) среди всех существующих семей на основании их статуса (поле status). Выведите статус и дату рождения. Для вывода даты рождения используйте псевдоним birthday.
Пишу: SELECT status, birthday FROM FamilyMembers GROUP BY status HAVING MIN(birthday) Говорят, неправильно. Но по логике-то верно же? Мы берём status и birthday из таблицы FamilyMembers, группируем их по полю status, в каждой группировке определяем наименьшее значение и выводим. Но нифига - "нонагрегатед колумн birthday". Как правильно?
>>1862258 Спасибо. У меня фактически так и есть. Объект подключения у каждой модели один и тот же, из контейнера. Я видимо с $dbh->beginTrancaction недопонял. Если я начинаю эту транзакцию, то получается все модели которые получат этот объект, даже из контейнера зависимости - получат объект $dbh в состоянии транзакции, я чет об этом не подумал.
Потому что слева у элементов списка есть паддинг. Тебе надо не в Гугл лезть, а открыть инструменты разработчика в браузере и изучить свойства элементов списка.
HAVING - это условие отбора строк (как WHERE, только оно применяется после группировки). Там можно написать что-то вроде HAVING MIN(x) = 5 а писать HAVING MIN(x) без условия просто некорректно.
>>1863631 ты сам убирал этот паддинг? или ты думаешь я совсем дегенерат? иди попробуй убери паддинг от лефта а потом открой инструменты разработчика в браузере и изучи свойства элементов списка
Слушай, моделей и репозиториев получается много ведь. И все равно их всех в контейнер зависимостей слима? Хотя в этом контейнере объекты создаются только при вызове, что удобно.
Я просто чет уже столкнулся с тем что если связность высокая - то тяжело рефакторить код. А в моей организаци я факультативно пишу приложуху, и требования меняются /дополняются на ходу. И уже столкнулся с тем что неудобно рефакторить и все такое.
Возможно, там паддинг/маргин у самого списка (родителя), а не у его элементов. Можно пройти в инспекторе от элемента списка вверх по элементам и посмотреть, какие у них маргины/паддинги, они даже цветом подсвечиваются.
>>1863957 да, все, разобрался уже. я позицию выстраивал не у самих лишек а у самого блока юл, поэтому все по пизде шло. щас с трезвой головой все удалил, заново переписал и заебись стало. пиздец на такой хуйне спотыкнуться и втыкать 2-3 часа чтобы в итоге решить все за минуту. я в ахуе
Скалярные подзапросы Выведите количество полётов каждого пассажира, представленного в таблице Passenger. Список полётов находится в таблице Pass_in_trip. В качестве результата выведите количество полётов (используйте псевдоним count) и имя пассажира.
Я вообще не понимаю, какого синтаксиса от меня хотят. Как это вообще писать. Битый час перебирал методом научного ытка разные, ничего не подходит. Это ебанина какая-то, а не урок. Прямо классическое "нарисуйте сову". Какой вообще порядок написания ключевых слов? Вообще не понимаю.
Сумел только вот такое написать, вроде результат похож на правду, но запрос криво выглядит и его не засчитали. SELECT COUNT(*) AS count, (SELECT Passenger.name FROM Passenger WHERE Passenger.id = Pass_in_trip.passenger) AS name FROM Pass_in_trip GROUP BY passenger
>>1864239 Твой запрос выводит количество полетов летавших юзеров, а тебе нужно вывести количество полетов всех юзеров (некоторые из них не летали). SELECT name, (SELECT count(*) from Pass_in_trip where passenger=Passenger.id) as count from Passenger
>>1857612 Как-то видел как один чел на тайпскрипте писал. Вместо того чтобы заверстать один инпут и прописать ему событие он пиздошил целый интерфейс под этот компонент, потом класс для него, вся эта срань наследавалась хуй пойми откуда и хуй пойми как работала, и в завершение делал он это прямо на проде. Между прочим это был довольно активный и известный стриминговый ресурс. Вот теперь даже не знаю - то ли на фронтенде такие говнокодеры, то ли только на тайпскрипте. Проганье ради проганья не нужно.
Вообще, тут тебе хорошо бы поучиться использовать джойны.
> Какой вообще порядок написания ключевых слов? Вообще не понимаю.
Сначала строки выбираются из таблицы (FROM), затем джойнятся (JOIN), затем отсеиваются (WHERE), затем группируются (GROUP BY), отсеиваются дополнительно (HAVING), сортируются (ORDER BY). Примерно в таком порядке выполняются запросы. Тебе остается лишь подобрать условия, чтобы получилось то, что требуется.
>>1864239 Разбираюсь с задачей просацт со списком студентов.
Как правильно обрабатывать ситуацию когда передаётся несколько параметров через get в сервер? Сейчас сделал, чтобы весь _GET копировался в рабочий массив, потом передаю его в нужную функцию. А в самой функции уже смотрю, если в массиве есть ключ с необходимым названием, использовать значение по этому ключу, иначе использовать некое свое значение. Второй вопрос, в пыхе можно сделать, что если некий аргумент не передается вообще, то функция может брать его значение по умолчанию. Можно ли сделать явное указание при передаче функции чтобы она использовала значение по умолчанию? Типо function foo($a=1) {} foo( is_null($b) ? {По-умолчанию} : $b ) {}
Гугл говорит что так нельзя, но это не точно. А если так нельзя, то как подобное обрабатывать? Уместно ли сделать внутри функции условие if, типо если передаю null как аргумент то использовать $a=1?
>>1864589 >А в самой функции уже смотрю, если в массиве есть ключ с необходимым названием, использовать значение по этому ключу, иначе использовать некое свое значение. Оберни это в класс, будет удобней. Psr\Http\Message\ServerRequestInterface Можешь глянуть этот интерфейс, мб там описаны нужные методы. Можешь сделать по подобию
>Второй вопрос >function foo($a=1) {} Ну, так и можно или что ты имеешь ввиду?
>А если так нельзя, то как подобное обрабатывать? Уместно ли сделать внутри функции условие if, типо если передаю null как аргумент то использовать $a=1? В том примере что ты привел - так function foo($a=1) {}. Еfunction foo(int $a = 1, int $b = 2){} В таком случае ты обязан передать в $a инт значение иначе кинет фаталэрор
Ты, по моему, нарушаешь разделение ответственности. В MVC модель не работает с пришедшими из браузера параметрами вроде $_GET. Это задача контроллера.
Ты можешь сделать, чтобы функция поиска студентов принимала массив условий, но тогда в нее надо передавать чистый массив только с разрешенными значениями, а не свалку произвольных параметров, приходящих в GET.
То есть, допустимы оба варианта:
findStudents(array $criteria) findStudents(string $query, string $sort, int $offset, int $limit)
Второй вариант выглядит почище и логичнее. Тут видно, какие аргументы есть у функции. Первый поуродливее, напоминает массиво-ориентированное программирование, когда везде передаются какие-то массивы и ничего понять нельзя. Непонятно, зачем так делать. То, что тебе в GET приходит массив параметров, не значит, что надо остальной код под него подстраивать.
В любом случае, нельзя писать findStudents($_GET). В функцию надо передавать корректные значения, а не свалку параметров из $_GET. Ведь в $_GET могут отсутствовать или присутствовать вообще любые значения. Это просто свалка из пришедших данных.
Правильнее в контроллере разобрать $_GET, сформировать на его основе условия для поиска и передавать уже в функцию поиска.
>>1864694 Я хочу объявить функцию с входным аргументом А, который по умолчанию равен 1. Т.е. если я вызову функцию без аргумента, функция будет выполняться со значением А=1. А если вызову функцию с входным параметром, то А будет равен этому значению на входе, так? Мне интересно, можно ли прямо в вызове функции вместо аргумента вставить условие. Примерно так
foo( B==2? : 1); Т.е. если В равен 2 то функция foo выполнится без входного аргумента (будет использоваться значение входного аргумента по умолчанию) , а если В не равен 2, то на вход функции дадим 1, т.е. уже значение не по умолчанию. Наверное зерово разъясняю, но как получается.
>>1864708 Я только разбираюсь с mvc. Чтобы не вытворять велосипед, я нашел простую реализацию на гитхабе. Суть там такая, что все входные вызовы обрабатывает функция-роутер. Она парсит url, и выделяет в нем имя необходимого контроллера, метод который надо выполнить из класса соответствующего контроллера, Параметр который передается в вызываемый метод. Т.е. у меня создается контроллер отвечающий за Вывод таблицы студентов на экране. Внутри контроллера вызывается соответствующий метод для отрисовки экрана (include кусков html с небольшими вставками php, функция из модели которая выполняет запрос к бд и возвращает ответ от нее) Все работает хорошо, когда у меня в url три параметра (имя контроллера/имя метода/параметр). Мне сложно понять как обрабатывать когда параметр не один а произвольное количество. Либо мне надо забить на произвольное количество параметров, и напридумывать методы в классе контроллера под всевозможные случаи (например отдельные методы для отображения таблицы под разные условия сортировки) Сейчас у меня передается весь массив GET в контроллер, где я ищу в нем конкретные названиями параметров, которые могу передать к функции из модели и передаю. Но я не уверен, что это выглядят не рукожопно.
> Все работает хорошо, когда у меня в url три параметра (имя контроллера/имя метода/параметр).
Как видишь, эта схема не очень удачная и не подходит в данном случае. Ведь бывают URL без параметров, бывает с кучей параметров.
В студентах роутов мало, их можно вообще проверять через preg_match регуляркой (if ... elseif ... elseif ... else).
Если роут соответствует реглярке1, то ... Иначе если он соответствует регулярке2, то ... Иначе выдать ошибку 404
Это один вариант. Тогда можно будет сделать URL вида /students/name/2?query=иван
Также, параметры можно передавать после знака вопроса, например /list/?query=иван&sort=-score&page=2. То есть тут URL состоит из названия контроллера и кучи параметров.
> Мне интересно, можно ли прямо в вызове функции вместо аргумента вставить условие.
Нельзя. Только если писать явно значения, вроде foo($x == 1? $a : $b);
Анон, а на сколько реально сейчас вообще заработать копеечку на начальном этапе, изучив и закрепив на практике верстку? Или нахуй это вообще не стоит потраченного времени и лучше сразу идти дальше js изучать?
>>1864323 Спасибо. >>1864557 >Вообще, тут тебе хорошо бы поучиться использовать джойны. Задача не на джойны же. Это НАДО сделать с помощью вложенных запросов.
>>1865018 В твоем запросе как минимум два косяка. Ну с такими задачами и самообучением хули удивляться. 1) Подзапрос в SELECT части выполняется по разу на каждую строку. Так делать нельзя никогда, даже если очень хочется. Тем более что всегда есть нормальный способ.
2) В COUNT(*) всегда считай конкретные вещи, в твоем случае ты считаешь количество пассажиров, значит так и пиши COUNT(passenger).
По итогу твой запрос будет состоять из двух частей: Получение всех пассажиров и получение количества полетов для летавших, это и будет подзапрос. И объединяются эти части именно джойном.
SELECT flights_count.count, p.name FROM passenger AS p LEFT JOIN ( SELECT passenger, COUNT(passenger) AS count FROM pass_in_trip GROUP BY passenger ) AS flights_count ON flights_count.passenger = p.id
Теперь у тех кто не летал в колонке count будет NULL. Как превратить NULL в 0 тебе факультативное задание.
>>1865068 Ещё раз: это учебная задача из радела на вложенные запросы. Поэтому по условию задачи, её надо выполнить именно через вложенные запросы и никак иначе. Именно поэтому система отмечает твой монструозный запрос, как неверный, а лаконичный >>1864323, как верный.
>>1865097 Во первых "система" всего-лишь проверяет конечную таблицу. Никто в здравом уме не будет парсить сам запрос и тем более искать в нем подзапросы. Само написание такой системы равноценно созданию своей БД.
Во вторых это типичный запрос в базу, простой как два рубля и ничего монструозного в нем нет. К тому же вложенный запрос в нём присутствует.
В третьих без относитьльно "учебности" задачи. Подзапрос в SELECT части это профнепригодность с первой секунды. Это просто перечеркивает все твои дальнейшие усилия.
В это вся беда дистанционного обучения, машине насрать что ты там написал, она просто проверяет результат. А человека, который скажет что ты катишь квадратное рядом нет.
>>1865104 >Подзапрос в SELECT части это профнепригодность с первой секунды. А авторы учебног курса считают иначе. Вот и кому верить: им, или анону с двача?
>>1865112 С чего ты взял что они считают иначе? Ты где-то в самой статье прочитал что так надо делать? Ну зайди к "авторам" в группу в ВК и спроси там, тебе то же самое скажут.
Если ты пишешь подзапрос в SELECT части, то подзапрос выполнится по разу на каждую строку результата исходного запроса. По сути ты превращаешь один запрос в тридцать.
Это даже не "детская" ошибка, это как если бы тебя попросили проехать на велосепеде десять метров, а ты перевернул его колесами к верху, залез на него и пропрыгал в нужное место. Формально ты справился, но велосипедистом ты от этого не станешь.
>>1865115 Ну не драматизируй прям. Подзапрос в select это конечно не правильно, однако человек все таки пишет запросы, просто не до конца понимает порядок выполнения.
>>1864822 >Наверное зерово разъясняю, но как получается. Нормально разьясняешь, просто в этом нет смысла
>Мне сложно понять как обрабатывать когда параметр не один а произвольное количество. Либо мне надо забить на произвольное количество параметров, и напридумывать методы в классе контроллера под всевозможные случаи (например отдельные методы для отображения таблицы под разные условия сортировки)
Ты не правильно суть роутера понял. По хорошему оно должно работать так: Делаешь себе файл который возвращает конфигурацию твоих роутов. У каждого роута пусть будет контроллер и метод.
Создай класс роутер который парсит этот конфиг и запускает тот контроллер который тебе нужен. Еще желательно создать что то вроде класса Request, который будет содержать в себе все get и post параметры. И методы которыми ты их легко можешь получить. Это значительно тебе задачу упростит. Ты просто в контроллер будешь передавать этот Request и например методом $request->get('page'), получать параметр страницы гет запроса. То как ты писал выше - чем то похоже на роутинг в Yii, где название контроллера это одна часть урла, название метода - другая. А параметр в твоем случае это например $id студента. т.е ссылка в твоем случае такая /students/show/55. Этот же параметр можно передать в ГЕТ запросе /students/show?id=55.
Почитай про get, post запросы и как они на сервер приходят. Ощущение что ты просто этого не понимаешь.
П.С абу пидорас, нахуя он ебучую кнопку стикеров в поле ввода добавил, не виднно же нихуя что ты там пишешь с новой строки
> Подзапрос в SELECT части выполняется по разу на каждую строку.
Справедливости ради, это не обязательно так. Оптимизатор СУБД может переписать такой запрос на аналогичный запросу с джойнами (так, что он будет выполняться аналогично). Сама идея SQL в том, что ты только описываешь, что хочешь получить, а не как и в какой последовательности выполнять запрос.
В каждом случае надо смотреть вывод EXPLAIN, чтобы понять, будут проблемы с выполнением подзапроса или нет.
Там видно, что планы выполнения запросов с подзапросом и джойнами по сути одинаковы. Он будет обходить первую таблицу и для каждой строки делать поиск по индексу во второй таблице. В обоих случаях делается почти одно и то же.
Если тебе не лень, ты можешь у себя создать таблицы с большим числом записей (10 000 - 100 000) и померять время выполнения. По моим прикидкам, оно должно быть примерно одинаковыми для джойна и подзапросов.
Аноны, вопросец такой. Есть action='/mysite/aticles/1' формы с post запросом. Форма допустим обновляет статью за номером 1 вбазе. Я же в браузере , в html разметке могу руками поменять на /mysite/aticles/2? И соответственно если да, то данные обновятся на сервере для статьи 2, так ведь? Как таког избежать, делать в разметке какой то уникальный токен, на сервере его сохранять в базу для каждой формы, и проверять его?
Да, оптимизатор может соптимизировать твой говнозапрос и ты будешь ферзь. А может ухудшить. Учиться нужно чтобы самому понимать что работает быстро, а что медленно. Тем более что ничего сложного в этом нет. Уровень математики за третий класс. Получить один набор данных быстрее чем тридцать, объединить два набора данных быстрее чем пятьдесят. Обычная бытовая логика. А когда начнешь мыслить реляциями и наборами данных так вообще попрет изи.
Но писать хуйню, в надежде что оптимизатор переведет её в нормальный код это залупа полная.
Правильнее всего на сервере проверять права: имеет ли данный пользователь право редактировать данную статью. Также, можно использовать и проверять токен в URL (/articles/1/abcdefghi) но это более корявое решение.
>>1849138 приветствую. Что можешь по поводу в бека с нуля посоветовать для вката в течении полу-года +-. Стоит ли курс в шапке учить или что-то другое мб надо. Что нужно кроме пыхи (ларавэл) для бэка джуна? Как правильно хантить вакансии (ибо если просто писать back end, то выводит всё, что угодно, кроме самого бэка (или я не правильно представляю, чем бэк занимается?))
>>1865691 Проверять программно, если у авторизированого юзера есть возможность только себя менять, или наоборот - менять всех кроме себя. Должен ли не авторизированный пользователь иметь возможность менять данные? Если да, то почему он не может изменить данные с другим айдишником? И так далее
>Стоит ли курс в шапке Норм курс, можно местами пропускать. Например сделать студентов и потом сразу на ларавел/yii сесть
>(или я не правильно представляю, чем бэк занимается?)) Я когда пришел в контору меня уже продавали как мидла слабого. Чем занимаются джуны - хз. Джуну нужна норм база как в беке, так и в фронте. Поле там поправить какое нибудь, цвет кнопки может поменять - хз. На чисто бекенд вакансии планка выше всегда, я хз как вы туда попадете. Самый нормальный вариант - искать контору у себя в городе. Если это не говно-подвал, где на вордпрессы шаблоны натягивают - можно за пол года вырасти в мидла (на это и делают упор когда берут джуна)
>>1849078 (OP) не совсем понял слысла задачки про l33tspeak, это же тоже самое что и предыдущая про шифрование. Да и тот код что по ссылке работает. Или нужно все буквы перевести?
ОП, оцени что я тут накрутил по YodaSpeak. Пойдет? На мой личный взгляд, самая сложная задача, если сравнивать с предыдущими. Надо прям хорошо понимать как устроены массивы и функции для работы с ними.
>>1866159 А синьером 10+? Кто такой мидл, кто такой синьер? А если у меня год опыта, а работаю я на позиции мидла то что? Вселенная дала сбой? хуйню не неси
>>1865628 Я от этой трансляции приуныл. Пиздец как больно слышать о том, что разработка пыха сейчас так похожа на допиливание костылей к сайту на битриксе, а то и хуже. >Ну, самые лучшие практики по синтаксису в php никогда использоваться не будут, интерпретируемый язык всё таки, так уж парсер устроен >Путь пхп был предопределен еще 4000 лет назад, мы следуем в рамках этого пути >Чего в этой новой фиче такой синтаксис дэбильный? Ну это парсеру так удобней просто >Ну такого мы сделать не сможем, это ж придется всё ядро переписывать >Ну такое мы сделать можем, но это будет костыльно и замедлит работу в 20 раз
>>1866369 Трансляция не смотрел и на пыхе не пишу, но пыха с последними релизами приобретает более-менее адекватный вид даже арров функции добавили, охуеть!
>>1866159 >>Обычно, чтобы быть миддлом, нужно иметь опыт от 3 лет.
Думаю это около условная тема. Все зависит от человека, его дисциплины и способности себе задачи ставить. Сможешь самостоятельно херачить проекты , на заказ или для себя, дрочить теорию, и при этом писать много и постоянно - уже месяца через три имею ввиду что ты по факту уже уверенный джун на этот момент будешь около мидловым +/-. И с таким багажем втянешься в мидла в той конторе куда возьмут быстро.
Я по работе начал проектик один писать, по основной деятельности делать особо нехуй, а тут в довесок предложили проект , не спеша сделать, так еще и платят. Так я изначально одно наваландал. Щас хотелки заказчиков расширились - я уже перерефакторил, криво конечно. На слои разделил, как смог. Так как проект чисто мой, и с перспиктивой расширения - меня оч интересует его архитектурно запилить хоть как то удобоваримо. Но опять же лучший опыт - свои грабли. Поэтому писать нужно дохуя и много, и не ссать.
Не боги горшки обжигают по итогу. И я сомневаюсь чет что в какой то средней конторе с тобой будет ментор прям носиться. Будет условный прогер, которому совершенно не условно на тебя похуй - это максимум. А может попасться какой нибудь истеричный и инфантильный ебанат, который будет за твой счет себе самооценку поднимать. Так что один хуй будешь на самообучении в общем.
Это значит, что тебя называют миддлом, чтобы тебе было приятнее. А вообще, в разных конторах градации разные - сеньор из какой-то вебстудии может не потянуть в Яндексе даже на джуна.
Делаю посадочную на тильде, на странице нужно сделать СТА, пытаюсь шаблонами сделать - кнопка ходит по пизде, то большая, то маленькая Пытаюсь сделать кнопку через код, а текст, бэк и остальное в пикче, кнопка ходит отдельно от текста Пытаюсь сделать через код текст и под ним кнопку- работает либо текст либо кнопка
В програмировании вообще ни бум бум, нагуглил код на css - он вставляет либо кнопку либо текст, и то и то не дает сделать, как решить проблему и где ошибка?
А есть ли какая-нибудь информация, будут ли когда-то в PHP примитивы или как оно там называется, чтобы можно было сделать вот так?: $a = "foobar"; $b = $a->trim()->toUpper() А то сейчас очень отвратный дизайн, когда скобки в скобках в скобках в скобках
Салам алейкум, пыхеры. У меня есть приложка на symfony, и еще 2 микросервиса в придачу. Все они пишут логи в файлы в папке ./var/log/prod. Вопрос: Как мне лучше собирать логи в одно место, чтобы с веб морды все просматривать?
На текущей момент в моей голове плавает следующие мысли: 1. Graylog(но мне кажется уж слишком чересчур для трех файлов логов) 2. Самописный скрипт, который распарсит файлы и выведет в вебморду, а на js через регулярку подсветку(INFO, WARN, ERROR, etc..) 3. Какой-то открытый проект(о котором я еще не знаю), который подойдет под мои масштабы бедствия
>>1866921 Ну ты и жопочтец, конечно. Подзапросы в SELECT это плохо. Что по твоему происходит когда ты пишешь SELECT LENGTH(name) ? Для каждой строки результата выполняется функция LENGTH(). Точно так же для каждой строки результата выполнится подзапрос.
В WHERE подзапрос выполниться один раз, чтобы сформировать условие. А потом уже готовое условие будет использовано для выборки.
В итоге: в WHERE мы формируем запрос, который потом выполнится один раз. В SELECT мы модифицируем результат запроса, и делаем это по разу для каждой строки.
>>1867014 Что значит как собрать? Просто пиши логи не в файлы, а в общее хранилище. Чаще всего этим общим хранилищем выбирают Elastic. Graylog, например, использует именно его для хранения логов. Но хранить можно хоть в мускуле, просто для эластика уже есть куча готовых способов логи визулизировать, как ты написал "веб морд".
Так что тут все зависит от твоей лени и доступных ресурсов. Если лень что-то писать, но есть куда ставить Elastic, а он прожорливый, то накатываешь его плюс любую веб морду по вкусу, кибану например. Если хочется дешево и сердито, то кидаешь логи в обычную реляционную базу, пишешь на пхп форму поиска по логам и в бороду не дуешь.
Опцинально можно заморочиться с очередью, чтобы писать логи асинхронно и не падать если хранилище логов прилегло, но с твоими масштабами это вряд ли нужно.
>>1867300 Пока лучше 7.3-7.4 (версию где ввели строгую типизацию у переменных классов) они самые актуальные и 8 обратно совместима с ними. У нас некоторые проекты на 7.1 ещё сидят. И один Легаси на 5, но скоро с нуля будем его переписывать. Новые в 7.4 делаем. В проде 8 будет появляться только через годик-полтора.
>>1866622 Короче, вы мне не ответили, нашел статью от Никиты Попова по этому поводу http://nikic.github.io/2014/03/14/Methods-on-primitive-types-in-PHP.html Конечно охуеть, статья в 2014 написана, на тот момент он уже выкатил рабочий пример и написал что желает увидеть эту фичу в шестой версии, но пока что ему лень ее доводить до ума. Уже 2021, что за херня? Может они там у себя в шестую версию добавили, а в седьмую забыли?
Аноны, есть МООС-курсы на пхп по типу Фрикодкэмп для ЖСа, хиперскила для джавы и юлерна для шарпа? Автотестики, короткие видео, небольшие лекции в текстовом формате - вот это вот все?
Уважаемые аноны, тупой, но не унывающий в треде. Подскажите, пожалуйста, подойдет ли мне такая конфигурация сервера на первый месяц для видео хостинга с короткими видео 1-3 минуты. Пик онлайна планирую ~1000 человек (с трафиком я дружу)
Сайт сделан на laravel и я так понимаю мне нужно будет поставить библиотеку ffmpeg чтобы уменьшать битрейт у видео и меньше нагружать канал. Если не сложно, то подскажите как лучше уменьшить видео без потери качества. Поправьте, пожалуйста, если вопрос задан не корректно.я же тупой
>>1867825 >Intel® Xeon® E-2146G 6x3.50 GHz (до 4.50 GHz Turbo Boost) / 12 Threads >Сайт сделан на laravel Ларавель монолитный если чё >мне нужно будет поставить библиотеку ffmpeg чтобы уменьшать битрейт у видео и меньше нагружать канал Нужно просто пережать существующие\уплоадеющиеся юзерами видео?
>>1867848 Архитектурно сложнее реализовать весь потенциал процессора, если всрато написано - вбухивая больше бабла перформанс не улучшить Монолит нужно грамотно кластерить, шерить базы данных и лоад балансить плюс более громоздкие хендл нон-блокинг ио и прослойка под сервисы С дивана советую начинать выносить сервисы в отдельные микросервисы, как раз начиная с этого ffmpeg конвертатора (может и весь уплоад эндпоинт)
>>1868039 Ну это целая continuous delivery задача для девопса-программиста, который будет код ревьювить, тестировать, разворачивать и профилировать Гадая на кофейной гуще: если написано всрато - никакие 6 кор не помогут, если спроектированно и написано заебись - может хватить и меньше, но хз
По моему, ты написал ерунду. По моему, ты плохо разбираешься в архитектуре.
Ты ошибаешься, думая, что "монолитное" приложение не может использовать несколько ядер процессора. Наоборот, оно прекрасно масштабируется на них из коробки - просто создается нужное число PHP-FPM процессов.
БД также масштабируется из коробки, так как MySQL обрабатывает каждое соединение в отдельном треде.
Для сайта с 1000 посетителей этого вполне достаточно.
> С дивана советую начинать выносить сервисы в отдельные микросервисы, как раз начиная с этого ffmpeg конвертатора (может и весь уплоад эндпоинт)
Ты, по моему, где-то краем уха услышал миф, что "микросервисы масштабируются, а монолит нет" и бездумно его повторяешь. Какая разница между 2 микросервисами и 2 копиями монолита? Никакой, только с микросервисами архитектура бессмысленно усложняется на ровном месте, нужно возиться с докерами, больше памяти все это ест, больше накладных расходов на передачу данных, сложно читать логи, сложно отлаживать, надо синхронно выкладывать релизы нескольких микросервисов.
Микросервисы повысят затраты рабочего времени и стоимость разработки и поддержки.
Вдобавок, вряд ли у него загрузка видео идет в огромных масштабах. На сайтах с видео, как правило, тех, кто смотрит намного больше, чем тех, кто загружает файлы.
В пользу микросервисов можно сказать, что они позволяют масштабировать БД, если каждый сервис использует свою БД. Но твое предложение - вынести аплоадер отдельно - не позволяет ему использовать свою независимую БД и получить какие-то преимущества. Более того, в монолитном приложении никто не запрещает сделать несколько БД и использовать их.
У монолита огромное число плюсов. Разбиением на микросервисы обычно занимаются в двух случаях:
- если очень большая команда, и очень огромные объемы кода, и хочется приложение разбить на меньшие части - что тут неверно, автор один - если неопытным разработчикам, наслушавшись выступлений на конференции, хочется поиграться в Гугл (в убыток работодателю)
Автору в данном случае с его микроприложением разбивать на части просто нечего. Разбивать можно от объемов в десятки человеколет.
Вообще, с этими микросервисами какое-то помешательство творится.
>>1868021 >>1868125 Блять, и как вообще нормально вкатываться в этот ваш айти, если даже по таким базовым вопросам можно услышать настолько разные ответы? мимо
>>1868125 Про немасштабируемость монолитов наверное я и вправду написал куйню Но фсные операции с видео я бы всё равно вынес в отдельный сервис, оборачивающий какой-нибудь гринтредовый бинарник, или дописал бы этот гринтредовый бинарник в отдельный эндпоинт и форвардил запрос туда
>>1868125 > Никакой, только с микросервисами архитектура бессмысленно усложняется на ровном месте, нужно возиться с докерами В случае видео или фото проблема актуальна, чтобы как-то балансировать нагрузку.
Самая грамотная архитектура в данном случае это один или несколько воркеров, которым ты в очередь кладёшь задание "перепаковать что-то", и из другой очереди, например, получаешь ответ.
Иначе тебе сложно будет бороться с ситуациями, когда одновременно много фото-видео вдруг стали перепаковывать. У тебя просто ляжет твой сервер.
Не скажу про PHP, он синхронный и там в принципе сложнее. Может там необходимо уже делать микросервис для этого.
В любом случае это микросервисное проектирование. На питоне, например, тебе не обязательно именно в отдельный сервис всё выносить, ты можешь делать конвертацию в отдельной asyncio-задаче, или в отдельном треде (внешние либы и процессоры не блокируют GIL питона), давать задание через штатную очередь.
То есть поднимать отдельный сервис для перепаковки, очередь сообщений и т.п. не нужно. Вроде бы у тебя один процесс, а реально микросервисный подход, при желании быстро в полноценный микросервис переносится.
>>1867825 В твоём случае выносить перепаковку видео в отдельный микросервис необходимо просто.
Ставить брокер очередей-сообщений не обязательно, для твоей задачи можно в качестве очереди использовать БД, это такой типовой подход.
Пользователь загрузил видео, оно копируется в какой-то каталог. В БД в специальную таблицу вносится запись имя файла такое-то, пользователь такой-то, статус "не обработано".
Другой процесс, когда свободен, опрашивает БД, берёт запись оттуда, запускает процесс перекодирования. Как закончит, заносит в БД статус "перекодировано", имя нового файла-размер. После чего принимается за следующее видео.
Более правильный подход это полноценные очереди делать (вроде RabbitMQ), но иногда лучше проще, чем энтерпрайзно.
Главное, для чего это нужно, это чтобы балансировать нагрузку, иначе у тебя очень быстро сервер ляжет.
В данном случае ты больше ограничен трафиком, чем процессором. Хотя смотря что у тебя пользователи делают.
Если ролик в среднем 15Мб, то это всего 1 миллион просмотров.
Вопрос по DI-контейнерам. Может кто нибудь объяснить как работать с зависимостями в проекте, через контейнер, если реализации сильно вариативны. То есть например есть некий класс документа с большим количеством бизнес-правил и для его заполнения используются разные наборы сервисов/серчеров/репозиториев, которые подтягиваются через фабрики и стратегии. Как в таком кейсе правильнее использовать контейнер?
>>1868162 >>Блять, и как вообще нормально вкатываться в этот ваш айти, Ойти ныне - для смелых. Это со стороны какжется что крутые парни выбирают идеальные решения. ИРЛ все пишут как могут, а холивары бесконечны. Есть некая средняя планка качества которой нужно соответствовать, и то условно. Не мало успешных проектов какторые написаны через сраку, антипаттерн на антипаттерне. И их владельцам поебать чет там камьюнити кукарекает - они бабки поднимают. Как войти - ебашь свои проекты, количество перерастет в качество.
>>1868421 Есть, анон выше же написал, что проект как минимум поспавнит php-fpm процессы + фреймворкные воркеры на нон-блок таски Но имхо в пыхе нон-блок тасков лучше избегать и вынести вычисления (конвертация видео в этом случае) за пределы вебаппной логики
>>1868421 Нужно, чем больше, тем лучше. 1) Ты запускаешь много php-воркеров в любом случае. 2) При плохой архитектуре у тебя может работать много ffmpeg процессов одновременно. 3) ffmpeg для перекодирования использует много тредов, по числу ядер, там скорее надо вручную лимитировать через опцию -threads.
Архитектурно, мне кажется, здесь лучше запуск ffmpeg вынести в отдельный процесс, чтобы он по очереди перекодировал видео, а задания брал из какой-то очереди, может самодельной на базе БД или кеша какого-нибудь.
Закончил вуз по профильной специальности. Что-то кодил на крестах, Матлабе и прочем разном. Параллельно 1С программистом 3 года уже проработал, так как хотел деньги, а там порог входа был невысокий и платили уже много, дали совмещать с учёбой.
Счас закончил учёбу полностью (магистратура) и хочу в бекенд на полный рабочий день.
Но, блдеать, почему везде написано от 1 года опыта во всех вакансиях ? Тот факт, что я 1Сной разработкой занимался или на других ЯП какие-то штуки пердолил в рамках универских задач и вообще - их не ебёт ? Этот год опыта должен быть именно пхп-программистом или что имеется ввиду, когда в вакансиях вроде требования низкие, но всё равно год опыта пишут ?
>>1868645 С твоим бэкграундом тебе вкатиться как нехуй делать, не ссы. Прикинь, что было, если бы все писали "без опыта"? Они бы ахуели от толпы Петровичей, которые решил стать пахрамистами. Подтяни знания по стеку и вперёд.
Для работы с очередями не требуется микросервисов. Один и тот же монолит может как класть задачи в очередь (на основе БД), так и брать их и выполнять. При этом при необходимости можно этот монолит запускать на нескольких серверах и масштабировать хоть до бесконечности.
>>1868714 >Для работы с очередями не требуется микросервисов. Один и тот же монолит может как класть задачи в очередь (на основе БД), так и брать их и выполнять. Архитектурно это фактически и есть микросервис, просто без физического выделения.
Потому что выделяется отдельный сервисный процесс, который делает какую-то работу по заданию.
Причём я не очень понимаю, как это реализовать на PHP, когда работает много php-fpm процессов. Ведь потребность перекодировать может у любого возникнуть, причём одновременно.
>>1868679 Личные качества: решительность, упорность, дисциплинированность гораздо важнее чем какой угодно скилл. И гораздо тяжелее достигаются. Не ссы и пиздуй на собес.
Корона — дерзновенному, скипетр — смельчакам! Трон — тому, кто говорит: Возьму и не отдам. «Черта с два! — вскричал барон, прочь отбросив шлем, — Хладное железо властвует над всем!
Это не микросервис. Микросервис - это отдельное приложение с отдельным кодом и зачастую отдельным хранилищем (БД).
Вот, кстати, еще одна проблема с микросервисами: дублирование кода. Допустим, есть класс User, и его надо использовать в нескольких микросервисах. Причем в одном он еще проецируется на БД. Либо ты копипастишь и дублируешь код, либо ты пытаешься выносить это в библиотеку и получаешь отдельный набор проблем.
>>1868946 Анон сверху заигрался и ларавельные воркеры и вправду сложно назвать и сервисами, не говоря уже о микросервисе В чём твоя проблема поймать запрос на операцию с видео монолитом, прокрутить мидалварями чек сессии с пермишеннами и редиректнуть на микросервис, не имеющий представления о юзвере и выполняющий только выделенную операцию (о логике которой, в свою очередь, монолит не обязан знать за пределами роутов веб апи) будучи подключенным к тому же мускельному пулу, если надо
Мне кажется, регулярку для разбиения текста лучше было написать так:
- до текущей позиции знак препинания - после текущей позиции не знак препинания
То есть использовать не только look back assertion, но и look ahead.
> $wordsArray Лучше писать просто $words
> [А-Я][а-я] Надо писать [a-яё], так как ё в Юникоде не входит в диапазон а-я.
Сам код немного переусложнен. Вот как можно сделать чуть короче:
- сразу удалить запятые и все лишнее - разбить текст на массив предложений - каждое предложение разбить на слова, переставить их местами и склеить обратно - сделать первую букву заглавной - склеить предложения через точку
Ты же собираешь слова из разных предложений в общий массив, что затрудняет потом расстановку точек.
Также, достаточно использовать один цикл по предложениям.
Я написал, что утверждение "подзапрос всегда менее эффективен, чем джойн" неверно и все зависит от работы оптимизатора БД. Ну да, MariaDB не смогла оптимизировать, может какая-то другая СУБД сможет. Хотя планы выполнения запросов были похожи.
Ну и иногда такие запросы допустимы, если ты например руками его в консоли пишешь и тебе пофиг, что он будет дольше работать.
Уже выше писал же, в чем проблема микросервисов: архитектура с микросервисами усложняется на ровном месте, трудно разбираться в коде, трудно отлаживать, надо собирать логи, надо заводить докеры и сложные конфигурации. Сложно разделять код, в твоем примере объект видео и все, что вокруг него, должен разделяться между основным сервисом и вспомогательным.
В итоге, непонятно, ради чего такая сложность, если монолит делается без вышеперечисленных проблем и делает то же самое. Ты точно также с монолитом можешь организовать очередь и сделать воркера (часть монолита), который будет брать задачи из очереди и в фоновом режиме работать.
Если тебе захочется шардить БД, ты точно также можешь использовать монолит и коннектиться к нескольким разным БД. То есть с монолитом ты можешь иметь то же масштабирование, что и с микросервисами, но без кучи архитектурных проблем и без докера.
Единственная проблема монолита - негативное отношение спикеров на конференциях. Что можно пережить.
Если написанное выше сложно и запутанно, то могу выразить мысль короче:
Для вашего (не-гугла) проекта монолит - идеальное решение в сравнении с микросервисами. Все, кто предлагает его разбить на микросервисы, просто занимаются вредительством и нанесением убытка.
>>1869013 Ты охуенно переливаешь из пустого в порожнее. При этом еще и выдумал какое-то свое определение микросервисов. Я примерно представляю себе структуру простейшего видеохостинга, я её опишу и некоторые требования к ней, а ты нам конкретно расскажи как это сделать по твоему.
Итак видеохостинг. У нас есть железный сервер 8 ядер, 32гб оперативы, на 1К пользователей с запасом. На этом железе нужно разместить следующее: 1) Сайт, на который собственно заходят пользователи. 2) Админку, администрация должна иметь возможность управлять содержимым. 3) Реляционную базу, допустим MySql. 4) Memcached для реляционной базы. 5) CDN сервер, собственно с видео. 6) Elastic для поиска. 7) Несколько воркеров, которые перекодируют пользовательские видео.
Теперь требования к работе всего этого добра: 1) Сайт и админка должны работать стабильно всегда. Если не работает, то минус конверсия, или проще минус бабки. 2) Memcached не должен падать если упал любой другой сервис. Упал мемкеш -> все что было в оперативе по пизде -> нагрузка на базу -> сайт не работает -> смотри пункт первый. 3) CDN не должен жрать весь канал, мы не только видео отдаем. Опять смотри пункт первый. 4) У воркеров должно быть максимум доступных ресурсов, но не все, опять пункт первый.
Монолит, хуелит. Расскажи как ты будешь такое реализовывать, с соблюдением требований конечно. Требования типичные, не только к видеохостингу относятся, а к 99% сайтов.
Аноны, кто знает как работает автовайринг в ларавел, или допустим в slim с контейнером php-di? То как разрешаются зависимости для сервиса в контейнере - понятно. Я щас просто хочу переехать в своем приложении со слим 3 на четвертую версию. А там много где используется автовайринг, причем классы которые разрешаются в кострукторе класса на пример в доменном слое - не являются зависимостями которые определены в контейнере. Типа такого:
Сервис доменного соля
ServiceClass{ //Объект Class1 не находится контейнером, но как то разрешается все равно. В ларавел это в принципе стандартная тема. __construct( Class1 $class1 ){...}
>>1868958 Кладутся все варианиты постороения цепочек? Или просто некий дефолтный вариант, а остальные вариации сетаются уже на app уровне? Либо вообще делать все зависимости nullable и в контейнере складывать только сами экземпляры, как я видел в одном старом проекте, но какой же это тогда DI...
>>1869143 То есть для примера, есть класс Document, у него есть несколько фабрик, которые выбираются исходя из данных в запросе, соответсвенно у каждой фабрики своя генерация полей документа, которые в свою очередь подтягиваются из разных репозиториев через свои сервисные классы. Тупа перечислить все варианты в контейнере не выйдет. Вот я и пытаюсь понять, как в таком кейсе было бы правильно использовать контейнер.
Програмно можно получить список зависимостей у конструктора с типом зависимости по тайпхинту, и так рекурсивно до конца, а потом создать его. Офк если переменная просто int $a то контейнер не узнает что за инт ей нужен
>>1866312 А можно пожалуйста критерии мидлов, синьеров и всех из них вытекающих? Уже ни раз обсуждали и разжевывали вам эту тему
>>1866451 > сеньор из какой-то вебстудии может не потянуть в Яндексе даже на джуна
Я такое вижу, мне вас реально жаль становится. Мидл, синьер и прочее - это по сути вилка зп и ответственность которую ты на себя берешь за эту зп. А то, как это называется и какой у тебя опыт - ебет кого? Чтобы получать мидловскую зп тебе не нужно 3года опыта, как высрал чел сверху. И эти же 3года опыта совсем даже не дают тебе гарантий что ты эту мидловскую зп будешь получать. И мидловская зп это не "макако-конторная", а средняя по рынку
И если я не ошибаюсь в яндексе на пхп не пишут, так что такие мидлы и синьеры нахуй им не сдались (собственно как и сам яндекс нахуй не сдался этим мидлам/синьерам)
>>1869280 а если меня не интересует ни лёгкость вката, ни поиск работы тип работа есть не айти зарабатываю норм, себя по крайней мере без напряга содержу есть маня идея для проекта какую технологию выбрать чтоб она была быстрая, масштабируемая?
>>1868645 >Но, блдеать, почему везде написано от 1 года опыта во всех вакансиях ?
Потому что забей на это хуй и просто иди на собес. То что там про опыт где то в вакансии указано - очень часто с действительностью никакого отношения не имеет, разве что в самой вакансии могут написать что то вроде Требования: -От одного года коммерческой разработки на фреймворк/язык нейм -и т.д
>>1869165 Да я как то тупопездно спросил, выстрел в небо. Понятно что рефлексией. Сама логика реализации. Одно дело когда зависимость вызываемая из контейнера требует для самой себя зависимости из контейнера. Все это выполняется внутри условного метода resolve - и понятно что контейнер найдет нужный класс.
А вот когда какой нибудь сервис автовайром тянет зависимость которой нет в контейнере - как вообще в этом случае участвует контейнер? Каким образом он доступен и видит что нужно резолвить эту зависимость. Контейнер это обертка над всем приложением, или где то там контейнер вызывается и его методы срабатывают при вызове зависимости сервиса. Короче это только код смотреть. Тупой мой вопрос был.
>>1869147 я мимо шел. Щас с этой темой так же пердолюсь.
Есть приложуха на slim3, щас буду на slim 4 переезжать. В нем все несколько иначе. В slim3 судя по гайдам был DI в виде антипатеррна - сервис-локатор. Потому что контейнер передавался в конструктор контроллера. Соответственно необходимые зависимости контроллера скрывались. В slim4 нет встроенного контейнера, но по гайдам самый частый вариант -php-di. Он гораздо богаче pimple из slim3. Я к чему - php-di - при инициализации в нем можно создать набор зависимостей, этот набор так же попадет в экшен-контроллер или метод контроллера как контейнер доступный из $this. Однако, судя по примерам, по ходу выполнения скрипта другие зависимости, допустим в неком сервисе какой нибудь репозиторий вызывается - все это делается посредством инъекции в мтод или конструктор. И php-di по тайпхинтам как то резолвит эти зависимости. Из чего такой вывод - если у а нас контейнер без автовайр, то те зависимсоти которые в slim4 автоматически разрешаются - должны быть определены в контейнере. Меня в таком случае это тоже смущает, так как в контейнере будет определено дохрена разных моделей, или репозиториев, всяких хелперов и прочего. Вероятно в каких то местах инъекции должны быть жесткие, без участия контейнера.
>>1869293 >почему везде написано от 1 года опыта во всех вакансиях Потому что в HH работодатель может выбрать только одну из опций, или "без опыта работы", или "от одного до трёх", или "от трёх до шести" ну и ещё другие.
И если он выберет "без опыта", то будет шквал совершенно никаких людей, которые хотят на месте чему-нибудь научиться. Этого вот даром не надо.
Поэтому все указывают от "одного до трёх", даже когда в теле вакансии написано, что можно без опыта.
Короче не надо обращать внимания. Когда действительно хотят опыт, тогда указывают "от трёх лет", что не значит, что с годом коммерческого опыта к ним соваться не надо.
Возможно, он действует так: когда ты запрашиваешь сервис с именем SomeClass, он находит этот класс и смотрит в конструктор. Если там в тайп-хинтах есть другие классы - то повторяет процедуру. Когда все зависимости удовлетворены, он создает все нужные объекты.
>>1869640 Тоже самое тащемто, мигрировал на слим 4 с 3го, тот же php-di. Единственное у меня раньше на проекте di вообще не использовалось почти, вот пытаюсь понять как правильно.
Как кстати решил проблему совместимости старых методов Request/Response, если пришлось?
Дороу, скоро мне 24, стоит ли вообще хоть пытаться вкатиться в программирование, сам имею диплом из шараги тип прогер, даже курсачи писал на пхп, но на чистом.
Не знаю, как сделать две задачи: https://sql-academy.org/ru/trainer/tasks/60 >Выведите идентификаторы преподавателей, которые хотя бы один раз за всё время преподавали в каждом из одиннадцатых классов. и https://sql-academy.org/ru/trainer/tasks/64 >Выведите имена всех пар пассажиров, летевших вместе на одном рейсе два или более раз, и количество таких совместных рейсов. В passengerName1 разместите имя пассажира с наименьшим идентификатором.
В первой сделал только общую таблицу всех уроков для всех 11-х классов SELECT * FROM Schedule INNER JOIN Class ON Schedule.class=Class.id WHERE name LIKE '11%'
Во второй вообще не понимаю, как это решать. Явно какие-то джойны.
>>1869812 И ещё https://sql-academy.org/ru/trainer/tasks/16 >Вывести отсортированный по количеству перелетов (по убыванию) список пассажиров, совершивших хотя бы 1 полет. Ответ SELECT name, COUNT(name) AS count FROM Passenger INNER JOIN Pass_in_trip ON Passenger.id=Pass_in_trip.passenger GROUP BY name ORDER BY count DESC не приняли. Видимо потому, что в таблице Pass_in_trip есть люди, которые купили несколько билетов на один рейс и этот запрос считает каждый билет отдельным вылетом. То есть, нужно снаала вытащить номера пассажиров, которые вообще летали SELECT DISTINCT passenger FROM Pass_in_trip А затем как-то поджойнить что-то. Не понимаю, что и как, ве запросы выводят либо херню, либо не работают вообще.
Меня уже реально подбешивает синтаксис SQL. Вместо Выполните Пуск->Панель управления->Администрирование->Службы->Superfetch - Отключить пишешь что-то типа Панель управления ->IN Пуск-> Отключить WHERE (Службы=Superfetch) FROM Администрирование Кто вообще такую ебанину придумал? Почему нельзя было НОРМАЛЬНЫЙ синтаксис завезти?
>>1869842 Я уже писал, что реляционные базы это про наборы данных и их объединение. Разделяй свой запрос на отдельные наболры данных, а потом объединяй их.
>Вывести отсортированный по количеству перелетов (по убыванию) список пассажиров, совершивших хотя бы 1 полет.
Сначала считаем полеты у пассажиров: SELECT passenger, COUNT(trip) AS count FROM Pass_in_trip GROUP BY passenger
Потом берем имена вместо идентификаторов: SELECT p.name, trips.count FROM ( SELECT passenger, COUNT(trip) AS count FROM Pass_in_trip GROUP BY passenger ) AS trips INNER JOIN Passenger AS p ON p.id = trips.passenger
Потом сортируем: SELECT p.name, trips.count FROM ( SELECT passenger, COUNT(trip) AS count FROM Pass_in_trip GROUP BY passenger ) AS trips INNER JOIN Passenger AS p ON p.id = trips.passenger ORDER BY trips.count DESC
Если тебя путает формат записи, когда сначала выполняется то что внутри, то используй CTE. В этом тренажере используется MySql 8 он CTE поддерживает. С CTE запрос будет такой:
WITH passenger_trips AS ( SELECT passenger, COUNT(trip) AS count FROM Pass_in_trip GROUP BY passenger ), named_passenger_trips AS ( SELECT p.name, passenger_trips.count FROM passenger_trips INNER JOIN Passenger AS p ON p.id = passenger_trips.passenger )
SELECT name, count FROM named_passenger_trips ORDER BY count DESC
Понятно что второй шаг можно пропустить, но это нужно чтобы ты понял чем ты вообще занимаешься. Ты берешь набор строк с количеством полетов, и объединяешь его с набором имен пассажиров. Чем меньше эти наборы, тем быстрее все будет работать. Математика уровня пятого класса.
Получаем у кого вообще вел пары каждый препод: SELECT teacher, JSON_ARRAYAGG(class) classes FROM Schedule GROUP BY teacher
А потом проверяем есть ли среди пар преподов пары одиннадцатых классов SELECT Teacher FROM ( SELECT teacher, JSON_ARRAYAGG(class) classes FROM Schedule GROUP BY teacher ) AS teacher_classes WHERE JSON_CONTAINS( teacher_classes.classes, (SELECT JSON_ARRAYAGG(id) FROM Class WHERE name LIKE '11%') )
JSON используется потому что ебучий MySql не поддерживает нормальные массивы, но идея та же самая. Можно список пар хоть в строку засунуть, просто перед проверкой придется эту строку опять разбить.
>>1869842 >>Почему нельзя было НОРМАЛЬНЫЙ синтаксис завезти? Не тормози. Потому что все это основано на реляционной алгебре. Все это старше чем ты раза в три. sql синтаксим полностью своей задаче и логике удовлетворяет. Сахар - это про фронтред макак.
>>1869712 >Как кстати решил проблему совместимости старых методов Request/Response, если пришлось?
А какие там проблемы? Чет не столкнулся пока что. Они же и там и там psr7. Ток для slim4 пакет фабрик теперь отдельно. require slim/psr7 - я поставил и вроде все норм.
>>1869740 какой ты ответ ожидаешь услышать? люди в 30 лет вкатываются без проблем. если есть желание и интерес - просто бери и вкатывайся. гайд с нуля в шапке, но я бы советовал определиться с направлением сначала. фронт энд или бэк энд. так легче будет составить план действия по изучению и поделить задачи на мелкие
>>1869944 В третьем слимовский вариант Реквеста и респонса был расширен, методами вроде getParam, getParsedBodyParam и тд, в 4м все это снесли для соответсвия psr. Если с респонсом еще нет проблем, просто оборачивается кастомным в фабрике, то чтобы вернуть подобные штуки в реквест, его приходится чуть не сначала пересоздавать. Вообщем я предпочел отрефакторить контроллеры, поменяв только респонс.
ОП, что можешь посоветовать для изучения rabbitmq? Ну, как архитектурно приложение строить и так далее. Или там все настолько элементарно что просто ставишь php-amqplib и юзаешь? Есть ли смысл смысл в бандле для симфони (php-amqplib/RabbitMqBundle)? В Yii юзал либу для очередей, которая по консольной команде запускалась. Где почитать для чего, как и что делать правильно?
>>1870194 Я пока что не особо понимаю как в php-di работает этот автовайринг. Я определяю роуты как экшен контроллеры: Этот контроллер не инстанцирован в контейнер.
$app->get('/main', MainAction::class );
и судя по все в таком случае MainAction в конструкторе резолвит только те зависимости что есть в контейнере. У меня в контейнере объекты ServerRequestInterface $request и ResponseInterface $response отсутствуют - и выпадает ошибка. Но при этом при последующем вызове __invoke-метода( ServerRequestInterface $request и ResponseInterface $response ) - эти зависимости автоварятся. Короче пока что для меня все это из магии состоит наполовину. Нужно больше предолиться.
>>1870741 п.с. Вообще кака то залупа получается. Чет меня этот ебаный php-di подбешивает. Сделал $app->get('/main', MainController::class . ':main' ); - таким образом. Мне нужно подтянуть в этот метод main класс MainService как зависимость mainService - в контейнере изначально не определен. Рассчитываю на awtowiring и по итогу хуйня получается
class MainController{
//если передать в конструктор MainService public function __construct(ContainerInterface $container, MainService $mainService){ //то через конструктор зависимость MainService подтянется, //но при этом, как я выше писал через конструктор нельзя подтянуть ServerRequestInterface $request, ResponseInterface $response. //будет ошибка Entry "App\Action\MainAction" cannot be resolved: Entry "Psr\Http\Message\ServerRequestInterface" cannot be resolved: the class is not instantiable Full definition:
}
//тут получается хуйня - если я в методе определяю mainService - то выдает ошибку о том что передан нет клдасс а array public function main( ServerRequestInterface $request, ResponseInterface $response ,MainService $mainSrvice ){ //Argument 3 passed to App\Action\MainController::main() must be an instance of App\Domain\Main\Service\MainService, array given //с хуев ли array? }
}
Я как то через жопу настроил, и не могу инъекции в метод контроллера проводить, только в конструктор
Есть один метод. Принимает в себя экземпляр класса Model, например. Примет ли он экземпляр класса Event, если Event наследует Model? В онлайн компиляторе работает, локально нет возможности проверить. PHP 7+
Аноны, кто знает как в связке slim4 + php-di добиться того что бы в контроллере, в нужном методе автовайрились нужные зависимости автоматически? Чет нихуя красиво не получается, пока что получается что на каждый роут свой ActionController - в который загружается свой отдельный сервис, а в сервисе уже все требуемые зависимости через конструктор автовайрингом подтягиваются. Много файлов классов получается, но хоть прозрачно все.
>>1869910 Спасибо. Значит в 16 нужно было джойнить не сами таблицы, а сначала на основе таблицы билетов создать новую таблицу, а потом уже заджойнить её с существующей таблицей пассажиров. А зачем создавать псевдонимы? а многих сайтах вижу примеры сложных запросов, в которых куча псевдонимов. неужели это обязательно? Они же наоборот затрудняют чтение, вводя дополнительные имена.
>>1869912 А вот тут слишком для меня сложно. JSON_ARRAYAGG - это какие-то дальние закоулки документации, в гугле даже мало что с этой командой есть. Если для решения этой задачи нужно знать и помнить вообще все возможные функции (или как эти штуки называются?), то мне становится как-то стрёмно.
>>1871644 >А зачем создавать псевдонимы? Псевдонимы нужны чтобы отличать какие поля к чему относятся. По умолчанию в качестве псевдонима используется имя таблицы, но оно длинное. Обычно сокражают по первым буквам, а если сокращение уже есть добавляют номер. Это удобно и можно понять почему именно такое название. А для подзапросов наоборот нужно придумать максимально понятное название, чтобы по нему было понятно что внутри.
>А вот тут слишком для меня сложно. JSON_ARRAYAGG - это какие-то дальние закоулки документации Ты думаешь я помнил какие там функции есть? Я сначала сформулировал что мне нужно: структура в которой для каждого препода есть список классов, где он провел пары, потом сравниваем этот список со списком одиннадцатых классов и вуаля. JSON_ARRAYAGG это просто способ хранения. Первое что мне пришло в голову group_concat и find_in_set, но это совсем уж ебля мозга, поэтому я взял решение посовременней.
Вообще я бы НЕ рекомендовал учиться на MySql, даже 8 версии. Я понимаю что ты нашел пиздатый учебник, но лучше как для нервов так и для карьеры Postgres.
Здравствуйте, можно ли как-то поделить один файл php на ссылки не разделяя его при этом на разные файлы. Чтобы одной части кода задать один адрес, а другой части другой и т.д.
Может кто-нибудь знает, как шторм откатить до версии 2020.2? Там просто в новой версии баг один очень неприятный с ларавелем. Разрабы написали, что пофиксят в обновлении, но когда оно будет неясно.
Как вы относитесь к учебнику ОПа? Я вот дошел до задачки про сумму прописью и понял что без сторонней помощи и изучения чужих решений это просто нереально решить. В чем смысл тогда?
А на php или хотя бы js есть какая-нибудь библиотека для работы с текстом на русском? То есть есть текст из него нужно составить словарь и посчитать сколько раз то или иное слово там используется, учитывая склонения, спряжения и другие производные формы.
Эта задача решается разбиением на более мелкие. Делаем функцию, которая умеет выбирать форму слова в зависимости от числа, делаем функцию, которая выводит числа от 1 до 999, и из этого собираем программу.
Ты можешь объявлять зависимости в конструкторе контроллера, для всех методов. Тогда, правда, будет подключаться чуть больше зависимостей, чем требуется для одного роута.
Согласно принципу Лисков, объект-наследник может применяться вместо объекта-предка. Этот принцип во многих случаях соблюдается, например new Event instanceof Model тоже вернет true.
Как мне кажется, для создания объекта-контроллера Слим вызывает php-di, потому в конструктор можно передавать зависимости. При этом php-di ничего не знает о request/response, и не должен знать, так как это не постоянные объекты, а создающиеся на каждый запрос. Их нельзя создать автоматически, так как в том же реквесте тогда не будут прописаны нужные параметры (какой URL, какие GET параметры итд).
Метод main() вызывает не php-di, а Слим, php-di тут никак не участвует, потому в него зависимости не передаются. А объекты request/response - передаются.
Что именно передается в callback, и откуда там 3-м аргументом берется массив, описано тут
- видит что контроллером указан MainController::class . ':main' - просит DI контейнер создать сервис с именем MainController::class - вызывает у объекта метод main и передает в него реквест/респонс.
В новом Симфони есть компонет Messenger для работы с очередями. Но ты можешь использовать и другие библиотеки. Архитектура простая - есть писатели, которые пишут задачи в очередь, есть процессы-воркеры, которые читают задачи из очереди, и выполняют. В случае Messenger тебе не надо особо разбираться в RabbitMQ, он все настроит за тебя.
Если же ты хочешь разобраться, то проще всего почитать документацию про очереди, обменники и что там еще есть. Мне, к сожалению. в голову не приходит пример, где все это нужно, может кто-то другой подскажет.
Так как 11-х классов всего два, можно заджойнить таблицу Schedule саму на себя, с условием что справа и слева один и тот же препод (FROM schedule sch1 JOIN schedule sch ON sch1.teacher = sch2.teacher) и искать записи, где слева класс 11A, а справа 11B.
Но, что если классов может быть больше? Хочется более универсальное решение. Оно есть. Мы можем:
- взять таблицу schedule - выбрать из нее только записи с 11-ми классами (WHERE) - сгруппировать по преподам - посчитать число уникальных классов COUNT(DISTINCT) - оставить только записи, где это число >= 2 (HAVING)
SELECT teacher, COUNT(DISTINCT class) num FROM schedule sch WHERE class LIKE '11%' GROUP BY teacher HAVING num = 2
И без всяких JSON-ов! Учи SQL получше, это довольно простая задачка. Учись применять джойны и делать группировки.
Привет, есть строка адреса. В ней может быть что угодно забито юзером, вот пример: 1234 West Groove Street.
Так вот, например в реальности юзер может West написать как W, а Street как St, соответственно получаются следующие комбинации: 1234 W Groove St 1234 W Groove Street 1234 West Groove St 1234 West Groove Street
Например у меня есть словарь слов которые могут быть записаны с такими вот вариантами, как мне написать метод, которому я на вход подам любую из этих строк, а на выходе получу массив из всех возможных комбинаций?
>>1873271 Навасянил за пол часа забейте. Тот неловкий момент когда гоняешь туда-сюда строчки два года уже без перерыва, и уже даже забыл как цикл for() работает, не то что бы какие-то простейшие алгоритмические задачи решать по типу этой :((((
>>1873253 http://phpbook.ga/l1/finals.html >>1873162 >Эта задача решается разбиением на более мелкие. Делаем функцию, которая умеет выбирать форму слова в зависимости от числа, делаем функцию, которая выводит числа от 1 до 999, и из этого собираем программу. Я знаю из каких частей состоит программа, я не знаю что использовать для решения.
>>1873339 Ну к каждому числу нужно в массиве добавить значение с нужным текстом, а что делать с числом типа "123"? Мне же не вручную заполнять массив для каждого числа от 0 до 999 и так далее.
Вот, ты уже начинаешь правильно думать. Вместо того, чтобы делать массив для всех чисел от 1 до 999, мы делаем массив с круглыми цифрами (единицы, десятки, сотни). Разбиваем число на 3 цифры: сотни, десятки, единицы и для каждой цифры находим соответствующее слово.
Единственное, тут еще надо заморочиться с распознаванием чисел 11-19, для которых алгоритм выше не работает, но это можно добавить позже.
Чтобы получить старший разряд числа, можно использовать floor($x / 1000). Например, 9876 / 1000 = 9.876, после округления останется 9. Чтобы получить младший разряд, достаточно взять остаток от деления числа на 10. Например, остаток от деления 9876 на 10 равен 6.
>>1873679 Ну вот смотри, разбиваем число 973 на (9, 7, 3) , то есть должно получиться прописью "девятьсот семьдесят три", но если начать сравнивать это с элементами массива, то естественно получиться "девять семь три". В чем тут прикол? Я видимо не очень умный.
Тут надо либо сделать 3 разных массива (для сотен, десятков и единиц), либо домножить числа на 100 и 10, чтобы получить не 9,7,3, а 900, 70 и 3 и тогда можно использовать один массив.
>>1873703 Реально. Просто проверяешь что функция выполняет то, что ты от неё ждешь. Юнит-тесты можешь посмотреть в тех же исходниках Symfony, ну или на ютубе.
Для проверки правильности твоих юнит-тестов можешь попробовать подключить мутационное тестирование (https://github.com/infection/infection) (оно проверит твои тесты, меняя проверки и др., и если тест крашнул - все хорошо)
Чтобы перейти к большим числам, их надо точно так же (с помощью деления) разбить на группы по три знака: единицы, тысячи, миллионы. Для каждой группы ты вызываешь функцию, чтобы преобразовать число в слова, и приписываешь нужное слово (тысяч, миллионов).
По коду: цикл по массиву $spelling тут лишний. Чтобы взять из массива слово, достаточно использовать квадратные скобки, например:
$x = 100; echo $spelling[$x];
Также, надо добавить условие, что если число оканчивается на 11-19, то вместо единиц и десятков по отдельности мы берем одно слово.
>>1871773 >лучше как для нервов так и для карьеры Postgres. С карьерой понятно, его сейчас каждый первый требует. А что насчёт нервов с майскулом не так, а с постгресом так?
>>1874420 Аноны, вы тоже хуй забиваете на все эти связи между таблицами? Нигде в работе не видел что бы чет связывали.
Наверное в теории все это круто и заебись, но на практике рот все ебали когда все так жестко связано. Типа нельзя почистить одну таблицу без другой итд. Других объяснений я не нахожу.
>>1874372 да много чего не так. Нет табличных выражений, не поддерживаются DDL запросы в транзакциях, не поддерживаются курсоры (точнее поддерживаются только внутри хранимых процедур), добавить колонку на таблицу под нагрузкой без блокировок нельзя. Учи сразу PostgreSQL, дока на русском, курсов много. Если знаешь PostgreSQL, а в вакансии MySQL, то не расстроятся, а если работал с MySQL, а в вакансии PostgreSQL, то напрягутся.
>>1874558 Ты что далбаёб совсем ? Я пока в PHP зелёный, но до этого оч много с SQL работал. Как ты себе представляешь БД без связей ? Всё чистится, есть специальные алгоритмы, которые проверяют целостность БД и могут рекурсивно очищать в зависимых таблицах связи. Только думать надо - чтобы ничего не удалилось лишнего.
Как записать в куки сначала массив, а потом этот массив удалить? Хочу в функции получать только определенный набор значений из Кук и работать с ними, чтобы не тащить все говно туда.
>>1874558 Бывает что нужно изменить связь (другой родитель, другая дочка) и в большой таблице это делать долго. Поэтому связи через классы описывают, а поля которые используются в таких связях просто добавляют в индекс.
>>1874558 >Нигде в работе не видел что бы чет связывали. пиздец, сваливай с такой работы. Это какое то дно У меня прямо противоположная ситуация. Уже хер знает сколько лет не видел проектов без связей.
>Типа нельзя почистить одну таблицу без другой итд ON DELETE CASCASE\SET NULL, в зависимости от бизнес-логики.
Пытаюсь прикрутить к Laraver-8 авторизацию через вторую таблицу. Не могу залогиниться в контроллере.
Auth::guard('manager')->attempt(['email' => $request->get('email'), 'password' => $request->get('password')]) всегда возвращает false, хотя в то же время Hash::check($request->get('password'), DB::table('managers')->where('email', $request->get('email'))->first()->password) возвращает true
Аноны, кто знает, как пхп выполняется в контексте "потоков". Вот у меня комп, 4 ядра, 4 гига. Допустим шиндовс.
Как это работает? Создается процесс на одном ядре-> и если все четыре ядразабились - то все, сервер лег ? Или в одном процессе создается что то типа потока , в котором выполняется скрипт, и потоков на одном ядре могут сразу выполняться тысячи? Чет я на хабре прочел и нихуяч не понял.
>>1875622 п.п.с. Или вэб-сервер создает какое то количество потоков в (10 или 20 или 500), в соответствии с количеством запросов, и в рамках каждого потока запускае5тся скрипт пхп, ну и выполняется?
>>1875632 this Упрощенно, на каждый запрос порождается отдельный поток, в котором и выполняется скрипт. После выполнения поток закрывается. Алсо, потоков на компе может выполняться очень много параллельно. Не обязательно по числу ядер. Почитай про многопоточность
Ребят. У меня к вам вопрос. Делаю туду. И пришел к моменту, когда нужно данные сохранять. Так как меня больше интересует жыес а писание на пхп хочу свести к минимуму. А скьюел вообще лень. То подскажите мне.
Сейчас у меня сохранение происходит записью хтмл кода в блокнот по клику на кнопочку. Тупо берется контейнер и его детей записываются в блокнот. Сразу задам вопрос. Насколько это тупо? И делают ли так нормальные люди?
Так как я люблю необычное, я решил сделать авторизацию. Тоже завязав это все на файлах. Будет это выглядеть примерно так. Проходишь регистрацию. Создается папочка, в ней файлы. Блокнот с "БД" и блокнот с логином и паролем"для авторизации".
Если кто-то увидит это, меня засмеют? Или это норм и за такое не бьют. Если первое верно, то сразу лучше в скьюелами делать? Или можно не надо?
>>1874966 >в зависимости от бизнес-логики До тех пор пока не удалится то, что удалять было нельзя. Каскады работают на определенном масштабе. Когда у тебя база перевалит таблиц за пятьдесят каскады превратятся в ромбы и кольца, и ты физически не будешь знать что вообще удалится вместе с твоей мелкой хуйней. А скорее всего не удалится, а выдаст ошибку, что удалять нужно что-то другое или что-то не получается удалить.
Кроме того каскадное удаление это еще и удар по перфомансу, в супер хайлоад проекте даже пришлось вообще от DELETE запросов отказаться, ставили флаг типа удален, а потом чистили специальным воркером. И все потому что UPDATE Быстрее чем DELETE.
Ну останутся когда-нибудь где нибудь не удаленные записи, которые никто никогда не увидит - это вообще похую. Главное что у пользователя все происходит мгновенно и не приходится ждать когда там этот каскад отработает, если вообще отработает.
>>1875757 Понял, спасибо. Второй вопрос - opcache он по дефолту выключен получается? Если я для своей приложухи тупо его включу - будет работать из коробки , или что то где то наебнется ?
>>1875947 > писание на пхп хочу свести к минимуму. > А скьюел вообще лень. Тогда зачем ты сюда пишешь? Пиши в треды про фронтенды. > . Насколько это тупо? Тупость зашкаливает. Серьезно. > И делают ли так нормальные люди? Нет. Разве что в самом начале когда вкатывешься посмотреть как пхп работает с файлами и пост запросами
> Так как я люблю необычное, я решил сделать авторизацию. > Тоже завязав это все на файлах. Будет это выглядеть примерно так. Проходишь регистрацию. Создается папочка, в ней файлы. > Блокнот с "БД" и блокнот с логином и паролем"для авторизации". Пиздец. Пароль в открытом виде в бд хранить по сравнению с этим не такой уж и зашквар.
> Если кто-то увидит это, меня засмеют? Или это норм и за такое не бьют. Сначала охуеют потом засмеют > Если первое верно, то сразу лучше в скьюелами делать? Или можно не надо? Если ты копротивляешься учить sql то в бэке тебе делать нечего. Мой тебе совет - учи какой нить ангуляр / Ву / реакт
PHP-FPM для обслуживания запросов создает N воркеров (кол-во настраивается в конфиге). Сколько воркеров - столько одновременно скриптов может выполняться. каждый воркер это отдельный процесс ОС (а не поток, не путай). Если вдруг пришло больше запросов чем воркеров, то лишние ставятся в очередь и ждут освобождения воркера (это ограничение защищает систему от перегрузки большим числом процессов).
Если у тебя всего одно ядро, то ОС будет выполнять код на нем по очереди. Какую-то долю секунды (квант времени, time slice) будет работать первый воркер, какую-то второй и так по кругу. То есть одно ядро разделяется между многими процессами и имитируется их как бы "параллельное" выполнение.
Если у тебя 4 ядра, то они тоже будут разделяться между всеми работающими воркерами. Но теперь каждый воркер будет получать в 4 раза больше квантов времени (time slice), чем в случае с одним ядром, воркер будет работать быстрее и система сможет обрабатывать больше запросов в секунду.
Если воркеров менее 4, то каждый получит в свое распоряжение одно ядро полностью и никто не будет ему мешать, если более 4 - то какие-то ядра будут делиться между несколькими воркерами.
Это не особенность PHP, это реализация многозадачности в ОС. Точно так же будут работать другие многопроцессные или многопоточные программы.
Здравствуйте, подскажите, пожалуйста, как добавить текст на изображение, а конкретно на вотермарку, но чтобы текст выравнивался по правой стороне. Пример прикрепил. imagettftext позволяет отталкиваться только от первого символа.
И еще подскажите, у меня приложение slim 4 создает отчет, в виде эксель файла. Этот файл сохраняется в некий store. В ходе этого же запроса этот созданный отчет отдается на закачку клиенту. Этот отчет формируется часто, разными людьми, значит его нужно после отдачи уничтожить, что бы не хламились. Но допустим эксель файл большой, и в объект response он попадет по частям, как поток. То есть получается я response верну из обработчика раньше, чем смогу удалить этот файл. Как быть? Начать думать в сторону очередей?
И еще вопрос - по теме отдачи клиенту файла на загрузку. Как после того как файл был загружен клиенту сделать куда-нибудь редирект? Получается что единственный вариант - как то через JS, но я не могу найти события которые реагируют на окончание загрузки документа в папку "Загрузки" на компе клиента. Как сделать такое?
Как в абстрактном классе сделать метод который будет создавать экземпляр класса на котором он вызван? Типо кто-то наследует абстрактный класс - метод создаёт экземпляр этого наследника. Я попробовал self в абстрактном классе, но судя по тестам он привязан именно к абстрактному классу, а не к наследнику.
Не до конца понял смысл хеша и соли. Вот есть у меня пользователь с паролем "пароль". Я в базе данных храню соль и хэш от пароля+соль. Пользователь вводить пароль, сервер к этому паролю добавляет соль из базы данных, и сравнивает с хешем из той же базы данных для конкретного пользователя. Так? Что мешает в таком случае брутфорсить пароль, если соль и хеш всегда имеется на стороне сервера и автоматически добавляется и сравнивает с корректным значением?
>>1876712 > Что мешает в таком случае брутфорсить пароль Ничего. Следует пресекать подозрительную активность. Самые грубые варианты - блочить ip с которого брутят, либо замораживать учётную запись которую брутят. Ну думаю минусы этих вариантов очевидны
Лучше всего просто не сохранять файл на диск, а генерировать в памяти и сразу отдавать клиенту. Если это невозможно, то можно написать скрипт, который будет запускаться по крону и удалять все файлы старше X часов.
- при утечке базы пришлось перебирать каждый пароль отдельно и тратить время. Без соли пароли можно перебирать все одновременно, что значительно ускоряет их подбор. - чтобы не видно было по совпадению хеша, кто использует одинаковые пароли
Статистический запрос. Есть форма, прмерно 10 полей. Поля могут быть заполнены, могут не быть.
Соответственно из базы нужно получить выборку по этим полям. В духе: все автомобили , сделанные в июле 2016, с дизелем 2.5, красного цвета. А следующий запрос из этой же формы может быть все тоже самое, но уже без указания конкретного двигателя( т.е. все варианты двигателей ) Ну и так далее.
Собирать такой запрос в бд - склеивая сырой sql кажется мне хуитой. Особенно с учетом того что многие данные, допустим двигатель - хранятся в отдельной таблице, а в основной - просто id записи. Склеивать sql-строку из столько объединений и прочего - как то убого что ли. Альтернативой вижу как то распердолиться с моделями и классами что возвращают наборы данных из таблицы. Может какие то варианты где почитать про подобные запросы, какие то паттерны, или просто статьи? Примеры?
Если база не очень большая и работает с приемлемой скоростью - то собирать запрос, желательно не руками, а через Query Builder вроде доктриновского.
Если данных очень много и база не справляется, и есть много свободного времени, то можно попробовать подключить поисковый движок Sphinx или Elasticsearch.
>>1877590 База микроскопическая пока что, и скорее всего надолго. >>то собирать запрос, желательно не руками, а через Query Builder вроде Я знаком с eloquent. Но в данном случае хочу попердолиться самостоятельно. Но фактически получается что в рамках одной таблицы подобное можно получить только собирая строку sql запроса из необходимых частей по кускам? В соответствии с полями из $post?
>>1877748 Между тем, в случае когда полей формы много, и они могут как быть заполнены так и нет - с построением запроса с помощью самовелосипедного квери-билдера возникли трудности. Трабла в том что отдельные данные я могу отфильтровывать, или не отфильтровывать только в объединении INNER JOIN ( с фильтрами в where нет вопросов), что означает что я в построителе должен реализовать метод который создает объединение. Это не беда, проблема что объединений у меня штук 7, и их последовательный порядок важен. И значит квери-билдер должен создавать объединения в правильном порядке. Да и вообще, скрипт должен понимать какие методы квери билдера к какому полю формы применять. Для этих целей у меня существует массив, в котором для каждого поля из формы указано свое место в последовательности создания запроса в квери билдере, какой метод применять ( добавить ли в where, или в блок JOIN-ов, и т.д.).
Так как данные от формы каждый раз разные, какие то инпуты пусты, какие то заполнены - все это превращается в какой то запутанный цирк. Явно можно такое как то проще реализовывать. Может кто знает статью какую нибудь.
КАКНАХУЙ по SSH (сервер физически на другой машине) в VS Code сделать так, чтобы break point работал в Xdebug >>> ??? В Убунту установил xdebug, в vs code тоже. Точку ставлю красную, он не останавливается. Не могу в интернете найти нихуя, какие-то индусы вылазеют на ютубе. https://www.youtube.com/watch?v=lKXMyln_5q4 Но тут на C он отладчик запускает.
Наверно в конфигах где-то что-то сделать надо. Куда копать.
Для начала, как вообще работает отладка? Если речь не о консоли, а о веб-приложении, то примерно так:
- сначала ты настраиваешь в php.ini конфигурацию xdebug - настраиваешь IDE, чтобы она ждала соединение для отладки от PHP - затем ты открываешь страницу в браузере и передаешь с запросом trigger - специальную куку или GET-параметр, которая говорит о включении режима отладки (опция https://xdebug.org/docs/step_debug#trigger_value ) - xdebug останавливает выполнение скрипта и подсоединяется к твоей IDE - затем IDE через установленное соединение управляет выполнением скрипта
Тут есть минимум две сложности, так как машины разные.
1) скорее всего твоя машина с IDE находится за NAT провайдера, не имеет белого IP и в ней нельзя подсоединиться снаружи (с машины с PHP) 2) возможно, что на твоей машине и на сервере проект размещен в разных папках. Это может запутать IDE, так как отладчик будет передавать ей пути к несуществующим у тебя файлам.
Первую сложность обходят "пробросом" портов по SSH. Специальная команда ssh заставляет его открыть порт номер X на сервере и при соединении с ним подсоединяться к порту Y на локальной машине. Это описано тут: https://codex.so/ssh-tunnel (сценарий 2).
После этого ты настраиваешь xdebug соединяться с портом X на самом же сервере (127.0.0.1), а IDE заставляешь "слушать" порт Y локально (127.0.0.1). X и Y могут быть одинаковыми. ssh будет перебрасывать данные между машинами.
Опции для xdebug: xdebug.client_host, xdebug.client_port.
Что касается разных путей к проекту, то в IDE должна быть опция "замены" путей. Если ее нет, то проект должен быть расположен в одной и той же папке и локально и на сервере. Вроде как в расширении для VS Code есть такая опция pathMappings: https://marketplace.visualstudio.com/items?itemName=felixfbecker.php-debug
Твоя инструкция посвящена компиляции xdebug из исходников. Не понимаю, при чем тут это. Скорее всего, расширение xdebug (если на линуксе) ставится менеджером пакетов или, если его там нету, командой вроде pecl install.
Уточняй вопросы, если надо.
> Почему одной кнопкой нельзя отладчик поставить.
Именно поставить его можно одной командой в большинстве дистрибутивов линукса. А вот чтобы заработало, придется помучаться, обращай свои претензии к провайдеру, который выдал тебе серый IP.
То есть просто перечисляются все возможные условия и для каждого условия вспомогательная функция добавляет параметры в SQL-запрос. Query Builder как раз и придуман, чтобы составлять запрос по кусочкам. Строки склеивать не надо.
При таком разбиении код получается не сложным. Заметь, что я не работаю с формой или с $_POST в этой функции вообще, чтобы не сваливать все в кучу, я работаю с объектом фильтра, который создается из формы в другом месте.
>>1878985 Спасибо за ответ! Фактически к этому я и пришел самостоятельно, набросал свйо квери билдер, и им собираю запрос. На данный момент хорошо что это у меня все работает. После хочу уже свой велосипедный квери билдер дописать до нормального ООП состояния. а после перенесу на квери билдер из доктрины, или елоквент.
Начал изучать vue. Есть какое-то объяснение, почему во второй версии синтаксис объявления приложения такой красивый и лаконичный ( 1 пик ) , а в третьей такой ублюдский, что блевать хочется ( 2 пик )? Или возможно я что-то не так понял?
>>1878977 Да белый у меня ip. Можно хотя бы в консоли, чтоб работала она. Я ещё алгоритмические задачки решаю. По SSH по глобалоьному айпи у меня коннектится. Единственно я web-сервер на встроенном в php запускаю, если нужна веб-страничка. И там приходится в адресе прописывать 0.0.0.0. Так как если айпишник напрямую прописать, то почему-то ошибка (php -S 0.0.0.0:8000) -> на компе захожу по <мой белый ip>:5555. Мб для дебага какие-то порты в роутере надо пробросить тоже. Тут не понял: >порт Y локально (127.0.0.1) Это имеется ввиду не порт, а локальный ip ?
Еще у меня VS code на WIN10 вообще. Ubuntu server и ПК рабочей соединены по проводу через роутер. Они в одной локальной сети, поэтому я не понимаю, а зачем выходить за nat в принципе.
Попробую сделать и гуглить, что ты написал. Но это похоже надолго
>>1878977 >2) возможно, что на твоей машине и на сервере проект размещен в разных папках. Это может запутать IDE, так как отладчик будет передавать ей пути к несуществующим у тебя файлам. Это тоже не понял. У меня всё расположено на сервере. НА винде нигде не хранятся файлы. Там только редактор.
П.С. Получилось короче. На другом компе в локальном сети работает. Но думаю и через глобальный айпишник будет тоже работать тогда, если порт пробросить.
Пиздец, я 2 суток на это потратил. И в итоге сам разобрался. В интернете много старой инфы. Рабочий конфиг такой:
zend_extension=[Ваш путь к xdebug.so] xdebug.remote_enable=1 xdebug.remote_autostart=1 xdebug.remote_handler=dbgp xdebug.client_port=9000 //было remote_port xdebug.client_host=192.168.1.253 //было remote_host xdebug.discover_client_host=1 //было remote_connect_back xdebug.mode=debug //ЭТО ВООБЩЕ НОВАЯ НАСТРОЙКА, по умолчанию тут стоит develop. ЧТобы отладчик работал надо поменять на debug.
https://xdebug.org/docs/upgrade_guide Какого-то хера они заменили название параметров в 3 версии xdebug'a, а я вводил старые названия параметров (не только тот, что на скрине - там много их, они просто наименования параметров поменяли в 3 версии). Я хз, он недавно вышел или чего, нет нашёл инфы вообще.
Ну и в адресной строке добавить [адрес]?XDEBUG_SESSION_START=vscode (или другой редактор, если не vscode).
Делаю задание для начинающих, чет запутанная формулировка. Помогите понять, что от меня хотят: "Напишите код, как в многомерном ассоциативном массиве сотрудников отделов, найти ключ необходимого элемента массива фио сотрудника?"
Сап, двач. Как понять что я могу устроиться на позицию мидла в php?
Вот посмотрел одну вакансию рандомную.
> Владение php7.
Ну знаю да чем отличается от 5 и тем более древних, но не то чтобы от корки до корки. Анонимные классы писал, стрикттайпы в принципе могу писать если с ними кто-то пишет, в ООП могу, используем паттерны. Чё вообще почитать лучше по именно 7рке?
> git
Ну работаю с ним, чё такого. В мастер не сру, пул реквесты делаю.
> Фреймворк.
Пишем на ларе. Создал 2 небольших приложения. Базовые концепты знаю.
> Практики.
Вот тут сложно. Понимание есть, но мы так не пишем. Только теория. Писали бы мы так, я бы не хотел сбегать. И ТДД не юзаем и тесты пишем для галочки и хуёвые. Я хочу нормальный ТТД, пишу feature rich todo list.
> Опыт работы с JS
На ноде писал, заглушки апишки делал. Фронт знаю средне, реакт не могу. Но я ж бэк блят. Ну нахуярить на реакте помойку смогу.
> Знание SQL.
Ну запросы вручную пишу. Джойны, агрегации, знаю шо такое нормализация. Ну пишу запросы себе, да.
Остальные пункты все какие-то ещё более абстрактные.
Как сука понять шо аймреди? Я боюся, а хочется развиваться. Чё советуете?
Аноны, делаю курсач - сайт на жава спринг буте. У меня через форму загружается фотка. Если её не залить, получится пикрил хуета, а я хочу прост пустое место. Че поменять надо если в чтмле картинка энивей выводится
<img alt="" th:src="*{'data:image/jpeg;base64,'+{el.image}}" style ="width:350px; height:350px"/> Хотел вместо 350 засунуть кастомную el.width, но это так не работает Картинка по цвету фона тоже не варик, отступ большой будет Как проверку на жаве написать - понятно, че с чтмлом делать хз
Шапка на нулевой говорит про такие вещи спрашивать в языковых тредах, хотя и сомнительно, что мне именно сюда. Короче пацаны, есть один VS Code, на который я съебался с тормознутого пхп шторма, и в нём абсолютно всё заебись, кроме одного нюанса - при дебаге нельзя навестить на дочернее свойство/ключ массива и посмотреть чё там лежит. Пример: $arPomoika["GOLYE_BABY"] - можно навестись на $arPomoika и посмотреть, что в нём лежит, но нельзя навестись на ["GOLYE_BABY"] и смотреть сразу на голых баб, не копаясь в $arPomoika в их поиске.
Можно как-то это запилить экстеншонами/конфигами/етц?
>>1876014 >До тех пор пока не удалится то, что удалять было нельзя. Нормально ставьте зависимости и каскады, нормально всё будет.
>и ты физически не будешь знать что вообще удалится вместе с твоей мелкой хуйней. то, что нужно удалить с твоей мелкой хуйней.
>А скорее всего не удалится, а выдаст ошибку, что удалять нужно что-то другое или что-то не получается удалить. И хорошо, значит, удаляй не мелкую хуйню, а крупную. Что за паническая боязнь ошибок? Кинутые эксепшоны это заебись. Они в 9 из 10 случаев ловятся тестами, в одном тебе звонит пользователь и ты чинишь всё вилкой. Самые жопоебные баги в моей карьере, после которых нашего СЕО ебали как собаку а пиздюли летели всему отделу происходили из-за попыток ОБРАБАТЫВАТЬ исключения и сделать жопу незаметной для пользователя.
>ставили флаг типа удален, а потом чистили специальным воркером. Молодцы, и что вам не нравится? Нормально сделали. Пусть воркер шуршит, он не человек.
Проблемы, которые создают зависимости, ничто на фоне того, что какой-нибудь петушара таки удалит что-нибудь важное на проде. Уж на что уж я знатный гречневый говнокодер, с презрением смотрящий на современых смузихлебов, но ключи в базе проставить 100% нужно.
Есть небольшач форма в html в которой реализуется поиск. Тупо строка для ввода и кнопка для поиска. Если в форме стоит метод гет, он передает только то что ввел в строке поиска, но не использует кусок адреса в параметре экшн из формы для передачи. А если изменить на пост,то все ништяк. В чем дело?
>>1880999 >Нормально ставьте зависимости и каскады, нормально всё будет Ну ты жопочтец. Я тебе о том и говорю что при определенном масштабе ты не можешь принять "нормальное" решение. Прикинь, оказывается бывают проекты, в которых чисто физически невозможно знать что хранится во всех таблицах. И нет возможности найти "верное" решение прямо сейчас.
Нужно найти того кто знает, найти ответственных манагеров, бизнес аналитика, потратить время на митинг на следующей неделе. А Виталик вообще не станет этим заниматься, и нахуярит так как ему кажется "правильно". А тебе чтобы понять на ревью что он хуйню написал нужно проделать всю эту работу за него, а у тебя на ревью час отписан. И будет это не удаление всей базы, которую можно в один клик из бекапа поднять, а как червяк, который годы может создавать случайные баги и ебать мозги пользователям, а те тебе.
Про дедлоки и перфоманс это вообще классика. Последний раз когда я видел foreign ключи в коммерческом проекте была PIM система от французких гениев. Удаление одного товара длилось ~200мс. Кода удаляешь один, то вообще похуй. Но когда нужно удалить, напрмер все футболки, то это на пол часа. Мы сначала подумали что это развод на даллары такой, типа плати и ускоряйся. Но когда полезли в саму базу кекнули. Там таблиц тридцать, и все так или иначе завязаны на товар, и при удалении создавался нихуевый такой каскад почти по всем. Опять же если у тебя всего 2К товаров, то ты говоришь спасибо за foreign ключи и пользуешься. А если несколько миллионов, и поставщики меняются каждую неделю, то выкидываешь нахуй эти ключи, и делаешь все в двести раз быстрее.
Но самое главное, это то что я никогда не видел проблем из-за того что что-то не удалилось. А вот проблем из-за ситуаций когда удалилось то что не должно куча. Так что если пишешь блог или сайт местной хоккейной команды, то резвись: удаляй по каскаду, нормализуй до упора. На крупном проекте если это ничего не ускоряет, то это нахуй никому не надо.
>>1880349 Забавно, я это почти ты, ток у меня в активе ноль дней работы прогером точнее уже 2 года стажа в гос шараге в должности инженер-программист, но в коммерции ноль , и твой опыт для меня вполне релевантен. Я мидл? ололо:)
>>1880991 Да забей ты хуй на инфантильную помойку мыслей. Готов\не готов. Ебашь. Жизнь любит дерзких и активных это в принципе самое важно что нужно для успеха сапиенса. Овощей которые пять лет на мидла готовятся - жизнь по итогу ебет в лице тех кто кабанчиком заскочил пять лет назад и сейчас владеет бизнесом на котором овощ трудится.
Бля, что почитать человеческим языком по слоям и "чистой архитектуре"? Пишу приложение, Action/Domain/Responder/ По ходу пьесы не получается все в сервис воткнуть, нужны некие общие классы, типа квэри билдера. И я хз куда его воткнуть. Он общий для всего слоя Domain. Он по идее относится к "общим" классам Repository ?
>>1881571 > Нужно найти того кто знает, найти ответственных манагеров, бизнес аналитика, потратить время на митинг на следующей неделе. А Виталик вообще не станет этим заниматься, и нахуярит так как ему кажется "правильно". А тебе чтобы понять на ревью что он хуйню написал нужно проделать всю эту работу за него, а у тебя на ревью час отписан. Ну тут можно посочувствовать. Бардак на галере - бардак в бд и, судя по Виталику, сплошной говнокод.
> И будет это не удаление всей базы, которую можно в один клик из бекапа поднять, а как червяк, который годы может создавать случайные баги и ебать мозги пользователям, а те тебе. Я раз 10 перечитал но так и не понял что ты тут написал.
Срочно подписываем петицию чтобы из этих ваших ораклов, постгрессов и мускул убрали эти ужасные ограничения внешних ключей. У Сычева хайлоад тормозит и не то удаляется! мимокрок
Народ, почему в официальной доке нет пример по установке ебаного php-fmp? Я вдруг осознал что я его ставил и тысяча раз шерстил различные форумы ебаные чтобы узнать все расширения какие нужны по типу php-fpm7.3-cli php-fpm7.3-common php-fpm7.3-gd и прочее и откуда их брать? Почему нет примеров по установке? У них на сайте только сборка из сорцов блядь а не через apt. Меня это уже доебало блядь, почему нет модуль листа с теми что нужно и как подключать, я забываю уже все эти названия ебаные по типу php-fpm7.3 версию проебал и не поставится, название модуля не добавил и все. Что за пиздец?
>>1884323 Живее всех живых. Просто тут вкатунов уровня тудухи видимо мало. А остальные дрочатся с такими вещами о которых сложно сам вопрос задать, и тем более получить развернутый ответ.
Я щас ебусь с DDD, и бля, и никто мне не поможет и не надо помогать.
>>1849078 (OP) Есть портабельный этот похапе с мускулами чтобы блядь сделать примитивный сайт с регистрацией-авторизацией? Забали эти СУБД и БД и пердолинг с конпеляцией SQLite на C# и хуй знает как потом эту .dll юзать, и нет ли там бекдоров, и ещё и СУБД надо знать блядь, годной литературы для вката в эту залупу не подкинули, короче надо сукаблядь МУСКУЛ и ПОХАПЕ, но чтобы было портабле ексе и чтобы не было setup.exe с прописью в реестр, и чтобы не засрало roaming-хуюаминг и прочие Application-Data, и чтобы когда надо снести нахуй шиндошс и переустановить его - чтобы короче, с флешки запустился похапе с мусколом-хуюскулом этим, и чтобы всё завелось, и не выёбывалось мне, и чтобы не надо было переустанавливать всю эту залупу.
>>1884421 Нашёл XAMPP, но там сплошной бинарь, и хуй знает может вирасы есть или бекдори. Есть ли чо-то опенсорцное? MySQL знаю что опенсорцная, но лицензия какая-то мутная, проприетарное что-то вшито, можно вырезать это нахуй и сбилдить из сореца, норм мускул?
>>1884421 Нашёл вот такое: https://habr.com/ru/post/145970/ NodeJS + connect. Вроде, должно работать без пердолинга с СУБД, но на JS, и хуй знает можно ли качнуть NodeJS portable, чтобы не устанавливать эту еботу - в шинду.
Вопрос про поганый CSS. Есть div элементы под одним классом все. Нужно с Grid-Layout сделать так чтобы если ширина экрана между 768 и 992 то показываются только два столбика из этих div'фов.
Слой адаптера - тут экшен-контроллер, а так же коннект к бд. Внутри идет "use case" - слой. Это "сервис", допустим его задача - добавить "статью". За ним идет слой Entities (сущности) - бизнес логика. В этой логике у меня сущность характеризующая "статью". И с этой "статьей" нужно проводить действия какие то. Сама сущность "статья" должна быть независима от реализации хранилища (база данных и т.п.). В качестве прослойки к БД у меня eloquent (и его orm-модели)
Как должно все идти? Не понимаю в каком порядке все это вызывать.
Я в слое "use case" получаю из внешнего слоя ( экшен контроллер в моем случае ) данные - пост запрос. Далее мне нужно создать мой объект "статьи" из слоя Entities. Для этого мне получается нужно вызвать мой слой работы с хранилищем ( у меня eloquent и mysql ), пусть это будет некий класс ArticleRepository, он умеет получать данные из текущего хранилища, получается это низкий уровень абстракиции. И по данным из хранилища ( пусть это банальный массив для простоты ) я должен создать свою сущность которая характеризует бизнес логику. Вопрос - где конкретно должна быть создана сущность "Статья"? В классе ArticleRepository , из которой сущность "статья" будет возвращена в класс use case слоя? Или из ArticleRepository вернуть сырые данные ( массив ) и уже в use case создаем объект. Я думаю что правильно из ArticleRepository возвращать уже сущность в виде готового объекта. Далее - мне нужно провести манипуляции с сущностью ( сама бизнес логика) и после сохранить это все в хранилище через слой ArticleRepository. Первое - сущность "статья" сама в себе должна нести механизмы по которым она работает? Как мне кажется да - создаем сущность, потом она меняется ( условно от какого то поля сущности нужно посчитать ) - т.е. все бизнесправила, и вспомогательные классы по которым оно работает - находятся в слое Entities . Я правильно размышляю? Получив измененную статью - я должен получить из слоя работы с хранилищем ( любым получается, на данный момент моя измененная сущность "статья" не знает в какое хранилище она сериализуется ) ArticleRepository , который уже в свою очередь получит сущность, по каким то правилам ее сериализует и вызовет уже построитель запросов eloquent и сохранит данные в базе. Я правильно размышляю. Сорр за многословность и не совсем внятность, кошке объяснить не могу, она спит, поэтому тред у меня в качестве резиновой уточки.
Сап, вопрос по ларавелю. Допустим у меня есть метод create user. У меня есть для этого метода тест. Это юнит тест или feature test? Допустим я создаю юзера и проверяю если юзер есть в базе данных.
Для меня это звучит как юнит тест потому что мы тестим класс. И для проверки его работы мы лезем в базу данных и проверяем есть ли в базе данных этот юзер, а пользователь с точки зрения такой логики не может проверить базу данных, следовательно должен быть юнит.
>>1882107 А чем гос шарага отличается. Опыт есть опыт, а гос или не гос не важно. У меня тоже шарага шаражная.
>>1882110 Да понял уже, пилю себе проектик в гитхаб тестовый безмозглый чтоб хоть чёт показать с опытом. После НГ пишу заявления. До НГ не хочу, планы есть.
Не знаю, как в Ларавеле, но обычно это называют интеграционный тест, так как он тестирует взаимодействие класса с БД. Юнит тест тестирует класс в изоляции от других классов или БД.
Пацаны, советуйте чё по пхп почитать. Открыл пик 1, полный пиздец перелевание воды из пизды в жопу, анальная ебля в гланды и истории про космические корабли и большой театр.
Открыл 2. Годно, но мало. Чё вообще посоветуете?
>>1884403 Сука, Эванс бля. У нас этим каллом весь универ обмазывался
Не могу сообразить как спроектировать БД для условного магазина. Допустим, у нас есть таблицы client, order, goods. Если клиент Вася купил три штуки товара Х, это легко записать в order. Но если он купил три Х и один Y?
>>1888954 То есть, логика такая (на этой схеме): Как только клиент кладёт товар в корзину, система делает sql-запрос "есть ли сессия из куки клиента в sessionId таблицы cart?". Если нет, то появляется новая строка в таблице cart. Затем в cart_item ищется cartId, взятый из id таблицы cart. Это все товары из текущего заказа. Если такой товар ещё не заказан, то добавляем новую строку, если заказан, то инкрементируем quantity.
Когда клиент завершает добавлять товары к заказу, он пишет адрес доставки и эти данные тоже добавляются в cart, чтобы если он уйдёт, то при следующем заходе подтянть из куки сессию, найти эту корзину по ней и подставить юзеру.
Когда клиент переходит к оплате, мы считаем, что это уже сделка и копируем всю инфу из cart в order, и все строки заказа из cart_item в order_item.
Всё так? А почему здесь адрес клиента не добавляется в user? Зачем ему храниться и в cart и в order понятно: в корзине - чтобы клиенту показывать при перезаходе, а в ордер для сохранения инфы о заказе (мало ли, вдруг у клиента потом адрес сменится, а тут сохранится, куда старые заказы возили). Но если юзер потрёт куки или зайдёт с другого устройства, то ему придётся вводить адрес заново. Либо нужно делать на сайте постоянную проверку, чтобы в форму заказа автоматически подтягивались данные из последнего заказа, если он есть. но это дополнительные расходы производительности.
>>1889025 Эта таблица не окончательная истина, а только пример. Там многие моменты можно сделать по другому. >А почему здесь адрес клиента не добавляется в user? точно нет, это плохое решение. У тебя user только один, то есть ты всегда хранишь только один адрес. Нет ни истории доставок, ни выбора, ничего. Хотя бы я вынес в отдельную таблицу, типа buyer, с привязкой к юзеру и заказу, в которой хранил бы свойства покупателя. >Но если юзер потрёт куки или зайдёт с другого устройства ты мешаешь в одну кучу вопрос авторизации/идентификации пользователя и организации БД. Это принципиально разные вопросы. >но это дополнительные расходы производительности. не пытайся экономить один запрос кривой архитектурой.
А ещё бы я нахер выкинул из таблицы cart_item дублирование цены. Когда товар уже в заказе, у него ясен хрен цена не должна зависеть от оригинального товара. Но вот в корзине цена должна быть та же, что и в каталоге.
Достаточно наивно выглядит желание держать discount в товаре. Даже на самых примитивных проектах у меня система применения скидок разрасталась в достаточно ебовый сервис, при добавлении/удалении скидок пересчитывается каталог (желательно воркером). Там скорее хранится price_with_discount.
>>1889064 >У тебя user только один, то есть ты всегда хранишь только один адрес. Нет ни истории доставок, ни выбора, ничего. Эм, я же говорю "почему не добавляется"? То есть, понятно, зачем писать адрес в order и cart, но может стоит его добавить и в user?
И ещё, хранить всех юзеров в одной таблице, и клиентов и администраторов - это правильная практика? Не лучше ли выделить для авторизации администраторов отдельную таблицу?
> Но если юзер потрёт куки или зайдёт с другого устройства, то ему придётся вводить адрес заново.
Если он зарегистрирован, то можно сохранить адрес ему в профиль, привязанный к аккаунту. Если он не зарегистрирован, и специально потер куки, то адрес и корзина потеряется, тут ничего не поделать.
> И ещё, хранить всех юзеров в одной таблице, и клиентов и администраторов - это правильная практика? На практике делают и так, и так. Если хранить отдельно, то нужна отдельная страница для добавления/регистрации администраторов, и логин усложняется (надо проверять 2 таблицы).
Хочу стартануть в backend/devops (понять на практике к чему душа больше лежит), выбираю между пыхой, джавоскриптом и питоном, что лучше выбрать и почему?
Как освоить Ларавел? Тупо повторять за авторами курсов? Курсы в основном по старым версиям лары и у меня не получается самому адаптировать их под новые. Документация самого Ларавела? Я не понимаю её. То есть, я не понимаю, ни что там написано, ни зачем оно там написано.
>>1889305 >Хочу стартануть в backend/devops (понять на практике к чему душа больше лежит), выбираю между пыхой, джавоскриптом и питоном, что лучше выбрать и почему?
Питон - ебаное говно неудобное без задач. Ну по крайней мере джанго и бэк. Скрипты на нём я и сам иногда пишу, нраица, довольно урчу.
Посмотри в github всякие to-do list или appointment app, чтобы понять, что тебе ближе.
> пыхой, джавоскриптом
Не выбирай. Не конкуренты, а вполне дополняющие друг друга хуйни. Если делаешь бэк для SPA/Говна на электроне/Мобильного говна. Если делаешь API заглушку, тоже бесценно. Если надо какой-нибудь realtime app то нода лучше. Учи и то и то. Начни с пыхи, так как проще как по мне.
Потому что кодить не умеешь. Знаешь ли ты базы данных? Там хотя бы по минимуму, знаешь типы данных, чё такое нормализация, джойны там? Знаешь ли PHP? А OOP знаешь? А тесты чё такое знаешь?
А новые штуки-дрюки вроде неймспейсов или там трейтов? Laravel это ебучая экосистема где если ты ничего не знаешь, тебе её только сложнее понимать.
Напиши файлообменник на фреймворке slim из шапки треда.
>>1889776 А вообще, напиши сайт статейник на чистом пхп. С фронтом на jquery + bootstrap. Вообще на отъебись из стандартных классов. Можешь даже без ООП, но лучше с ООП. Просто рили набегают нубасы не знающие ничего в языке, и лезут сразу в фреймворк который написали не для нубов, а для хипстеров которые хотят экосистемку и чтоб всё искаропки
>>1889809 >Потому что кодить не умеешь. Два года работал веб разработчиком. Поэтому уж что-то я знаю. А вот английский - нет. И не понимаю, как освоить ларавел. Слим осваивать не буду. Просто потому что мне он не нужен. Мне ларавел нужен. Мне не нужно "понимать концепцию фреймворка" и вот это всё. Концепция и так понятна. Мне непноятно, как с ним вообще работать.
С тобой что-то не в порядке. Я не разбираюсь в Ларавеле, но открывал иногда документацию и там все довольно понятно описано. Если тебе это непонятно, то наверно ты берешься сразу за сложное, пропустив изучение более простых, базовых вещей.
Тебе надо знать ООП, MVC, DI, ActiveRecord, Query Builder, щаблонизаторы и другие подобные штуки прежде чем изучать сложный фреймворк вроде Ларавел.
Ну и без английского ... не знаю, как тогда читать документацию. Разве что примеры кода смотреть и догадываться, что они значат.
>>1890377 Не знаю англ, разобрался с ларавел +/-. На ютубе поглядел серию видео "пишем магаз на Ларавел". Доку читаю, то что не понимаю - перевожу транслейтом. На слим 4 собрал солянку из пакетов, с миграциями, логгером, контейнером зависимостей , ORM прослойкой и тому подобное. Корявая "чистая архитектура", со слоями и прочими адаптерами. Ни дня в коммерческой разработке. Хуле ты не можешь - я не понимаю.
>>1890878 кстати, помогите мне дураку - если ajax с клиента возвращает нихуя, тоесть сущность не существоуе - я должен вернуть какой код? 204, и без тела ответа? Или 200, а в теле ответа вернуть какой нибудь пустой массив?
Если тебе передали id несуществующей сущности, а функция должна вернуть ровно одну, то логично вернуть 404 - не найдено. Либо 200 и пустой массив, если это функция поиска, которая может вернуть много сущностей.
Код 204 для случаев, когда ответа в любом случае не ожидается. Например: отправка статистики на сервер.
>>1885723 >Сама сущность "статья" должна быть независима от реализации хранилища > В качестве прослойки к БД у меня eloquent Сразу забудь. Eloquent не позволяет сделать нормальные, независимые от фреймворка сущности. Он не для этого. Для этого нужна doctrine.
С доктриной просто без задней мысли создаешь сущность Article, пишешь в неё бизнес-логику, а потом доктриновскими аннотациями маппишь её в БД.
Парни в бэкэнд за 3+- месяца с пыхой вкатится можно, если дрочить его + html, css, docker, основная ос linux. Месяц учебы голой пыхи с тем, что выше, потом месяц+- свой простенький делать буду проект, после ларавел месяц дрочить тоже на рил задачах с сабжа. Норм тема Чи я даун?
>>1892015 нет, нельзя. Разве что у тебя уже есть большой опыт веб-разработки на других языках. Реалистичные сроки - от полугода, при дрочке по 6-8 часов в день. Но ты не осилишь. Забудь.
>>1892015 Нет конечно. Если б все так просто было... За 3 месяца максимум вордпресс освоить можно на уровне начинающего. Но этих макак уже столько, что по словам одного заказчика "когда я разместил заказ сайта на ВП, то мне чуть ли не в окно ломиться стали с предложениями".
>>1889305 Выбирай то, с чем тебе работать в том месте, куда тебя берут или могут взять.
Я могу в жабу и похапе или js. В питон не могу и не очень хочу, но если надо - буду. Похапе будет моим первым выбором. Все остальное - от безысходности. Если надо BDSM, то и на С могу написать.
>>1891545 Спасибо! А если такой вариант - ajax на сервен на обновление сущности. Варианты ответов три, какие статусы и заголовки должен вернуть сервер?: 1. Все успешно обновленно 2. Какая то ошибка на сервере, допустим что то в самом sql запросе сломалось 3. Условно на 5 миллисекунд раньше кто то удалил тот ресурс, который я хочу обновить - ( я еще не знаю что вернет в таком случае ORM - ошибку и ли просто пустой массив ) - какие заголовки и статусы ответа я дожен вернуть в этом случае?
>>1893354 Это кстати неоднозначный вопрос. Что работодатель хочет узнать? Загруженность и таким образом востребованность как спеца, или же ему просто нужно поскорее к работе приступить?
>>1892015 Конечно можно. Если у тебя хорошая логика, память и есть 12 часов времени ежедневно, то этого будет даже многовато. Не слушай тех, кто говорит что нельзя. Один мой знакомый вкатывался в HTML+CSS 2 месяца, так и не смог. Сам же за две недели с нуля смог сверстать страницу каталога интернет-магазина + разобрался с выводом карточек из массивов, сессией и авторизацией. Короче говоря, анон, просто пробуй
>>1893417 >просто нужно поскорее к работе приступить? this. Как правило галеры ищут людей "на вчера", лишь бы урвать здесь и сейчас заказ, а для этого им надо показать заказчику, что у них есть люди, готовые немедленно приступить. Кстати, этим их можно шантажировать и выбивать больше денег под выход "прям щас"
>>1893426 Здорово, только вот вывод картиночек из массивов с сессией и авторизацией учится за 2-3 дня. Это уровень даже не джуна, и не трейни, а хелловорлдщика. Где компостер, ооп, гит, базы данных и орм? Рано тебе ещё советы раздавать.
>>1894207 Ну это ты зря. Мы же не знаем с какого "нуля" он вкотывался. Может от до этого вообще компа не видел, а теперь вот сумел такое. Пара дней учиться, если ты до этого уже на чем-то котил, а теперь еще и похапе выучил.
>>1894523 Речь не о сложности, а про объемы. Человек вывел хелловорлд и считает, что за 3 месяца можно чего-то выучить. На самом же деле он ни верстку ни пхп не знает на нормальном уровне. Вся эта хрень требует довольно много времени на изучение и отработку практик. Нет - за 3 месяца ты не вкатишься в разработку. echo 'hello world' - не разработка и даже не близко чтобы можно было на этой базе прогнозировать какие-то сроки, тем более неизвестному анону.
>>1894523 Когда я писал хелловорды - я тоже так думал. Да хуле там. Эхо ебанул - вот и сайт. Так сейчас мой приятель думает - щас, три месяца и он для вордпресса будет модули на фрилансе писать, и маня мечты о 150, в условном мухосранске.
А сейчас я пишу свое первое приложение, которое уже используют, к счастью я работаю в госшараге, и имею кучу времени, вот надрочился и взял проект. И его нужно сделать как хотят заказчики, а не как я, и сделать по максимуму хорошо. И как же меня все это ебет в голову - это пиздец. Я уже его два раза переписал - крайний вариант это моя всратая реалзация "чистая архитектура". Много асинхронного JS на клиенте. Миллиард деталей, и постоянно что то не работает, постоянно туплю и буксую. Короче нихуя это не просто, если делать хоть как то приближенное к реальности.
>>1894765 п.с. Вот сейчас, поняв уже что я реально, пусть всрато и медлено - но могу полноценно писать - я решил прям на дисциплине тащить. Я в течении моего вкатывания больше всего проебывал времени по причине недисциплинированности, и отсутствия цели. И считаю что это основной враг любого человека, который хочет развития. Неделю делаешь, потом на неделю забиваешь, потом снова начинаешь, вспоминаешь то что забыл, чет делаешь - забиваешь, и так по кругу. Временную линию обучения это вытягивает в бесконечность. Плюс паралельно копротивлялся с питоном, разобрался в node.js, в ней в сущности все то что пишу на пхп - смогу реализовать. Но это копротивление было в том же стиле что и с пхп ,и по итогу к пхп мог вернуться через три месяца. Но вот последние пару месяцев я сконцентрировался и прям подрос по скилу. Прогинг - эта хуйня которая требует определенной интенсивности, и жесткой дисциплины. Иначе просто забываешь все нахуй.
Вы люди такие наивные. Вы никогда не научитесь делать сайты или мобильные приложения. Максимум на что вы, обычные люди, способны -это десктопные приложения на Си или Джаве. Это грустно, но вы должны принять этот факт и прекратить тратить время, пытаясь стать веб разработчиком.
>>1894765 Что за стек? Ну вообще да, на проект всегда надо много времени и денег. И лучше поэтому расписывать на таски и время на таску, как все делают, по кирпичикам строить, планировать, тестировать каждую таску. Обязательно использовать гит и делать ревью хотя бы для себя. И заказчик видит за что платит и тебе видно всё.
>>1894765 >три месяца и он для вордпресса будет модули на фрилансе писать, и маня мечты о 150, в условном мухосранске Классика - сразу видно нуба. 1. Не 3 месяца, а минимум год. 2. На фрилансе модули редко пишут - обычно говно разгребают чужое в стиле: человек навасянил сайт на вордпрессе из палок и взломанных плагинов, а тот у него закономерно завалился и отдаёт чистую страницу, и он идёт на фриланс чтоб починили за 500. Срочно! там специалисту на 15 минут работы же! 3. На СНГшных биржах ты даже 30к в месяц не поимеешь - там нищеброды одни. Нормальные заказы бывают, но 1 на 100 где-то.
Скажи ему что если хочет зарабатывать через фриланс - пусть не суётся на русскоговорящие биржи и сразу учит англ. Иначе заебётся даже на дошик зарабатывать.
>>1892015 Когда ты вкатишься - последнее, что должно тебя волновать. Будешь учиться и стараться - вкатишься. Ты хотя бы попробуй твоё это или нет, а то собрался вкатываться)
>>1895730 Ну нуб нато и нуб, что бы не видеть сложностей. Да пусть уж хоть как то учится. Пусть платят мало - ему и 30 в месяц нормально будет. У него есть работа, надрочится хотя бы 10 в месяц дополнительно поднимать - будет легче жить. Сам я с ларавелем пердолюсь.
>>1896051 Хм, спасибо, даже не знал о ней. Нужно почитать внимательнее, все таки сама по себе идея CMS - не так уж плоха. Потому что быстро развернуть какое то шаблонное решение - не так уж плохо. А архитектура основных пхп-CMS настолько дегенеративна, что тут смотреть невозможно. В вордпрессе как то дико устролено все - буквально из трех таблиц собирается где в кучу все подряд, смотрел как то. А эта October CMS на ларе собрана. Хотя глобально ларавел тоже сборник условно "антипаттернов", но это паттерны, хоть и "анти". Архитектура есть, и над ней нужно думать.
Пчелы, а вы отмечаете как-нибудь в моделях связанные с ними тригеры и функции в БД? Есть какой нибудь стандарт или принятый формат комментов для этого? Я ни на одном проекте ничего подобного не видел, хотя было бы просто пиздец как удобно.
>>1896051 Как-то смотрел октобер, что-т не врубился в чём прикол его юзать) Хочу друпал попробовать как-нибудь, мне как симфонисту может интересно будет
>>1896674 >не врубился в чём прикол его юзать Ускорят создание сайтов и приложений. Готовая админка + уже написанный кем-то функционал в виде плагинов. Это преимущества любой CMS.
>друпал Пробовал, но он мне в админке дико перегруженным показался.
>>1894765 Дополню - как же меня заебал клиентский жава-скрипт. Я хз как его пишут скилловые чуваки, и как организуют код. Я пишу как могу, и пишу на классах. Типа класс "ФормаНейм" - у класса в конструкторе я через какой нибудь getElementById() получаю DOM-елемент формы, и уже в рамках класса "ФормаНейм" пердолюсь с хтмл, вешаю/снимаю обработчики, создаю/уничтожаю какие то элементы или уведомления, отправляю к серверу ajax и получаю обратно данные. Норм подход? А то буквально пару элементов вывожу/убираю, с формы собираю JS-ом данные , и на нескольких кнопках ajax запросы - а получается какая то ебаная портянка. Единственное я все это динамическое щастье на клиенте отрисовываю с помощью JS шаблонизатора Handlebars. Отдавать пхп шаблоны, что бы на клиенте тоже рендерить шаблоны, охуеть. Но без этого я насмерть охуею от создавание элементов через js и заполнения их атрибутами и прочим говном. Уже хочу все по файлам раскидать, и вэбпаком + бабель собирать на фронт. В js тред непойду там в нативный js полтора человека умеют. Охуеваю децл
>>1896928 п.с. Если дрочить DOM-элементы в рамках класса то раздражает что в обработчиках событий теряется контекст класса, приходится изголяться с стрелочными методами класса, и опять же иногда требуется передать в обработчик события какие то параметры. Короче задрочка.
>>1896928 >получается какая то ебаная портянка На простых задачах нефиг классы с шаблонизаторами городить. Поэтому и портянка. Получил элемент в переменную - указал ему нужные свойства и обрабработчики, и всё.
Или ты там везде микросервисы делаешь - чтоб отдельно бек, отдельно фронт работали? Так вот спешу уведомить тебя, что на небольших приложениях, которые делает один человек это дикий оверхед и ненужная хуйня.
>>1896928 Возьми вьюжс и не пердолься, я не могу понять почему кто-то НЕ использует вью или реакт или что угодно но не чистый жс. Ты сам себя загоняешь в рамки по времени, по качеству и расширяемости кода. Я назвал вью потому что его можно крутить как угодно, хранить шаблоны прямо в жсе, или рендерить на уровне пхп
>>1897292 >>1897007 >>я не могу понять почему кто-то НЕ использует вью или реакт Да бладж, и не говори, лучше бы сразу на реакте писал - я его немного знаю. SPA не напишу, но компоненты написать могу. Эта ебля с DOM-элементами меня огорчает. Один хуй тот же жеквери бутстрап требует.
Почему авторизация не работает? Точнее она работает и даёт положительный результат, при любом логине и пароле, а надо, чтобы она проверяла есть ли такая запись в бд.
>>1896605 >тригеры и функции в БД >Я ни на одном проекте ничего подобного не видел
Я вообще ни в одном проекте не виде, чтоб кто то использовал триггеры, встроенные процедуры и прочее.
Таким народ баловался в начале 2000х, и подход был признан жутко неудачным. Если ты так будешь делать, то закончишь с проектом, где половина логики будет написана PHP кодом, а другая половина SQLем встроенных процедур. Это будет просто безумная лапша, где никто ничё понять не сможет. Не делайте так.
Всем привет, давно сюда не заходил! Помогите советом, есть ли смысл использовать Docker контейнеры для MySQL и Symfony для небольшого проекта, ios приложение - тематический календарь. Только выложили приложение в эплстор, нужно настроить dev сервер, до этого был только prod и локальный. Будут ли плюсы, если обернуть бд и апи в контейнеры, или только заморочек с настройкой добавится? И потянет ли vps на kvm (2 ядра shared, 2 гига памяти) докер?
У тебя $result хранит информацию о том, успешно выполнен SQL-запрос (независимо от того, найден пользователь или не найден - любой вариант считается успешным), или же в нем есть какая-то ошибка.
Тебе надо проверять не $result, а вытягивать их БД результат, функциями вроде mysqli_fetch_assoc.
>>1898861 >Будут ли плюсы, если обернуть бд и апи в контейнеры по моему опыту, для небольшого приложения ты только поимеешь кучу геморроя с нулевым профитом.
>>1899558 >Wordpress 80% заказов на нём - безденежные днари. Как и 80% сайтов на нём - говно говна непонятно зачем сделанное школьником\домохозяйкой, либо откровенно мусорные сайты под чёрное сео.
>Bitrix Много посредников и хитрожопых, считающих, что фрилансер будет делать за 2-3к то, за что в "сертифицированной" студии возьмут от 15к. Если будешь на нём работать, то не демпингуй - если есть деньги на Битрикс, то и на работу 15к найдутся. Алсо код внутри у него говняный.
>modx Многого о нём не знаю, но слышал, что медленно уходит в прошлое.
>>1899658 - попробуй сконфигурить nginx + php-fpm так, чтобы они работали в разных контейнерах. Несмотря на то, что, вообще то nginx`у нафиг не нужны php файлы - тебе всё равно придётся примаунтить папку с проектом к контейнеру с nginx`ом. Причём пути маунта должны точно совпадать с тем, как код примаунчен к контейнеру с php-fpm. Это выглядит как костыль, и им, по сути, и является. - если у тебя сложное приложение на symfony, в котором есть консольные, постоянно работающие event-consumer`ы - деплой превращается в какую то клоунаду. Само собой, консюмеры должны работать в отдельных конейнерах, ради масштабирования. Иначе в чём смысл этого вашего докера? В итоге простая очистка кеша превращается в ёбаный цирк: Остановить все контейнеры, кроме одного. В единственном контейнере запустить cache:clear. Заново стартовать. Аналогичное относится и к composer install. - указанные выше консюмеры должны запускаться после rabbit`а. Хоть докер и умеет запускать контейнеры в определенном порядке, но он следит за фактом запуска контейнера, а не за фактом запуска сервиса (того же rabbitа) внутри контейнера. В итоге консюмеры, стартующие раньше rabbitа были обычным делом. Приходилось руками писать код, решающий эту проблему. Вот нахер мне это надо? - postgres в контейнере работает так, что лучше бы вообще не работал. Наверное я где то недоразобрался, но если пытаться хранить данные постгреса в примаунченной папке - то периодически данные корраптятся и приходят в негодность. От нахер мне это нужно на проде? Мне делать больше нечего, как разбираться сутками, какого хрена там БД портится? А потом восттанавливать её из бекапов? - при апдейтах контенйеров всё время вылазила какая то проблема с внутридокеровской TCP\IP сеткой. Не помню что там точно было, но из за этой хрени деплой постоянно падал.
Как следует натрахавшись со всем вышеперечисленным на stage - прод я уже разворачивал на голом железе. Просто небо и земля - если на stage я постоянно руками дрочил деплой, ибо авто-деплой через CI постоянно заедал - на проде с той же CI не было ни единого разрыва.
>>1899681 Чет притензии твои скорее к тебе самому, чем к докеру.
>Несмотря на то, что, вообще то nginx`у нафиг не нужны php файлы - тебе всё равно придётся примаунтить папку с проектом к контейнеру с nginx`ом Про nginx вообще хуйню написал. Если у тебя в конфиге написано try_files, то ясен хуй ему будут нужны файлы. Не лезь в nginx'е к файлам проекта и монтировать ничего не придется.
>простая очистка кеша превращается в ёбаный цирк: Остановить все контейнеры, кроме одного. В единственном контейнере запустить cache:clear То есть ты использовал для, по сути отдельных серверов приложений, общий файловый кэш. И обвинил в этом докер. Ты хоть на секунду задумывался как это работает без докера? Типа как работает кэш, если запустить два воркера на одном сервере. Или каждый на отдельном.
>указанные выше консюмеры должны запускаться после rabbit`а. Хоть докер и умеет запускать контейнеры в определенном порядке, но он следит за фактом запуска контейнера, а не за фактом запуска сервиса С рэббитом тоже какие притензии к докеру? Тебе и без докера нужно написать скрипт, который будет определять порядок запуска. И один хуй придется написать healthcheck, чтобы убедиться что рэббит уже готов принимать запросы и можно стартовать остальное.
>postgres в контейнере работает так, что лучше бы вообще не работал. периодически данные корраптятся и приходят в негодность >при апдейтах контенйеров всё время вылазила какая то проблема с внутридокеровской TCP\IP сеткой Вот это серьезные претензии. Я бы даже сказал неправдоподобно серьезные. Можно просто нахуй вычеркнуть все что ты написал и оставить только: "Докер рандомно корраптит вашу базу на продакшене". И этого было бы достаточно чтобы никто и никогда не использовал такой кусок говна на проде. Все. Сворачивайте свои ебаные облака с кубернетисами, это говно не работает.
>>1899971 >Чет притензии твои скорее к тебе самому, чем к докеру. А я и не спорю, мои познания в докере весьма поверхностны. Но тут возникает вопрос - если в дополнению к докеру на любой мало-мальско сложный проект надо нанимать девопса за тыщи баксов - нахрена всё это надо? Нахера, если на голом железе с настройкой проекта справится любой админ с минимальным знанием линукса+субд.
>>1899971 >Если у тебя в конфиге написано try_files, то ясен хуй ему будут нужны файлы. Ану, можешь привести пример конфига nginx в связке с php-fpm так, чтобы nginx`у вообще не нужен был доступ к PHP файлам?
>>1900035 А где в предыдущем посте "познания в докере"? Там есть инсайт про то что докер как софт в принципе не работает. И то как по мне очень спорное заявление.
Ты опять все ставишь с ног на голову. Докер это последний этап подготовки окружения - упаковка. Распределенная асинхронная система это сложно. Я могу помимо рофла с кэшем сходу назвать штук пять проблем, которые могут привести к пиздецу похуже чем временная остановка всех воркеров на пятиминутные техработы.
Сначала проектируется система, потом подготавливается окружение, а потом готовый результат упаковывается в контейнер. Ты никак не избежишь работы девопса. С докером или без, но нужные команды все равно будут написаны. А чтобы упаковать результат работы PhD не надо.
>>1900073 >Распределенная асинхронная система это сложно. Йоу, вас куда то в космос архитектуры уносит. Ты на начало обсуждения посмотри: > есть ли смысл использовать Docker контейнеры для MySQL и Symfony для небольшого проекта >для небольшого проекта а ты тут рассказываешь, как на монстроузном проекте надо распределённые асинхронные системы проектировать. И девопса ещё, ага. На проект из 3 человек.
>>1898788 >Я вообще ни в одном проекте не виде, чтоб кто то использовал триггеры, встроенные процедуры и прочее. Есть сейчас такое на одном проекте, десктоп приложение раньше могло прямыми запросами к бд обращаться (и до сих пор иногда может, лол). Хз зачем, походу еще до времени когда апи не прикрутили. Вот я и думал эти триггеры ради удобства как нибудь в моделях отметить. Плюс на хабре недавно высрали пачку статеек, где чуваки хвалились переносом логики в БД и рассказывали, как им теперь жить стало лучше. Хотя не могу представить, как они этот код поддерживать будут.
>>1900301 Думаю потому, что в некоторых Б-гомерзких языках не надо ставить $ перед именем переменной и так проще отличить имя класса от переменной. User user = new User("user");
Правда в кошерном php можно и наоборот сделать. $User = new user("user"); Но лучше не надо.
>>1900301>>1900397 А еще бывает было такое iXyuta, cXyuta, dXyuta, и судя по тому, что кто-то очень хочет типизации в няшном php, мы и до такого дожить можем.
>>1900933 еще >As of MySQL 8.0.17, the nonstandard FLOAT(M,D) and DOUBLE(M,D) syntax is deprecated and you should expect support for it to be removed in a future version of MySQL. а как тогда надо?
Или делай это сам в том месте, где ты сохраняешь свои данные. Типа ..UPDATE ... " . date('Y-m-d H:i:s') , "... Но ты опять же не написал, то ты юзаешь.
>>1900944 mysql CREATE TABLE t1 ( бла-бла 1колонка бла-бла 2 колонка ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, dt DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP ); так? а когда вводить данные где value для 3 и 4 колонки че писать?
>>1901359 >апач в сборке читай внимательно Я читал, написано Устанавливать Apache, PHP, MySQL лучше всего самому, так как при этом ты получишь ценные знания, а сборки лучше не использовать.
Я сделал функцию для сброса выбранного пользователя, она должна срабатывать при нажатии на ссылку с надписью "Выйти", но она не работает и страница не может забыть нынешнего выбранного пользователя. Чувствую, что легко решить.
>>1901541 В зависимости от буквы в конце умножает число байт на 1024, чтобы получить именно число байт. Там нет брейка, потому операции проводят начиная с самой первой.
onclick указывает на javascript функцию, а clearUser() у тебя в php Можешь сделать так, чтобы href вёл на php скрипт, который разлогинивает пользователя и потом перенаправляет куда надо
>>1901515 >тогда ставь на линукс Там так не написано. Там только было написано Устанавливать Apache, PHP, MySQL лучше всего самому, так как при этом ты получишь ценные знания, а сборки лучше не использовать.
>>1901576 Это я прохожу курс Игоря Борисова по php, лабораторная работа, 2015 год, скачал на рутрекере Спасибо, теперь более понятно как это умножение работает!
>>1901515 >>1901593 З.Ы. А вообще хоть в уроках и предполагается Apache установленный на Windows. Но GNU/LInix все-равно придется осваивать. Буду ковырять. Но потом, разу уж в уроках предусмотрена Windows.
>>1901586 >>1901587 Что-то ничего не работает. Попробовал поставить href="index.php?clear_user=1" - не работает(ноль изменений). Создал отдельный файл clearUser.php и написал там <?php session_unset($_SESSION['user']); ?> - после чего поставил на этот файл ссылку в той кнопке на которую я нажимаю, но снова ноль эффекта. Как же так? Неужели на этом моя карьера php программиста закончена?
>>1901613 >Что с английским? Все очень плохо. Я на русском языке двигаюсь чисто. Но сейчас 2к21 год на джворе. По пыхе дохуища материала на русском языке.
>>1901635 >Все очень плохо Если честно я вообще не понимаю как можно пытаться заниматься программированием, не зная английский. Даже мне, человеку который знает английский, очень тяжело продвигаться по карьере программиста, но я не могу представить как тяжело людям, не знающим английский.
>>1901646 ЛОЛ нет. Я просто пытаюсь хотя сделать свою первую страницу. Я вас уверяю: Web программирование >>>>>>>>>>>> изучение английского, в плане сложности.
>>1901658 > Я просто пытаюсь хотя сделать свою первую страницу. Но ты же сказал, что ты с трудом по карьере программиста двигаешься. Ты смеешься надо мной как казахи и кабардинцы над Джиганом.
>>1901615 >Неужели на этом моя карьера php программиста закончена? Не исключено, но не обязательно. Я же смог.
Смотри. У тебя есть "Сессия". Это такое хранилище и оно на сервере.
В браузере ее содержание (обычно. мы тут не про сокет.ио и прочие рокеты говорим) узнают только тогда, когда с сервера приходит новая страница.
Значит тебе нужно: 1. Получить страницу с результатом в броузер 2. Послать на сервер новые данные 3. ГОТО 1
Попробуй сперва без кнопок сделать три файла: 1. display.php <?php var_dump($_SESSION)
2. da.php <?php $_SESSION['xyuta'] = 'DA';
3. net.php <?php $_SESSION['xyuta'] = 'NIYET';
Теперь попробуй повызывать их по очереди и посмотреть на результат. Например сперва display.php потом da.php потом disply.php потом net.php и снова display.php
ЗЫ. Я исхожу из того, что сессию ты запустил и прочее.
Искать готовые проекты, которые можно поковырять и поразбирать, лучше всего на гитхабе, или есть какие-то отдельные популярные площадки, которые вы можете посоветовать? При гуглении глаза разбегаются, не знаешь, за какой сайт первым хвататься.
В PHP для генерации HTML-кода используются шаблоны. Я бы советовал кроме основ PHP, еще изучить синтаксис шаблонизатора twig, например. Тогда ты сможешь внедрять свою верстку в проект на Симфони. Ну или изучи шаблонизатор blade, чтобы внедрять верстку в Ларавель.
В session_unset судя по документации, ничего не надо передавать. В атрибуте onclick указывается не PHP-код, а яваскрипт-код. Яваскрипт - это язык, на котором можно написать программу, которая будет выполняться в браузере. То есть у тебя он будет пытаться вызвать функцию clearUser() в яваскрипт-программе (а не в PHP).
>>1901593 Линукс ты обязан знать минимум на уровне пользователя, юный падаван - на нём почти весь веб работает. И мало-ли чего в шапке не написали - всего не упомнишь.
>>1902909 У меня на пеке винда. Теперь вторую операционную систему GNU/Linux хочу на пеку поставить. А что лучше поставить Ubuntu desktop или Ubuntu server?
Не совсем по теме - посоветуйте, пожалуйста, окружение раб стола для линукса, чтобы и красивенько и не сильно нагружало. Крыса не заходит В кедах долго грузится все Гном - то еще говно. Юнити - охрененная, но она не поддерживается больше, авось что не ВК вставать будет
>>1903206 Mate выглядит не очень, вообще её прикола не понял, как оболочки, если честно. Cinnamont выглядит страшно + как я понимаю он только на линус минт, а мне бы ток убунту или манджаро (но там пакет пэкмэн ебанутый, не хочу с ним париться ..) LXQT - это разве не ещё более страшно, чем крыса?
Какая-то странная херня. Я скачал файл css с инета, написал ссылку на него в файле index и всë работает. Проблема в том, что сайт не реагирует на любые изменения этого css файла (более того, даже если этот файл удалить, то сайт НИКАК не изменится, но если убрать ссылку на css из файла index, то он потеряет стили). Сайт как бы запомнил css файл и не принимает любые изменения, даже полное его удаление. Кто-нибудь встречался с подобным или это у меня одного?
>>1903909 Да, я всë обновлял и css и index. Такое чувство, что есть какая-то призрачная копия css, которую я не вижу, а тот файл, что я вижу и редактирую - это лишь пустышка. Жуткая срань.
>>1903901 Попробуй подгружать css с гет параметром, например "cache=123" и меняй его каждый раз, когда ты меняешь что-то в css. <link href="style.css?cache=1" title="makaba" type="text/css" rel="stylesheet">
Или href="style.css?cache=<?php echo time(); ?>" если тебе лень менять параметр.
Учу Python несколько месяцев, хочу на фрилансе сайты делать. Недавно узнал что на фрилансе деньги только в PHP. Правда? Стоит ли браться за изучение PHP, он проще? Или и дальше Django пытаться освоить? (Все упирается в деньги, хочу поскорее начать зарабатывать.)
>>1904522 Ну не только на PHP но всяко лучше чем с питоном(ибо все что угодно больше чем ноль) Если надо только деньги то php куда лучше конечно(но лучше ищи по началу работу в офисе, хотя можешь конечно попробывать фрилинс, но на многое не надейся)
Нашел русскую документацию по Слиму https://slimframework.ru/v4 Но у меня возникают большие сомнения в качестве перевода, написано все не совсем понятно. Мне кажется что уже проще читать оригинал, со своим плохим знанием английского и переводчиком.
>>1905015 >Мне кажется что уже проще читать оригинал this. Чувак, если ты хочешь профессионально заниматься программированием - то от чтения доков на английском тебе вообще никак не уйти. Без этого ты просто не сможешь работать. Так что привыкай сразу. Учи английский. На первых порах - google translate в помощь.
>>1905376 Да. Так же как и пхп говно среди языков WordPress говно от мира cms но он на самом деле уебищен Yii говно от мира фреймворков а по факту - ставишь и смотришь. если нравится - юзаешь, не нравится - пишешь о том какой он ущербный на дващах
>>1905384 Единственное что могу сказать - попробуй сделать гостевую книгу на yii2, симфони и ларавеле. С небольшой админкой модерацией комментов. Здесь у тебя и формы и модели, авторизация и миграции. И уже выбери. Но Яб советовал либо симфу либо Лару. Говноконторы их чуть реже выбирают >>1905386 Кто сейчас в лидерах? Js?
Начал изучать ларавель. Hасколько часто ИРЛ используются такие вещи как Breeze, Jetstream, Livewire и прочие приколы из экосистемы? Просто хочу понимать, стоит ли потратить время на их осмотр, или же это все херня на самоподдуве от разрабов.
Неужели люди до сих пор думают, что эти "задачи" как-то помогут им в изучении языка? Я вижу столько постов здесь про мусор вроде "Помогите решить задачку где надо посчитать бла-бла-бла". Если вы до сих пор страдаете этой херней, вы никогда не станете программистом. Вы должны сначала изучить базовый синтаксис, после чего практиковаться, делая что-то связанное с непосредственной сферой деятельности, а не решать задачки для имбецилов.
Посоны, норм ли книга для старта "Изучаем PHP и MySQL" от Орелли? Знания у меня какие-никакие есть всё же, могу на Django сайт состряпать и не плохо знаю чистую Java, к Spring не притрагивался.
>>1905944 Вроде неплохо получается. Особенно мне вот это место понравилось "[летюн]{1,2}". Хорошо зделол. Только я не понел зойчем {1,2}? По одной же букве достаточно определять.
Из доёбок могу только к той, что уже была выше, предложить проверить твоей проверялкой предложение "Он разделал труп и выкинул в Неву.".
> зойчем {1,2} Чтобы слово целиком выделялось. Допустим, есть два слова "зделал, "зделает". Если мы убираем {1,2}, то второе слово выделится [зделае]т
> проверить "Он разделал труп и выкинул в Неву." Чекнул щас, выдало ошибку, пофиксил добавлением границы /\bздела[летюн]/ui И еще один косяк нашел в fixGrammar, preg_replace же null возвращает только в случае ошибки, поэтому там проверка априори бесполезна
Кому не лень, не могу найти инфу на счет того как в ларавеле обработать <select> в форме. Пишу $newItem->category = $req->input('category'); , но работает это только для инпутов как я понимаю, так же $newItem->category = $req->get('category'); не работает
>>1905832 >Вы должны сначала изучить базовый синтаксис Дык для этого задачки и нужны. Ты не запомнишь синтаксиса, если просто прочтешь учебник. Нужно ручками его набирать.
Для меня пока самое неприятное в веб девелопменте - это то, что у html нет переменных. Я просто хочу взять с помощью php данные из БД и передать эти данные в переменную html, но насколько мне известно у html нет переменных, поэтому приходится делать какую-то безумную конструкцию, где 2 языка скрещиваются и может быть оно заработает. А вы что думаете, джентльмены?
>>1849078 (OP) Знатоки, пожалуйста, помогите советом кто может. Есть цель создать маленькую веб-библиотеку для своих. Планируется хранить в библиотеке книги в формате pdf, epub, fb2, mobi и т.д. Хочу сделать там форму загрузки, где можно указать аннотацию, название, автора и т.п. а также загрзуть обложку и собственно сам файл с книгой. Тут встаёт вопрос как правильно всё хранить чтобы было не стыдно и всё работало? В гугле говорят что если файлов не много то можно хранить в базе данных. Но файлы там хранятся в двоичном формате. Пожалуйста подскажите урок где показанно как правильно делать загрузку файлов и самое главное как их оттуда вытаскивать. Хочется чтобы на странице с книгой помимо данных о книге отоброжалась обложка как картинка и была кнопка скачать которая бы собственно давала прямую ссыль для скачки книги. Заранее всех благодарю.
До меня правда так и не дошло с этими регулярными утверждениями, как надо было сделать, чтобы preg_split не закидывал в массив точки и etc, если их подряд несколько
Ебаный клиентский JS, я прочувствовал эту боль. Как пишешь что то сложнее alert('hello word') , все превращается в говно нечитаемое. Сука, следующаю часть я уже соберу вэбпаком. И раскидаю классы по файлам, как положено. Это невыносимо...
Есть тут те, кто работает уже? Работал почти три года в мухосранской конторе, где нет процесса разработки вообще. Про докер не слышали, пушат в мастер ветку на гите с ебанутыми комментариями типа "соси". ci/cd нет, говнокод в контроллерах и 0 тестов. Щас вообще работы нет тупо сидим чилим. Ни одного синьера, все блять джуны, которые ебашут закрыв глаза, но проекты работают и вроде как денюжку даже приносят, а то бы не держали. Вопрос в тащем та такой, сложно ли мне будет найти норм работку, а то заебало уже сидеть в говне и зарабатывать копейки(25к в серую) Про solid слышал, постоянно дрочу курсы Елисеева и пишу петы, короче стараюсь. Докер тоже ковыряю. Бля помогите советом, как нахуй вылезти из этого болота. Яж даже пул реквесты никогда не далал, боюсь напизжю на собесе и обосрусь потом
Лел, чет проиграл. Нужно твой пост скинуть моему одному знакомому, который начал учить похапе с ноля, и через уже 2.5 месяца хочет вкатиться в разработку на вордпрессе. Пока что влажно мечтает от 150 тыщах. тоже мухосранск точнее почти мухосранск, город с курортной спецификой
>>1907292 >Яж даже пул реквесты никогда не далал, боюсь напизжю на собесе и обосрусь потом Неправильно информацию подаёшь. Надо этот беспредел в подвиг определить - дескать ушёл с прошлого места потому, что тут даж пул-реквесты не делают, и тебе расти некуда как специалисту. Тебя ещё в жопу поцелуют за такое.
>>1907428 Собственно он мой приятель, и он хороший человек. Но он прям типичный вайтишник, своя карьера у него не сложилась нихуя. Прогинг ему не особо нравится, и единственное зачем лезет - поднять бабла. Это прям идея фикс. И поэтому все разговоры о программировани - в русле зарплат. Серебрянная пуля которая из нищего неудачника сделает успешного человека которому все завидуют. Ага. Начитался всякой мотивационной хуиты. Но мож ему прогинг реально зайдет - тогда поглядим как сложится.
>>1907433 Ага, а потом, когда устроюсь, ебану пуш форс с коммитом "сасай лалка". Меня же в первый же день вычислят и выпрут. Бля, три года коту под хвост, какое же я чмо...
>>1907441 >ебану пуш форс с коммитом "сасай лалка" Тебе объяснят как у них принято, если ты их в известность поставишь как я написал выше. Опять же - ты об этом в курсе, а значит очень сильно не накосячишь. Хуиту обычно от незнания и непонимания творят.
>>1907292 Помню тестовое делал, результат работы которого просили прислать по почте. Рофлил с них и делал. Потом пытался отправить, но гугл проверил архив и возмущался на типы файлов, и не отправлял их. Я взоржал и скинул им через гугл-диск по ссылке. Они так и не ответили позже.
>>1907448 Найти бы еще компанию, которая возьмет на работу такого бездаря. Даже на собесы идти страшно, хотя после универа еще глаза горели и были норм офферы, а щас тупо сам себе мозги ебу каждый день и этобудет заметно, скорее всего, на собесе
>>1907478 Если правду пишешь - то ты просто далбоеб и пример человека который в жопе находится только от того что инертный и пассивный овощ. Люди, которые предприимчивые, на такой хуйне умудряются зарабатывать что диву даешься. А ты, в наше время, прогер с опытом, лол блядь. Твои посты опять же доказывают что самое главное в человеке - го личность. Что предприимчивость и активность важнее любого склила
>>1907501 п.с. Чувак, совет даю - ливай вникуда. Ты явно по жизни овощ ебаный, а значит измениться сможешь только если тебя жизнь начнет заставлять. А то так и будешь сидеть
>>1907434 В отличии от него для меня в программировании деньги - второстепенное. Окончил профильный вуз и устроился на работу. Работу выбирал по принципу нравиться/не нравиться сам продукт. Начальник смог красиво мне это продать и вот я уже 3 года завис на уровне трейни, даже не джуна. Хотел бы устроиться куда-нибудь в badoo, но такого великовозрастного дебила уже не возьмут туда. Знал бы, что так все обернется, не веслал бы за 25к, а устроился сразу с норм зп(хоть какой то профит с этого получил бы)
>>1907527 Сейчас уже да. Хочу развиваться, скорее всего поступлю так, как написал анон выше. Уволюсь вникуда и все, чтобы заставить себя искать другую работу, а не сидеть и ныть о том, какой я плохой...
Не, ну 25к за работу с кодом это, конечно, днище. Даже в моей мухосрани зарплата макаки на опенкарте от 30к начинается, а там фактически только плагины накатывать надо и темы.
Пачаны, вопрос про CDN. Где-то видел, что советовали выгружать все либы локально из сети, а тут статейки почитал где говорят, что наоборот надо - получать их из сети мне так тоже кажется. Может я не учёл какие-то нюансы? Как принято делать в норме для небольшого сайта в контесте "поднять скорость загрузки"?
>>1907669 >мухосраньская говноконтора А чем ты там занимался? Не могло статься так, что тебя перепродавали раз, так, в 10 дороже? Ещё инфу слышал, что многие жирные корпорации на аутсорс отдают работу именно вот таким вот "мухосраньским говноконторам".
Господа, ходил около веба долгое время, решая смежные задачи. Решил залезть на бэк, решил учить php, решил. Такой вопрос, вот я сейчас читаю "php, js, mySQL", книжка топ, оче широка, но поверхностна. Ещё глушит по голове объяснениями переменных на спичечных коробках, и тому подобным. Классно для начинающих, наверно, но нагоняет на меня скуку. Плюс пхп там какой-то не такой: старый, дремучий, плюсы не торчат наружу. Как учить современный пхп, заделитесь курсами и книгами пожалуйста. Эту книгу я дочитаю энивей, так что буду рад книгам для уже знающих. Хочу по итогу (ну, как цель) стать жёстким фуллстек челиком, код которого (на php в частности) висит в Лувре. С меня лучи добра в вашу сторону, снижающие дефицит D3 в организме.
>>1907695 Короче тебя наебывали три года, прими это. Есть у меня в кентах есть люди, такие как тот кабанчик на которого ты пашешь. Там логика простая максимально - плати работникам как можно меньше, а с заказчиков греби как можно больше. Покупай крузак. Есть девченка знакомая sql разраб, уже лет 7-8 работает в конторе на одного чувака. ЗП - 40 тыщ рублей. И все остальные столько же получают. Так еще тип этот - манипулятор пиздец какой. За резюме на hh истерики закатывает, мол мы "семья". Сам при этом двух-этажную хату купил. Короче чувак, отращивай зубы скорее.
>>1908056 Ну про "мы семья" я слышал и не раз. Просто прикол в том, что я получается теперь говнокодер, который норм разработку и не видел. Сложно будет на работку устроится вот и боюсь сижу отсюда сваливать, хоть и решил уже, что уволюсь.
>>1908057 Есть у меня такое ощущение что если ты не в условно гугле/яндексе - то перестать быть говнокодером ты сможешь только на личной тяге. Ожидать что кто то возьмется с нисхуя и тебя учить начнет - очень инфантильно. Ты просто ответственность перекладываешь. Опять же сам обдумай постановку задачи - сидишь ты такой работаешь, и вот вы берете парня, а он - ну я плохо знаю, меня подучить нужно. Как сам к такому отнесешься? А с другой стороны приходит тип - и заявляет, я тут в своих проектах Action-Domain-Responder навасянил, и по слоям разбил как смог. Понятно что через жопу, дайте посмотрю как у вас сделано. Совсем другой коленкор же. Так что делай все сам. Накопи денег на пару месяцев жизни, ну а дальше ищи удаленку, попутно ищи фриланс. На ларе его не мало. Я тебе скажу что стагнация - штука липкая, ты обернуться не успеешь, а полгода пройдет, и ты все там же и на том же месте. Я просто такое проходил. Пока прям копытом не стучишь, и не действуешь - нихуя не меняется.
>>1908167 И что, а на джаву еще больше, я к тому, что если в мухосрани кроме пыхи ничего нет, то тут у меня выбор аж глаза разбегаются. >>1908168 Альтернативы думаю про ноду или питон сейчас, еще go все вокруг обсуждают.
>он - ну я плохо знаю, меня подучить нужно. Как сам к такому отнесешься?
Да, в таком ключе это даже звучит по тупому, чет я об этом даже и не думал. В общем, все понятно, надо брать себя в руки и ебашить, как в старые добрые, а то рили так и останусь в этой конторке. Еще раз спасибо, анон.
>>1908211 >думаю про ноду или питон сейчас, еще go все вокруг обсуждают Очередной выбиратель что ли? Ну провыбираешь ещё пару лет - как определишься, так приходи. Не вижу смысла тебя уговаривать.
>>1908249 Да выбиратель, указал же что я вкатун и пришел узнать, стоит ли нуфагу имено на ваш стек прыгать. Потому что во всем западном интернете пишут, что пыха это путь в никуда, а вот у нас в снг наоборот, что пыха вечна и вообще анаговнет(c)
>>1908257 >во всем западном интернете пишут, что пыха это путь в никуда, а вот у нас в снг наоборот, что пыха вечна и вообще анаговнет И? Тебя смущает наличие у разных людей разного опыта и мнений или отсутствие собственного? А может ты пришёл сюда в ожидании того, что тут сидят свидетели ПХП, которые будут тебя агитировать за вступление в свои ряды и устраивать спецолимпиаду? Да всем насрать.
Тут люди учатся программировать веб в первую очередь, а пхп идёт, скорее, как первый язык. Никто тебе не мешает потом на ноду или го перейти - там ты тоже веб будешь писать по тем же принципам. Алсо чистый пхп почти никому не нужен - будешь ещё учить вёрстку, базы данных, жавускрипт, линуксы и чёрта лысого. Пхп тут процентов 20-30 будет из всего.
Подскажите где на проде применяется rabbit mq, какое у него основное применение? Просто, чтобы ставить задачи в очередь? Вот, например, в телеграм боте отправку сообщений через него реализовать норм?
>>1908453 >>какое у него основное применение? Как я понимаю -какие нибудь потенциально тяжелые и долгие задачи разбивать на куски, и выполнять последовательно.
сап, погромач. я в отчаинии. в начали недели дали таску по переносу товаров с одного сайта движок netcat на более менее норм хуйню тоже какой то cms-шоп но на основе ларки. и вот спустя два с половиной дня ебли я пришел сюда спросить совета у знающих анонов. суть такова: в каталоге имеется 13 категорий, в каждой из них по от n количеству разделов при этом с разными уровнями вложенности в основном от 3 до 5 и на разных соответственно находятся сами товары с ценниками и описаниями. как мне блять эту залупу переносить то?в самом этом неткаде есть экспорт товаров в csv и я могу их разгрузить на новый движок, но проблема в том что он мне позволяет забирать только по одному из подразделов и товаров (естественно без вложенностей). я так делал джва дня и в итоге даже одну категорию из 13 блять не перенес. сегодня вот полдня копался в базе в надежде составить нормальный sql запрос на выборку товаров и разделов с соответственной вложенностью и экспортнуть в csv чтобы хотя бы по одной категории загонять - но всплыли камни в виде того что там бд люто денормализована и все хранится прямо вообще в хаотичном порядке до сих пор гадаю как сайт то с такой структурой ворочается. категории, товары, разделы хранятся вообще в совершенно разных таблицах. я сейчас пытался получить по конкретной категории с использованием вот как раз 3 разных таблиц в итоге получил лишь порядка 30% того что мне надо. покопавшись выяснил что некоторые разделы хранятся в таблице с товарами, а некоторые товары хранятся в таблице с разделами. так вот, анонсы, как поступать то? дальше колупать базу в надежде чет годное состряпать хотя нервы уже сдают, либо же писать парсер и самому всю инфу вытягивать при этом храня всю структуру вот четенько и так как надо но тут есть проблема - какой то говенный хостинг у заказчика что при определенном кол-ве запросов в час он блочит сайт нахуй и просит оплатить тариф по богаче, либо же забить хуй и дальше ручками переносить ? хотя думаю при такомм раскладе я до марта не закончу лол алсо, сайт локально не получилось развернуть тк тут нужна какая то древняя блять версия пыхи с соответствующими функциями и коннектами из за чего я наебся и с этой хуйней тоже но в итоге ниче тупо не вышло и я смог ток локально бд у себя держать. как поступать, анонче? уже охото послать и галеру и заказчика нахуй потому что заебло
>>1909005 Делай проще - запускай парсер и собирай базу в том виде, в котором тебе нужно. Проблемы с хостингом это проблемы только заказчика. Если хочет чтобы ты в его БД ковырялся, то называй ему цену х5 - х10 от текущей и соответствующие сроки.
>>1909005 Перенос напрямую из БД одной CMS в другую это большой геморрой, как я знаю - там со структурой каждый извращается как может + плагины добавляют градуса неадеквата. Это ж не фреймворки, где чистые архитектурки и правильные нормализации для хипстеров, с чем удобно работать.
>>1909075 двачую, анонче >>1909069 попробую так поступить ради выебонов перед начальством. хотя сам уже сейчас sql запросом длинным сбилдил таблицу как мне надо и задача выполнена по факту. но я помолчу - пусть заказчики с пмом погорят )))
>>1909172 >пусть заказчики с пмом погорят Типа как ты погорел за эти два дня? Всё правильно - если выгорать, то не одному, чтоб необидно было. хо-хо-хо
Можно как-то получить ключ из такого массива по классу? const MODELS = [ 1 => \App\Models\Huina, 2 => \App\Models\Zalupa ] То есть models[1] выдаст хуйню, а мне нужно передав хуйню получить 1. array_search не работает.
А почему ваш php плох? По мне так это единственный язык, изначально сделанный для своих задач. Работа есть, фреймворки есть, время прилизало всё как надо. В чём проблема, почему мёртв-то?
>>1909843 Порнхаб например или фейсбук с вк. Но у них своя редакция языка уже. Так-то фича этого ЯП - быстрое создание приложений и прототипов. Нет смысла тратить сотни денег на кучу java\c++ программистов если можно быстро на пхп запилить и проверить гипотезу на практике.
Вообще около 80% сайтов на пхп работают.
ps если ты жаваскрипт-ребёнок, то учти, что на ноде делать бекенд это пиздец и дно. Жаваскрипт не для бекенда был создан - учи нормальный бек, а не срезай углы.
>>1909856 Ну это понятно, но я же спрашиваю за крупные айти компании. >ps если ты жаваскрипт-ребёнок, то учти, что на ноде делать бекенд это пиздец и дно. Нет, я пыхер. Просто как-то приуныл с того, что у меня уже пол группы в епам джунами через курсы по джаве почти с нуля вкатились, а я все еще труп php ковыряю.
>>1909893 Да я и не жалуюсь. Пых и его ниша мне нравятся, за сам вкат я не особо беспокоюсь ( я на него еще не так много времени отдал ). Единственное что пугает - это перспективы.
Нужен скирпт для очискти датабазы. first_name и last_name колонны имеют некорректные значения. Колонна first name имеет значения такие как 'Mark null' или 'Lisa undefined', колонна last name имеет значения такие как 'undefined'. Слова вроде null и undefined надо убрать.
Я ничего не смыслю в php и очень тупой, но задачку надо решить помогите плз~~
>>1910152 Думаешь все сразу шедевры лепят? Ты б видел какое я говно поначалу делал.
1. Меньше слушай мнение других и больше сам глазами смотри - кто, что и как делает. 2. Всегда доводи до логического конца начатое. Даже если говно получилось.
>>1910152 В образовательных целях полезно написать без фреймворка. В работе же чаще используют фреймворки, ту же лару. Ты в любом случае придешь к фреймворку, своему или популярному
>>1910216 Этот анон прям по делу говорит. Слушать вообще никого не нужно. >>Всегда доводи до логического конца начатое. Даже если говно получилось. Люто двачую, когда начинаешь доводить до финала - лезет всякая мякотка. Детали которые хуй пойми как реализовывать.
Начал изучать ооп в пхп. Интересует такой вопрос. В некоторых языках, как я понял, объект класса и экземпляр класса - не одно и тоже. В пхп же это просто синонимы или же я тупой ?
>>1910493 В yii через require рендерятся страницы, это точно. Как до рендера работает лень копаться. Думаю по роуту вызывается и выполняется php файл, в нем через пространства имен идет обращение к другим файлам. Но это уже работа php а не фреймворка.
>>1911342 Двачую - лучше сильно не загоняться на SQL, имея возможность нормально писать логику. Особенно делать такой трэш >>1911026 Онли чтение и запись в нужном виде.
Вообще лучше сильно не загоняться по этому делу иначе получится так, что на проекте 50% логики на SQL и 50% на пхп, что есть дерьмо и размазывание функционала. В прошлом десятилетии этого наелись. Это имеет смысл если нужно разово что-то такое из БД взять или с таблицами как-то поработать.
Гутен Морген, майн кляйне комраден! Эс гибт эйн проблем, дас их нихт ферштехен унд дас их нихт ферштехен кан. Их браух хилфе! / Дан массив из n чисел, поменять местами наибольшего и наименьшего элемента массива и вывести на экран. Если есть две или больше наименьший, то выбрать элемент ближе к левому, а с наибольшим наоборот ближе к правому, а если все элементы одинаково вывести на экран 'everyone is equal', а если у массива единственный элемент, то вывести на экран этого же элемента. simple input: 8 11 7 8 5 3 4 9 17 27 45 1 97 81 1004 74 simple output: 8 11 7 8 5 3 4 9 17 27 45 1004 97 81 1 74 Sample Input 3: 1 -7 8 7 9 7 -7 9 8 Sample Output 3: 1 9 8 7 9 7 -7 -7 8 / <?php $array = stream_get_line(STDIN, 1024, PHP_EOL); $arr = explode(' ', $array); $a = max($arr); $b = min($arr); if (count($arr) == 1) echo $a; elseif ($a == $b) echo "everyone is equal"; else { foreach ($arr as &$value) { if ($value == $a) echo $b . " "; elseif ($value == $b) echo $a . " "; else echo $value . " "; } } ?>
>>1911754 бля, случайно половину отправил. И в файле модели для которой нужна пагинация прописал use Illuminate\Pagination; use Illuminate\Pagination\Paginator;
после этого для модели становится доступен метод paginate() ( я кстати так и не понял как это работает. Типа в Model от которого наследуется мой класс Модели елоквен где то захардкодены эти классы? ). Который работает - если указать paginate(5) - он выдаст первые пять записей. Но я чет не пойму как в paginate передать номер текущей страницы.
>>1911717 1. Потому, что эта CMS-ка устарела лет на 10 в технологическом плане и имеет здоровый такой технический долг. 2. Изначально она для блогов, а на ней пытаются лепить всё подряд. 3. На ней почти всегда работают низкоквалифицированные специалисты и после них разгребать никому не хочется. 4. Лапша вместо кода вообще везде - в шаблонах, в плагинах, в темах, в ядре. 5. Зачастую очень хреновая документация плагинов.
Так как мы тут всё же разработчики с кодом, то смотрим на вордпресс с точки зрения ковыряния в коде, а там всё плохо - вордпресс не предполагает разработку через код, а работает в стиле: взяли тему, напичкали плагинами, повырезали что получилось и готово.
>>1911923 >готовый интернет магаз Готовый самому делать надо.
Братишки, поясните за работу с массивами из гайда. Для чего перед началом цикла, в котором выбирается рандомное значение из массива, мы вводим переменную $name с пустым значением, если можно ввести переменную в теле цикла? Без строчки с вводом переменной до цикла все работает, проверял. Алсо, подскажите, пожалуйста, где обмазаться простыми задачками, чтобы закрепить полученные из тутора знания?
>>1912040 Но мы ведь ее создаем в теле цикла и сразу же выполняем над ней действие циклично. Что не так? PHP, насколько я понимаю, по умолчанию несуществующей переменной присваивает значение "0". Бля, у меня проблемы с выражением мысли Например, пикрелейт. Дописывая $name++, переменная $name будет дальше увеличиваться на единицу, с переменной можно выполнять действия, и т.д. Понятно, если бы к существующей переменной $name нужно было бы добавлять слоги, но по условиям задачи мы составляем $name из ничего. В чем подводные? И почему лучше так не делать? Моветон?
>>1912069 >Я думаю, что тебе сперва стоит выучить синтаксис языка - цикл идёт ниже. Не, я говорил, что в моем случае, когда переменная не указывается до цикла, мы создаем ее в цикле. >Плохая практика - если привыкнешь, то в других языках может вообще не работать такое в большинстве компилируемых языках. Во! Спасибо. Жаль, что нет рядом никого, кто бил бы по рукам, когда делаю рабочий, но неправильный код.
>>1912080 >мы создаем ее в цикле Тогда ты, получается, обнуляешь\ставишь дефолтным её значение каждый проход. Переменная создаётся только один раз - когда ты впервые указываешь ей значение. Сама суть переменных, по простому, в программировании вообще - это указатель на блок памяти, куда ты будешь писать какие-либо данные. Вместо $name можно было бы писать что-то вроде 0xff334ff223a и писать туда данные на заре так и делали, но это нечитабельно чуть более чем полностью - через месяц быстрее заново написать будет, чем разбирать - что в них хранится в ходе работы. А так - ты его указал один раз и твой скрипт запомнил его, и по названию понятно что в ней лежит.
>Жаль, что нет рядом никого, кто бил бы по рукам Такое обычно денег стоит. Это азы и никому не интересно их объяснять - я б тоже мимо прошёл, но мне делать нех в этот субботний вечер.
Удалённая работа
Аноним17/01/21 Вск 04:38:07№19124061000
Аноны, сап. Есть вопрос, ответа жду только от шарящих в этой теме, так как мне нужен верный ответ.
Я долго думал, как построить свой вопрос правильно, чтоб он прозвучал нормально, но лучше спрошу как есть:
Хочу устроиться джуниором(!) на удалённую работу(!) Вопрос: есть ли у меня хоть какие-то шансы сделать это неофициально? Говорю как есть: дабы к моим документам не касались левые людиналоговая, мвд, и прочие ребята Чисто, и как есть: я выполняю свою работу, работодатель мне выплачивает заработную плату на тот банковский счёт, который я укажу. Все довольны, все в расчёте. Как происходит трудоустройство на удалённую работу вообще? Везде официально оформляют? Хорошо, а если я, например - захочу поработать на компанию в Украине/Беларуси - меня так же будут официально оформлять? Чисто опираясь на свой опыт сугубо: какие у меня шансы попасть пыхо-джуном сразу на удалёнку, да ещё и без официального оформления. Фриланс не предлагать, это важно! Заранее благодарю за ответы. Больше мне не у кого спросить.
>>1912406 >Хочу устроиться джуниором(!) на удалённую работу(!) И тут сразу мимо. Джуны на удаленке не нужны
>есть ли у меня хоть какие-то шансы сделать это неофициально? Неофициально устроиться можно. Там уж как договоритесь с работодателем
>Как происходит трудоустройство на удалённую работу вообще? Везде официально оформляют? ТК РФ (серая и белая схемы), ГПХ, ИП, в черную (без бумаг).Чаще всего устраивают по ТК РФ или как ИП.
>Чисто опираясь на свой опыт сугубо: какие у меня шансы попасть пыхо-джуном сразу на удалёнку, да ещё и без официального оформления. Практически нулевые. На удаленке работодателю не нужен чел, за которым нужно постоянно следить, учить его и переделывать за ним.
Ребят, помогите понять задачу про палидром из гайда. Вернее, логика поиска палиндрома мне понятна, но я посыпался на цикле, пикрелейт. Хочу взять первую и последнюю букву из строки, потом вторую и вторую с конца и т.д. Почему хитрая пыха в первом проходе принимает $i и -$i за ноль, а во втором $i=1, -$i=0; в третьем $i=2, -$i=1 и т.д.? ЧЯДНТ? Спасибо
Файлы и обложки стоит хранить на диске, а в базе данных - только информацию о них. При этом, желательно сначала сохранять файлы на диск, а только потом вставлять информацию в БД. Тогда в БД никогда не будет ссылок на несуществующие файлы, если в процессе загрузки произойдет какая-то ошибка.
У тебя пример неправильного кода. При его выполнении выводится нотис: "Undefined variable: name". Так как $name ++ эквивалентно $name = $name + 1 и при вычислении $name + 1 происходит обращение к несуществующей переменной. Нужно поставить в начале $name = 0; чтобы ошибки не было.
sort() это сортировка по значению, но ключи теряются, и проставляются заново начиная с 0. Есть сводная таблица с отличиями функций сортировок: https://www.php.net/manual/ru/array.sorting.php
Он используется для организации очередей задач. Это нужно, чтобы:
1) сократить время отдачи ответа
Допустим, нам надо при добавлении товара на сайте перестраивать каталог и это занимает 30 секунд. Если мы будем перестраивать каталог прямо в скрипте, то пользователь будет долго ждать ответа. Вместо этого мы кидаем в очередь задание на перестройку каталога и быстро возвращаем пользователю ответ, что все ок. Фоновый скрипт-рабочий разгребет очередь и перестроит каталог.
Или, у нас есть сайт вроде Ютуба и нам надо перекодировать добавляемые пользователем видео. Это может занимать по 10 минут, естественно, тут только очередь задач и поможет.
2) ограничить нагрузку на БД (или на какую-то систему)
Допустим, у нас много пользователей добавляют товары. И при добавлении создается нагрузка на БД от множества пользователей. Если мы вынесем тяжелый код в фоновую задачу, то эти задачи будут выполняться не одновременно, а последовательно, что ограничивает нагрузку на БД и защищает ее от перегрузки.
Или, например, надо при добавлении товара переслать этот товар в какую-то внешнюю систему. Если мы начнем все это делать прямо в скрипте добавления, то мы сильно нагрузим эту систему (а пользователи будут ждать ответа). Опять же, очередь тут поможет ускорить отдачу ответа и ограничить нагрузку на внешнюю систему (товары будут посылаться в нее по одному по очереди).
Считается, что у CDN много точек присутствия и к пользователю он может быть ближе (но по факту, там могут быть точки в зарубежных городах, которые для российской аудитории бесполезны). Из минусов - нужна возня с выгрузкой файлов на CDN при деплое и нужно платить за CDN.
Код желательно разделить на функции: отдельно соединение с БД, отдельно валидация, отдельно сохранение в БД.
Исключение не надо ловить через catch. По умолчанию оно и так поймается и запишется в лог ошибок, и ты узнаешь об ошибке, просматривая лог. А в твоем варианте оно никуда не пишется и ты не узнаешь об ошибке на сайте.
Тут есть риск, что если $stringPos < 30, то получится отрицательное число и будет взят кусок не оттуда (а с конца строки). Это видно в выводе программы:
> Допущена ошибка: .... Пикрандом а так. [Жывотные] Хочу принести тебе прохладную... (жи/ши пиши через И)
> [а-яёА-ЯЁ0-9]+\s+а\s+
Здесь после "а" лучше поставить \b, иначе не сработает, если после "а" идет запятая.
Еще, конечно, хорошо было бы не дублировать регулярки два раза, а сделать единый массив с регулярками, комментариями и исправлениями к ним. Но и так неплохо сделано.
Вообще, по задумке эту проверку должна была делать функция smallNumberToText. То есть мы передаем ей число и род (мужской, женский), а она сама определяет, какую форму числа брать. В твоем решении 71000 выводится неправильно.
>>1912688 Хуёво быть тупым и невнимательным. Спасибо, Анончик. Решил через mb_substr ($text, -$i-1, 1) , но это какие-то костыли, не? Еще вижу вариант в создании двух циклов. Один с начала слова, второй с конца. Перед циклами создать два пустых массива, а в цикле заносить в массив по одному символу из $text. Затем навернуть ещё один цикл, в котором будут сравниваться элементы обоих массивов. Ещё вот какой вопрос: я использую str_replace (" ", "", $text) для удаления пробелов в $text. А что если, предположим, текст содержит знаки препинания, перенос строки и т.д.? Каждый раз ручками прописывать str_replace для каждого символа?
>>1913477 >Решил через mb_substr ($text, -$i-1, 1) , но это какие-то костыли, не? Подогнал индекс - вполне себе нормальное решение
>А что если, предположим, текст содержит знаки препинания, перенос строки и т.д.? Каждый раз ручками прописывать str_replace для каждого символа? Регуляркой попробуй
>>1913471 В руководстве написано,что не нужно Все автоматом > Настоятельно рекомендуется использовать автоматическую генерацию соли. Данная функция самостоятельно создаст хорошую соль, если вы не будете ей мешать подсовывая свою.
Как было замечено выше, опция salt была объявлена устаревшей в PHP 7.0 и будет вызывать соответствующее предупреждение. Поддержка ручного задания соли может быть удалена в более новых версиях.
>>1913395 >>1913892 Солёный хэш + соль у тебя в переменной $hash, а в датабазу ты загружаешь просто пароль $password. password_verify нужен не при регистрации пользователя, а когда кто-то хочет зайти в свой аккаунт.
>>1914478 Из базы выбирай только по имени(логину), а не связке логин-пароль. Пароль уже на втором этапе проверяй - когда у тебя пользователь с данными из базы пришёл.
>>1914526 >реализацией пиздец 1. Посылаешь запрос в бд на получение всех данных пользователя по логину 2. Если результат не пустой, то проверяешь пароль через password_verify, подставляя туда полученный из формы пароль с одной стороны и хеш пользователя из бд с другой 3. Если возвращает true, то ставишь юзеру сессию
>>1914202 >>1914567 password_hash() должен возвращать строку в 60 символов, но в базе видно строку намного короче. Какой допустимый размер у поля password? Если он меньше, чем 60 символов, то sql может, в зависимости от настроек, выдавать ошибку или сохранять обрезанную строку.
Что должен уметь php программист на ларе, чтобы получать 120к? То, что лару он должен знать - это понятно. Просто вакансии сильно отличаются по требованиям и такое ощущение, что их как-то на похуй составляют.
Хочу сделать так, чтобы в общем диве можно было хранить большое количество внутренних дивов, а показывало только 3. Дальше хочу, чтобы кнопка справа передвигала див, то есть при нажатии должно показывать див номер 2, 3, 4 и так далее. Знаю, что для этого вроде нужен Джаваскрипт, но я не знаю, что искать. Прошу помочь.
>>1914860 >Что должен уметь php программист на ларе, чтобы получать 120к? Отвечу на первую часть вопроса, т.к. зп зависит не от того, сколько ты знаешь, а от того в какую фирму и идешь и как себя продашь.
Надо иметь в кармане пару законченных проектов на ларе. И желательно применить различные плюшки фреймворка в этих проектах. Из мастхева: - Контроллеры, елоквент модели, релейшены, квери билдер, роутинг, шаблонизатор блейд - DI - принципы работы, как подключать в проект сторонние либы
Полезно будет изучить другие фишки вроде консольных команд, шедалера, полиморфных связей и т.п.
>>1914884 >зп зависит не от того, сколько ты знаешь, а от того в какую фирму и идешь и как себя продашь
Да, я заметил. Вообще зп сильно прыгает, а по факту в требованиях одно и то же. Не могу разобраться, почему вот именно столько они предлагают и от чего отталкиваются.
>>1914894 >Не могу разобраться, почему вот именно столько они предлагают и от чего отталкиваются От клиентов фирмы зависит их бюджет. Региональные фирмы предлагают зп чуть больше, чем в соседнем супермаркете кассиром. Далее идут фирмы, работающие на дс/зарубеж, у которых филиал в регионе. В дсах уже на порядок больше зп. И в топе работа на белых господ.
>>1914978 На 18 строке какая-то содомия у тебя и неправильно логику написал. Ты используешь логическое И, тогда как там надо логическое ИЛИ. Т.е. не если пустой логин И пустой хеш, а если пустой логин ИЛИ(or) пустой хеш. Гугли таблицы истинности, которые непонятно зачем проходят ещё в школах и их все забывают. Сам хеш лучше проверять не вместе с логином, а на 20 строке через ту самую ИЛИ.
А что за детсад с этим 'fuck off' тебе 10 лет что ли? Пиши туда нормально хотя бы: логин или пароль не верны. Это важно - писать именно так чтобы исключить возможность подбора пароля по логину.
>>1915186 >>1915196 Так называемый fail fast. Проверяем условие провала. В данном случае, ты же не залогинишь человека без логина? Неважно, дал ли он пароль, если нет логина. Соответственно мы проверяем, дал ли человек логин, если нет - сразу шлем нафиг. В коде как-то так выглядит:
if (emtpy($login)) { return false; // представим, что у нас есть метод, проверяющий, заполнены ли логин и пароль. false - не заполнены }
>>1915187 >В случае успешного выполнения функции возвращаемое значение зависит от режима выборки. В случае неудачи, функция всегда возвращает false. Результат фетча проверить надо. if ($row) { //достаешь логин, пароль из роу } Там он ебануто результат выдает: либо массив полей строки бд, либо фелс
Или так: if (!$row) { return; //сворачиваем работу, или кидаем ошибку о том, что не смогли достать учетку из бд }
Убери цикл while() и используй просто один вызов $sth->fetch для получения строки из БД. Учти, что он может вернуть false, если строка не найдена и это надо проверять.
Также, проверку можно бы вынести в функцию, чтобы вызывать ее как:
if (is_valid_login($name, $pasword)) { ... }
Когда ты получаешь значения из $_POST, их там может не быть и это вызовет ошибку. Используй ??, например $x = $_POST['x] ?? '';
В CSS тебе надо сделать, чтобы внутренние дивы выводились последовательно, без переносов. Для этого можно использовать flexbox, с запретом переноса. Чтобы были видны только 3 дива, нужно поставить overflow: hidden.
Что касается JS, то его надо изучать сначала, вряд ли получится "подсмотреть" быстро нужную функцию. За прокрутку элемента отвечает свойство scrollLeft, определить позицию элемента на экране можно с помощью getBoundingClientRect(), размеры элемента с помощью offsetWidth.
Потому что там есть отдельный счетчик и очищением таблицы ты его не сбросил. Сбросить счетчик можно запросом вроде ALTER TABLE tbl AUTO_INCREMENT = 100.
привет всем знатокам php. вопрос такой - нужно написать сайт с авторизацией, заполнением нескольких полей и их сохранением в табличку. мысли сделать это все на mysql с двумя бд: одна для хранения логинов и паролей, вторая для сбора инфы с сайта. скажите, я верно мыслю? или есть какой-то способ попроще
>>1916211 Но для этого мне нужно будет изучить два этих языка, я спрашиваю для того чтобы сократить время вкатывания, в будущем допускаю изучения второго по мере надобности.
>>1916360 Ты их по году собрался изучать каждый? Банально посмотри кол-во вакансий, стек технологий в них и зп по каждому из языков и решись. Так то языки решают одни и те же задачи. Особой разницы при разработке под веб не почувствуешь
Какие бест практис для админ секции сайта? Насильно генерировать длинный пароль для юзеров(админов) не давая возможность придумать свой, прятать /admin в какой-то /admin_cG9rYSB5b2tl (что в принципе не имеет особого смысла кроме неудобства для всех), что еще можете подсказать? Можно еще после например 5-10 неудачных логинов банить айпи
>>1916804 >длинный пароль для юзеров(админов) Я обычно рандомный генерю только для разработчика ака root админки, а редакторы контента пускай сами себе выбирают - максимум что можно сделать на их уровне это попортить контент. У тебя должно быть разделение прав в админке.
>прятать /admin в какой-то /admin_cG9rYSB5b2tl (что в принципе не имеет особого смысла кроме неудобства для всех) Имеет - боты ходят по сети и стучатся в известные пути админок. Если сайт отдал 404, то они отстают от этого адреса.
>после например 5-10 неудачных логинов банить айпи Принято не банить, а ставить тротлинг - возможность повторной попытки логина через, например, минуту. Это сводит к 0 брут-атаку с перебором.
>>1916999 При попытке логина инкрементишь в каком-то хранилище счетчик запроса на +1, записываешь время, ключом для хранилища выбираешь айпи запроса + что-то сверху, ну и смотришь чтобы не превышало
Я снова на связи. А сделать аккаунт юзера осмысленным. Вот он есть в БД,но нужно сделать страничку для него. Вот допустим php нашел юзера в БД,дальше че?
>>1915852 Нету никаких. Иди изучай питон, это стильно модно и молодежно. Лучший язык человечества. Рекомендую записаться на какой-нибудь месячный курс, после него сразу можешь идти устраиваться на работу.