• Не стабильная работа mysql сервера?

    twix007
    @twix007
    mysqltuner оптимизация
    Ответ написан
    Комментировать
  • Законно ли хранить личнык данные за пределами Украины?

    saboteur_kiev
    @saboteur_kiev
    software engineer
    В Украине такого закона пока что нет.
    Ответ написан
    Комментировать
  • Как называется такой стиль рисования?

    @Nwton
    Совсем очевидно: 3d pixel style / voxel stylemarket-stand-d-art-picture-sellling-frui
    Ответ написан
    Комментировать
  • PHP / sys_get_temp_dir игнорирует Local Value?

    Melkij
    @Melkij
    PostgreSQL DBA
    sys_get_temp_dir смотрит в настройку sys_temp_dir, если таковая объявлена.
    upload_tmp_dir посмотрит в sys_get_temp_dir только если значение upload_tmp_dir не указано явно. Аналогично сессии.
    Ответ написан
    1 комментарий
  • Письма попадают в спам. Как исправить?

    webirus
    @webirus
    Тыжверстальщик! Наверстай мне упущенное...
    Если бы был свой сервис, можно было бы поискать решение.
    Но думаю, что при использовании Почты для домена, только Поддержка Яндекса скажет.
    Правда они там неадекватные, так что выбить решение придется постараться)
    Ответ написан
    Комментировать
  • Как отобразить подсказку сигнатуры метода в PHPStorm?

    Pinsky
    @Pinsky
    Кофеиноникотиновая смесь в backend-код
    quick documentation on mouse move
    Ответ написан
    1 комментарий
  • Как отобразить подсказку сигнатуры метода в PHPStorm?

    @Quieteroks
    php программист
    Все очень просто, ctrl + q при выборе метода. Всплывает подсказка из доки.
    Переход к методу ctrl + click. Даже к библиотечному, они просто описаны в библиотеке самого phpstorm.
    Ну и когда вы ставите скобки, появляется список аргументов. Если вы вышли из списка, просто ставите запятую после последнего аргумента, ждете секунду и Вам вновь высвечивается подсказка по аргументам.
    Ответ написан
    Комментировать
  • Что означает криптографически безопасное случайное целое число?

    Sanasol
    @Sanasol Куратор тега PHP
    нельзя просто так взять и загуглить ошибку
    Хороший рандом:
    randbitmap_true.png

    Плохой рандом:
    randbitmap_computer.pngsource
    Ответ написан
    3 комментария
  • Запоминание паролей в браузерах. Какой атрибут используется в алгоритме?

    IonDen
    @IonDen
    JavaScript developer. IonDen.com
    Атрубут name разумеется.
    Это по сути общепризнанный стандарт именования полей "login", "email", "password" и т.д.
    Ответ написан
    Комментировать
  • Попросили проверить код, на что смотреть нужно?

    index0h
    @index0h
    PHP, Golang. https://github.com/index0h
    Смотря зачем)). Я когда делаю Code Review критерии следующие:

    * Безопасность:
    - Каждый аргумент метода простого типа должен проверяться на тип в случае его проксирования и на граничные значения в случае обработки. Чуть что не так - бросается исключение. Если метод с кучкой аргументов на 80% состоит из поверки из аргументов - это вполне норм))
    - Никаких trigger_error, только исключения.
    - Исключения ДОЛЖНЫ быть человеко-понятны, всякие "Something went wrong" можно отдавать пользователю, но в лог должно попасть исключение со стектрейсом и человеко-понятным описанием, что же там пошло не так.
    - Каждый аргумент (объект) метода должен быть с тайпхинтингом на этот его класс, или интерфейс.
    - За eval как правило шлю на **й.
    - @ допускается только в безвыходных ситуациях, например проверка json_last_error.
    - Перед работой с БД - обязательная проверка данных.
    - Никаких == и !=. Со swtich - единственное исключение, по ситуации.
    - Если метод возвращает не только bool, а еще что-то - жесткая проверка с ===, или !== обязательна.
    - Никаких условий с присваиваниями внутри. while($row = ...) - тоже идет лесом.
    - Магические геттеры/сеттеры разрешаются только в безвыходных ситуациях, в остальном - запрещены.
    - Конкатенации в sql - только в безвыходных ситуациях.
    - Параметры в sql - ТОЛЬКО через плейсхолдеры.
    - Никаких глобальных переменных.
    - Даты в виде строки разрешаются только в шаблонах и в БД, в пхп коде сразу преобразуется в \DateTimeImmutable (в безвыходных ситуациях разрешено \DateTime)
    - Конечно зависит от проекта, но как приавло должно быть всего две точки входа: index.php для web и console(или как-то по другому назваться) - для консоли.

    * Кодстайл PSR-2 + PSR-5 как минимум, + еще куча более жестких требований (для начала все то что в PSR помечено как SHOULD - становится MUST)
    - В PhpStorm ни одна строчка не должна подсвечиваться (исключением является typo ошибки, например словарик не знает какой-то из аббревиатур, принятых в вашем проекте). При этом разрешается использовать /** @noinspection *** */ для безвыходных ситуаций.
    - Если кто-то говорит, что пишет в другом редакторе и у него не подсвечивается, на эти отговорки кладется ВОТ ТАКЕЕЕНЫЙ мужской половой **й и отправляется на доработку)).

    * Организация кода:
    - Никаких глобальных функций.
    - Классы без неймспейса разрешаются только в исключительно безвыходных ситуациях.

    * Тестируемость (в смысле простота тестирования) кода должна быть высокая.
    - Покрытие кода обязательно для всех возможных кейсов использования каждого публичного метода с моками зависимостей.

    * Принципы MVC:
    - Никаких обработок пользовательского ввода в моделях, от слова совсем.
    - Никаких ***ть запросов в БД из шаблонов.
    - Никаких верстки/js/css/sql-ин в контроллерах.
    - В моделях НИКАКОЙ МАГИИ, только приватные свойства + геттеры с сеттерами.
    - В моделях разрешено использовать метод save(при наличии такого разумеется) только в исключительных ситуациях. Во всех остальных - либо insert, либо update.

    * Принципы SOLD:
    - Никаких божественных объектов умеющих во все.
    - Если метод для внутреннего пользования - private, никаких public.
    - Статические методы разрешаются только в случае безвыходности.

    * Принцип DRY разрешено нарушать в случаях:
    - Явного разделения обязанностей
    - В тестах (каждый тест должен быть независимым, на сколько это возможно)

    * Работа с БД:
    - Запрос в цикле должен быть РЕАЛЬНО обоснован.
    - За ORDER BY RAND() - шлю на***й.
    - Поиск не по ключам (конечно если таблица НЕ на 5 строк) запрещен.
    - Поиск без LIMIT (опять же если таблица НЕ на 5 строк) запрещен.
    - SELECT * - запрещен.
    - Денормализация БД должна быть обоснована.
    - MyISAM не используется (так уж)) )
    - Множественные операции обязательно в транзакции, с откатом если чо пошло не так.
    - БД не должна содержать бизнес логики, только данные в целостном виде.
    - Не должно быть нецелесообразного дерганья БД там, где без этого можно обойтись.

    * Кэш должен очищаться по двум условиям (не по одному из, а именно по двум):
    - Время.
    - Протухание по бизнес логике.
    Разрешается по только времени в безвыходных ситуациях, но тогда время - короткий период.
    - При расчете ключей кэша должна использоваться переменная из конфигурации приложения (на случай обновлений кэш сбрасывается кодом, а не флашем кэш-сервера). В случае использования множества серверов - это очень удобный и гибкий инструмент при диплое.

    * О людях:
    - "Я привык писать так и буду дальше" - не вопрос, ревью пройдешь только когда поменяешь свое мнение.
    - "Я пишу в vim-е и мне так удобно" - здорово, код консолью я тоже в нем пишу)) но есть требования к коду, если в них не сможешь - не пройдешь ревью.
    - "Я скопировал этот страшный метод и поменял 2 строчки" - это конечно замечательно, но по блейму автор всего этого метода ты, так что давай без говняшек, хорошо?
    - "Оно же работает!" - вот эта фраза переводится примерно так: "да, я понимаю, что пишу полную хрень, но не могу писать нормально потому, что руки из жо", я правильно тебя понял?))
    - "У меня все работает!" - рад за тебя, а как на счет продакшна?
    - "Там все просто" - не используй слово "просто", от слова "совсем". Вот тебе кусок кода (первого попавшегося с сложной бизнес логикой), где там ошибка (не важно есть она, или нет)? Ты смотришь его уже 2 минуты, в чем проблема, там же все "просто"))

    * Всякое:
    ActiveRecord (это я вам как в прошлом фанат Yii говорю) - полное говно, примите за исходную. По факту у вас бесконтрольно по проекту гуляют модельки с подключением к БД. Не раз натыкался на то, что в тех же шаблонах вызывают save, или update (за такое надо сжигать).
    То, что используется Laravel - это печально((. Что бы выполнить требования приведенные выше, приходится "воевать" с фреймворком.

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

    UPD

    Формализировал данные критерии по ссылочке: https://github.com/index0h/php-conventions
    Ответ написан
    55 комментариев
  • Как правильно перенести httpd.conf с apache 2.2 на apache 2.4?

    @xtreme
    Снимаю порчу по SSH :)
    А вы не добавляйте домены в httpd.conf
    У вас же FreeBSD, если я верно помню. Там в /usr/local/etc/apache24 есть директория Includes, а в дефолтном, идущем в комплекте httpd.conf в самом низу строка инклюда Include etc/apache24/Includes/*.conf которая подключает все файлы с расширением .conf в директории Include в httpd.conf.
    Перенесите конфигурацию ваших доменов/сайтов в отдельные файлы в Includes/site1.conf, Includes/site2.conf и т.д.
    Дефолтный httpd.conf, кстати, требует крайне мало изменений. Чаще всего изменения от дефолтного конфига в таких параметрах:
    EnableSendfile off
    LoadModule php5_module libexec/apache24/libphp5.so #при инсталляции mod_php5 у вас уже должно было это появиться
    Listen 127.0.0.1:80 #Или другой порт, если у вас используется nginx фронтендом, если нет - оставить Listen 80
    ServerName localhost:80 #Я ставлю так, чтобы не морочиться с /etc/hosts и апач не ругался на невозможность разрешить имя
    Require all granted #Если требуется. Это как бы замена Deny, Allow в apache-2.2
    #Также при большом желании можно еще поменять DirectoryIndex, но не всем это надо, да и можно переопределить в отдельном файле
    DirectoryIndex index.php index.html

    В остальном, если перенесете виртхосты в отдельные файлы в Includes - практически ничего не понадобится, ибо конфиги практически совместимы. Надо будет только, если у вас используется в Directory
    Order allow,deny
    Allow from all

    заменить на
    Require all granted
    если не разрешили в основном файле.
    В остальном - уже смотрите по выдаваемым apachectl configtest замечаниям и по логам.
    Так что проще взять дефолтный конфиг, идущий с апачем и поменять нужные строки, а адаптировать старый конфиг от apache-2.2 выйдет дольше по времени, плюс к тому, можете не учесть каких-то новых параметров.
    Ответ написан
    Комментировать
  • Не запускается apache 2.2 после обновления PHP. Как исправить?

    saboteur_kiev
    @saboteur_kiev
    software engineer
    Не каждая версия php совместима не с каждой версией Apache.

    Надо смотреть, какая библиотека php подходит под твой апач, возможно нужно или подставить нужную библиотеку или обновлять сам apache.

    Именно поэтому сейчас чаще пользуются готовыми LAMP и не ставят все отдельно
    Ответ написан
    9 комментариев
  • Как привязать footer к низу экрана в Twitter Bootstrap?

    @web11
    для bootstrap 3 есть отдельный пример с прижатым footer
    getbootstrap.com/examples/sticky-footer

    в файл стилей нужно добавить
    html {
      position: relative;
      min-height: 100%;
    }
    body {
      /* Margin bottom by footer height */
      margin-bottom: 60px;
    }
    #footer {
      position: absolute;
      bottom: 0;
      width: 100%;
      /* Set the fixed height of the footer here */
      height: 60px;
      background-color: #f5f5f5;
    }
    Ответ написан
    6 комментариев
  • Как организовать javascript код?

    @Insayt
    Для автора возможно уже не актуально, но для тех кто нагуглит топик - недавно написал статью об этом habrahabr.ru/post/218485
    Простой подход к структурированию кода на клиенте
    Ответ написан
    Комментировать