Задать вопрос
  • Objective-c, как начать обучение с нуля?

    @GreenElephant
    Не нужны Вам книги.
    https://vk.com/iosdevcourse - все что нужно. Главное выполнять задания.
    Ответ написан
    Комментировать
  • Возможно ли вернуть iPhone 4s по гарантии из-за iOS 9?

    @Neonoviiwolf
    Flutter developer
    сдайте по гарантии с диагнозом "сильно тормозит" пусть сц разбирается в вашей проблеме, а не вы, вы потребитель, ваше дело быть довольным. Пишу как человек работающий в СЦ (не яблоко)
    Ответ написан
    1 комментарий
  • Библиотеки и пространства имен. Нужно ли их переименовывать?

    okwinza
    @okwinza
    PHP Developer
    Нет. Зачем? Если вы не трогаете их код, они должны лежать себе в папке vendor спокойно.
    Ответ написан
    Комментировать
  • Как в php отправить письмо через smtp?

    DPechurkin
    @DPechurkin
    Веб разработчик
    progger.ru/2009/07/phpmailer-otpravka-pisem-cherez-smtp
    вот , можно достаточно безболезненно внедрить
    Ответ написан
    Комментировать
  • Где лучше проверять входные данные, в контроллере или в модели?

    Fesor
    @Fesor
    Full-stack developer (Symfony, Angular)
    Данные надо проверять там, где они есть (гуглить "GRASP информационный эксперт").

    В вашем случае мы говорим о "входящих данных". В контексте вопроса стало быть мы говорим о контроллере. Для модели данные тоже будут "входящими" но это уже будут данные в формате модели (например вместо строки готовый DateTime объект и т.д.)

    Модель же не должна входить в "невалидное состояние" за счет бизнес правил и т.д (банально не должно быть возможности вызвать какой-то метод и сломать целостность состояния модели). А стало быть валидировать ее нет смысла.
    Ответ написан
    2 комментария
  • GET параметры. Как запретить изменение их вручную?

    sergiks
    @sergiks Куратор тега PHP
    ♬♬
    Добавлять параметром подпись, которая считается как хэш от параметров в ссылке и некого «секрета», известного только серверу. Такую подпись злодей не сможет подделать (с приемлемой вероятностью), а при изменении параметров, подпись не совпадёт, при проверке на сервере. Такая схема, в частности, применяется во ВКонтакте для проверки GET-запроса при открытии iFrame приложений.

    Например, ваша ссылка должна содержать параметры param_a и param_b. Когда вы её генерируете на сервере, добавляется параметр sign, равный md5-хэшу от строки, полученной конкатенацией названий параметров, их значений и секретного ключа:

    $secretKey = "nXYFyArf6F6iQXTzg"; // хранится в тайне, известен только серверу
    $a = "значение неподделываемого параметра А";
    $b = "значение неподделываемого параметра B";
    $params = array(
      'param_a' => $a,
      'param_b' => $b,
      'sign'    => md5( "param_a" . $a . "param_b" . $b . $secretKey),
    );
    printf( '<a href="http://site.com?%s">Суперссылка</a>', http_build_query($params));

    На сервере полученные GET-параметры проверяются: необходимо наличие подписи, и её совпадение с переданными параметрами. Подпись для полученных параметров вычисляется так же, как и при генерации ссылки – и сравнивается с переданной подписью.
    Ответ написан
    2 комментария
  • GET параметры. Как запретить изменение их вручную?

    riky
    @riky
    Laravel
    ко всем ссылкам добавлять сигнатуру.

    пример функции для генерации ссылок
    function getLink($url, $data) {
      ksort($data);
      $query = http_build_query($data);
      $signature = sha512($_SESSION['salt'] . $query);
      return $url . '?' . $query . '&sign=' . $signature;
    }


    при получении запроса - добавить аналогичную функцию для проверки сигнатуры.

    function checkSign() {
      $data = $_GET;
      $signQuery = $_GET['sign'];
      unset($data['sign']);
      ksort($data);
      $query = http_build_query($data);
      $signature = sha512($_SESSION['salt'] . $query);
      return $signature === $signQuery;
    }


    если юзер чтото поменяет то сигнатура не сойдется.
    чтобы увеличить безопасность лучше в сигнатуру добавить еще и юрл. иначе у
    /users/?id=5
    /post/?id=5
    сигнатуры будут одинаковые
    Ответ написан
    3 комментария
  • GET параметры. Как запретить изменение их вручную?

    miraage
    @miraage
    Старый прогер
    JWT, например.
    Ответ написан
    Комментировать
  • VestaCP. Как она в плане безопасности, да и вообще, в роли панели управления VDS?

    @mr_ko
    Javascript, Node.js. React.js, Vue.js, Wordpress
    Я использую весту уже около 3х лет. Поставил на свою тестовую VPS где часто создаю поддомены для демонстрации клиенту работ, очень удобно и просто.
    Сервак конфижит она сама под себя. Но ее связка nginx+apache вполне рабочая.

    На счет безопасности много не скажу, но взломов именно сервера за три года не было, хотя нафик он кому нужен :)
    Ответ написан
    Комментировать
  • VestaCP. Как она в плане безопасности, да и вообще, в роли панели управления VDS?

    webirus
    @webirus
    Тыжверстальщик! Наверстай мне упущенное...
    Чисто интуитивно мне она не нравится.
    Я плачу 4 бакса за айсипи и доволен.
    Но функционал не уступает у весты.
    Ответ написан
    Комментировать
  • VestaCP. Как она в плане безопасности, да и вообще, в роли панели управления VDS?

    Kinozol
    @Kinozol
    Тёплый LAMPовый вебдев :)
    Весьма котируется, вот недавно уже богиней величали :)
    https://habrahabr.ru/company/ua-hosting/blog/274029/
    Сам я бы именно её поставил.

    зы На своих VPS панели не нужны, только лишняя прослойка.
    Пришло время менеджеров конфигураций (puppet, ansible, chef и т.д.) и docker.
    Ответ написан
    Комментировать
  • C чего начать обучение YII?

    @sergyx
    Ответ написан
    Комментировать
  • C чего начать обучение YII?

    @SilverSlice
    Лучше начинать сразу со второй версии. Вот вам материалы:
    Ответ написан
    1 комментарий
  • Objective-c, как начать обучение с нуля?

    @onepavel
    Консультация и разработка мобильных приложений
    Книга, проще некуда vk.com/doc26136448_437186611
    Для старта самое то, после уже более серьезные книги.
    Ответ написан
    1 комментарий
  • Как сохранить типы данных при выборке из MYSQL?

    artgrosvil
    @artgrosvil
    #dev #programming #student #startups #chill
    Проверьте, точно ли у вас в базе integer, ибо должно работать из коробки. Как вариант, приводите к int вручную.
    (int)$a;

    См. комментарии. Стыдно.
    Ответ написан
  • Обфускация PHP кода. Или использование API проверки лицензии. Какие варианты подскажете?

    abyrkov
    @abyrkov
    JavaScripter
    НИКАК.
    НИКАК.
    И еще раз НИКАК.

    Если ваш проект заинтересует крэкеров, то он все-равно будет взломан
    Проще всего - поставить пароль на файлы. Если они утекут - смело можно жаловаться в суд на клиента
    Ответ написан
    Комментировать
  • Вывод отладочной информации. А как делаете вы?

    27cm
    @27cm
    TODO: Написать статус
    Ответ написан
    Комментировать
  • Попросили проверить код, на что смотреть нужно?

    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 комментариев
  • Как в битрикс подключить Font-Awesome?

    @fenixol Автор вопроса
    Это подключение в хедере всех скриптов.
    <?
    # Если пользователь набрал домен с www
    if (preg_match( '|^www\..*|', $_SERVER [ 'HTTP_HOST' ]))
    { # переадресовываем на домен без www
    header ( 'HTTP/1.0 301 Moved Permanently' );
    $url = trim ($_SERVER [ 'REQUEST_URI' ], '/');
    if(trim($_SERVER [ 'REQUEST_URI' ], '/') != '')
    $url .= '/';
    header('Location: electrolopata.ru'. $url);
    die();
    }

    if(preg_match('#index\.php#siU',$_SERVER['REQUEST_URI'])){
    $url = preg_replace('#index\.php#siU','',$_SERVER['REQUEST_URI'],1);
    LocalRedirect($url);
    }

    if( $_SERVER['REQUEST_URI'] == '/index.html' ){
    LocalRedirect('/');
    }
    if( $_SERVER['REQUEST_URI'] == '/index.php/' ){
    LocalRedirect('/');
    }

    if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED !== true)
    die();
    IncludeTemplateLangFile($_SERVER["DOCUMENT_ROOT"] . "/bitrix/templates/" . SITE_TEMPLATE_ID . "/header.php");
    $wizTemplateId = COption::GetOptionString("main", "wizard_template_id", "eshop_adapt_horizontal", SITE_ID);
    CUtil::InitJSCore();
    CJSCore::Init(array("fx"));
    $curPage = $APPLICATION->GetCurPage(true);
    /*
    





    */
    ?>




    <? $APPLICATION->ShowHead(false);?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/font-awesome.css"); ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/colors.css"); ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/reset.css"); ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/jquery.bxslider.css"); ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/modal.css"); ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/mistakes.css"); ?>
    <?
    if(strpos($curPage, '/cart/order/make/') === false)
    $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/select.css");
    else
    $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/jQueryFormStyler/jquery.formstyler.css");
    ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/checkbox.css"); ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/fancybox/jquery.fancybox.css?v=2.1.5"); ?>
    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/css/main.css"); ?>

    <? $APPLICATION->SetAdditionalCSS(SITE_TEMPLATE_PATH . "/jquery.fancybox.css.css"); ?>


    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/modernizr-2.6.2.min.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery-1.8.3.min.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.bxslider.min.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/rating_stars.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/fancybox/jquery.fancybox.pack.js?v=2.1.5"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.countdown.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.slider.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/mistakes.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.maskedinput.min.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/jquery.fancybox.js"); ?>

    <? if(strpos($curPage, '/cart/order/make/') === false)
    {

    $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.select.js");
    ?>


    <?
    }
    else

    {
    $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/jQueryFormStyler/jquery.formstyler.min.js");
    ?>


    <?}

    ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.nice.radio.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.checkbox.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/js/jquery.main.js"); ?>
    <? $APPLICATION->AddHeadScript(SITE_TEMPLATE_PATH . "/script.js"); ?>


    <? $APPLICATION->ShowTitle() ?>

    <?if( (strpos($_SERVER['REQUEST_URI'], '?') !== false) || ($_SERVER['REQUEST_URI'] == '/cart/') || ($_SERVER['REQUEST_URI'] == '/search/') ):?>

    <?endif;?>

    Уже перезаливали заново и при внесении в файл main.css небольшого изменения (закоментировал строку ) - вылетали стили битрикса.
    .sub-menu div > a {
    display: block;
    padding: 8px 5px 9px 49px;
    font-size: 11px;
    line-height: 13px;
    font-family: "dinpro-medium";
    /* color: #fff;*/
    text-transform: uppercase;
    white-space: pre-line;
    position: relative;
    z-index: 2;
    text-decoration: none;
    }
    После того как снова убрал сжатие файлов css - сайт заработал но файл main.css не показывает мои изменения. Кеши чистил с админки не один раз. Режим ускорения и композитный сайт отключены. Файл main.css если смотреть через фаербаг имеет такой вид main.css?144983...
    Понятно что он где то закешированый... но где его убрать? Есть предположение что на стороне хоста он закешировался и висит...
    Ответ написан
    1 комментарий