Задать вопрос
  • Зачем нужны корневые сертификаты?

    CityCat4
    @CityCat4 Куратор тега Цифровые сертификаты
    //COPY01 EXEC PGM=IEBGENER
    Вся система PKI - она иерархична и построена на доверии. Больше ни на чем. Только на доверии, которое достаточно один раз обмануть, чтобы перестать доверять системе в целом.

    Есть некое множество контор, которые выпускают SSL-сертификаты. Они не самые лучшие и не самые правильные, просто однажды они собрались и решили замутить бизнес. Почему все доверяют им? Да просто потому что до недавнего времени не было поводов их обвинить в мошенничестве - там все в порядке (было) с "внутренней полицией", которая нарушителей выкидывала нафиг с пляжа.
    Ну и - самое главное - все доверяют им, потому что их корневые сертификаты размещены в хранилищах корневых сертификатов у Windows и Mozilla (Google использует хранилище Windows).

    И все

    Никакой исключительности - просто тупой договорняк размером с мир. Но, поскольку всегда есть возможность поместить в хранилище корневых (кроме как в андроиде, который сразу же начинает визжать "аааа, меня контролирует Большой Брат!") свои собственные сертификаты - эта схема всех устраивала.

    Пока ребята не решили выстрелить себе в ногу, прекратив выпуск сертификатов в зонах .ru/.su/.by/.рф просто по политическим мотивам. Их право - частный бизнес - он такой частный бизнес. Но тут все резко как-то вспомнили, что все "мировые удостоверяющие центры" вовсе нифига не мировые, а просто кучка самозванцев.

    И будут у нас скоро госСA, госсертификаты, госбраузеры и все прочее в порядке импортозамещения.

    Теперь о том, как проверяется валидность сертификата. А проверяется она очень просто - если сертификат выпущен CA, который находится в списке доверенных - он валидный.

    ВСЕ!

    Ты можешь развернуть свой CA, поместить его сертификат в хранилище корневых у себя на компе - и все сертификаты, выпущенные им - для тебя - станут валидными. Выпускай хоть для vk.com, хоть для whitehouse.gov.

    И вот именно поэтому все так боятся поместить в хранилище корневых сертификат от какого-нибудь госСA - потому что все сертификаты, выпущенные им система будет считать валидными! Она не делает разницы между сертификатом от Thawte и от "Товарищ Майор Inc." - она примет сертификат и от того, и от того. А товарищ майор, получив возможность выпускать сертификаты, валидные в Вашей системе, будет выпускать их на ходу и подсовывать их вместо "настоящих", получая доступ к сессионным ключам и таким образом расшифровывая https-трафик (что собственно Fiddler и делает)
    Ответ написан
    8 комментариев
  • Зачем нужны корневые сертификаты?

    Rsa97
    @Rsa97
    Для правильного вопроса надо знать половину ответа
    Кажется, что вся эта конструкция держится на том, что тот единственный корневой (?) сертификат, которым подписаны все остальные, есть только у удостоверяющего центра.
    Именно. Система держится на доверии к УЦ.

    почему все так боятся, что кто-то установит в их систему левый корневой сертификат?
    Потому что это позволит злоумышленнику сгенерировать свои сертификаты на произвольные имена, подписанные корневым сертификатом, которому доверяет ваша система и, при возможности перенаправления трафика, отправить вас на свой сайт или просматривать ваш https-трафик, который вы считаете зашифрованным.

    И сразу второй вопрос: почему какой-нибудь Fiddler, который устанавливает в систему свой корневой сертификат вообще работает?
    Без установки своего корневого сертификата Fiddler не сможет перехватывать https-трафик. Тот, кто ставит себе Fiddler, должен понимать, что в системе возникает уязвимость.
    Ответ написан
    2 комментария
  • Зачем нужны корневые сертификаты?

    vesper-bot
    @vesper-bot
    Любитель файрволлов
    Ну начнем с того, что корневых сертификатов приличное множество. Не один, и не один десяток даже. Пример:
    624e91669b7e4193133731.png
    64 штуки. И сертификат, подписанный любым из них, система считает доверенным. Это, собственно, и причина, почему боятся получить дополнительный корневой сертификат - заранее не знаешь, у кого есть возможность подписи с его помощью, и отличить сертификат, подписанный новым добавленным корневым (транзитивно или нет), можно только после того, как ты его получишь, при этом большинство программ не позволяют пользователю заблокировать соединение, установленное с использованием доверенного сертификата. То есть, вначале тебя с ним поимеют, потом тебе вычищать последствия.
    Fiddler точно так же устанавливает свежесозданный (это важно, новая пара ключей, которых ни у кого нет) корневой сертификат тебе в доверенные корни, и использует его, чтобы на лету генерировать сертификаты для каждого сайта, куда ты ломишься, подсовывая их браузеру, чтобы тот не вякал, а сам выполняя роль man-in-the-middle.
    Вопрос доверия имеющимся "корням" остается на совести администратора системы (то есть вас), при этом по сети могут прилетать обновления списка корневых сертификатов, после которых опять нужно проверять хранилище на случай появления нежелательных для вас корневых сертификатов.
    Ответ написан
    1 комментарий
  • Зачем нужны корневые сертификаты?

    15432
    @15432
    Системный программист ^_^
    Fiddler перехватывает подключение, создает "промежуточный сайт", с тем же именем который и подписан левым сертификатом. Так он может видеть все пересылаемые данные и HTTPS перестает быть безопасным.

    Потому все и боятся левых сертификатов, чтобы локально или на уровне провайдера ваш трафик / пароли / данные карт / переписку не прослушивали.
    Ответ написан
    1 комментарий
  • Как/чем обработать фото лица человека, чтобы оно оставалось ясным для людей, но по нему стало невозможно искать аккаунт в соцсетях?

    AgentSmith
    @AgentSmith
    Это мой правильный ответ на твой вопрос
    Самый действенный способ - не выкладывать свои фото в соцсети.
    Проверено на себе. Работает.
    Ответ написан
    2 комментария
  • Что почитать про парсинг?

    BadCats
    @BadCats
    К ответу datka - как к реальному и чисто прикладному - добавлю, что еще можно углубиться в теория формальных языков, грамматики (как работают компилятор, интерпретаторы) - что, возможно, позволит писать более универсальный код - не так сильно привязанный к верстке страницы - т.к можно пытаться анализировать html/xml - на уровне токенов и лексем, даже с кастомными классами и атрибутами для элементов. Но это очень сложная область и возможно, что "овчинка выделки не стоит".
    Ответ написан
    Комментировать
  • Как понять PlatformIO?

    profesor08
    @profesor08
    Написали расширения для VS Code, написали некоторый универсальный фреймворк для разработки. На первый взгляд выглядит неплохо.

    А на ООП можно писать, сделай врапер и пользуйся.
    Ответ написан
    Комментировать
  • Как понять PlatformIO?

    @RockindDemon
    platformio это, во-первых, всё-таки фреймворк. Он задаёт общий формат описания и структуру проекта для микроконтроллеров, умея инсталлировать тулчейны и собирать проекты под разные конфигурации. И наподобие cmake он умеет генерировать файлы проектов для работы в различных IDE.

    Во-вторых, это ещё и плагин к vscode (можно использовать и без vscode, через командную строку).

    Вещь приятная и удобная в использовании, мне нравится.
    Ответ написан
    Комментировать
  • Как именовать булевские "флаги"?

    longclaps
    @longclaps
    Весело у вас )
    Флаг DISABLE, буде он принят, будет явно указывать то, что он обрамляет легаси-код. Придёт новый программист в команду, прочтёт вот это моё предыдущее предложение, и будет не заглядывая в историю коммитов понимать, что про заенабленые фичи можно спрашивать у коллег, а задизабленые придётся разгребать самому (
    Ответ написан
    Комментировать
  • Что делать с include-ами?

    terrier
    @terrier
    Ну, в C++ так не делают.
    Вставлять результаты дефайнов в "#include" явно запрещено, хотя, может быть, было бы и полезно.
    Если вам это действительно сильно нужно - используйте предварительную кодогенерацию, пройтись скриптом по исходникам и подменить какой-нибудь "$placeholder$" на определенную some_const_name должно быть несложно.

    Правильно ли я понимаю, что препроцессор никто и никогда не будет развивать и, видимо, вскоре от него откажутся?

    Нет, пока жив C++, жив и препроцессор.
    Ответ написан
    1 комментарий
  • Какие стратегии повышения зарплаты существуют?

    xmoonlight
    @xmoonlight
    https://sitecoder.blogspot.com
    А вот я добавлю к отличному ответу Сергей Горностаев.

    1. Первое, что нужно знать: ...
    поэтому фонд оплаты труда руководитель должен держать на том минимальном уровне, который гарантирует бесперебойную работу сотрудников
    ...откуда этот фонд берётся.

    2.
    От чего вообще зависит "щедрость" руководства? Есть ли какие-то причины, которые могут заставить руководителей "среднего" звена усиленно экономить бабло? Какие цели обычно преследуют руководители?
    Зависит от того: сколько будет стоить тебя заменить для компании на такого же (или лучше) специалиста и сколько времени на это потребуется?

    Т.е., итог таков: насколько ты уникален для компании на данный момент времени, чтобы давать тебе ту ЗП, которую ты просишь на данный момент, и всегда нужно знать конкурентов (и наладить контакты заранее), куда можно перейти на более высокую ЗП (в случае, если не удастся договориться на текущем рабочем месте).
    Ответ написан
    Комментировать
  • Какие стратегии повышения зарплаты существуют?

    Jump
    @Jump
    Системный администратор со стажем.
    От чего вообще зависит "щедрость" руководства?
    Никакой щедрости нет и быть не может.
    Тут вопрос в целесообразности.
    Если платить мало - уйдет паразит, если платить много, это может быть невыгодно, да и расслабляют большие зарплаты.

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

    Есть ли какие-то причины, которые могут заставить руководителей "среднего" звена усиленно экономить бабло?
    Разумеется. Вы же не думаете что у компании неограниченное количество денег?
    Сколько бы денег не было - тысяча рублей или миллиард долларов, это сумма ограниченная, и ее нужно тратить экономно.
    Решать куда выгодней потратить больше, а куда меньше. Меньше платить разработчику - больше останется на другие цели - например на закупку оборудования, выплаты владельцам, или на погашение займов.
    Самая большая ошибка, это считать, что если компания крупная и у компании много денег, значит и платить она может неограниченно много.
    Если компания большая то у нее очень много статей расходов и расходы огромные.
    Поэтому зачастую намного выгоднее выгнать зажравшегося работника и взять нового. Но зависит от конкретной ситуации.

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

    saboteur_kiev
    @saboteur_kiev
    software engineer
    Стратегия руководителя полностью зависит от руководителя и финансов.

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

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

    3. Кроме руководителя - есть политика компании.

    В одной компании нужны простые середнячки, и держать там дорогих сеньоров невыгодно - достаточно 1-2 человека с нормальной зарплатой, на которых держится архитектура, а рост остальных компании невыгоден, так как повышать им зарплату неоткуда. В таких будет либо текучка, либо работать небольшая команда некарьеристов, которых все устраивает.
    В другой компании выгодно выращивать своих специалистов и продавать их подороже. Там будет приветствоваться рост и повышение зарплаты. Но опять таки зависит от финансирования - есть куда перевести подросших людей - хорошо. Некуда - какое-то время подержат, но просто так повышать не будут.

    В общем возможный рост зарплаты конечно зависит от компании и как компания зарабатывает.
    Ответ написан
    3 комментария
  • Какие стратегии повышения зарплаты существуют?

    CityCat4
    @CityCat4
    //COPY01 EXEC PGM=IEBGENER
    Пока ровно сидите на попе - и зарплата будет ... ровная, без повышений :) Зачем повышать ее тому, кто работает и за текущую? КапитализЪм.
    Повышение зарплаты нужно хоть чем-то да обосновать, причем "жена-дети-ипотека" не канает практически никогда. Типа твоя ипотека - ты и трахайся решай проблему. Обосновать можно повышением обьема работ, инфляцией, встречным предложением от кункурентов :)
    Как руководитель подходит к такой просьбе - замечательно разьяснил Сергей Горностаев Но тут есть тоже опасность "оверквалифайда" - не все руководители любят, когда контора держится на одной "мегазвезде". Зачастую, звезда, поняв, что тут с ней носятся как с писаной торбой, начинает "звездить"...
    Ответ написан
    5 комментариев
  • Какие стратегии повышения зарплаты существуют?

    sergey-gornostaev
    @sergey-gornostaev
    Седой и строгий
    Центральный показатель для бизнеса, а следовательно и руководителей, как людей представляющих интересы этого самого бизнеса - это коэффициент возврата инвестиций (ROI). Соответственно, сотрудник должен приносить компании больше денег, чем потребляет. Естественно, что чем выше разрыв между затратами и прибылью, тем лучше, поэтому фонд оплаты труда руководитель должен держать на том минимальном уровне, который гарантирует бесперебойную работу сотрудников. Один из факторов этой бесперебойности - низкая текучка. Сотрудников терять нежелательно. И чем ценнее для компании сотрудник, чем более он профессионален и/или чем больше на него завязано, тем дороже обходится его потеря. Натурально в деньгах. Придётся затратить больше, чем обычно, денег на поддержание работы без него. Придётся затратить деньги и время (те же деньги) на поиск, найм, введение в работу, возможно, обучение нового сотрудника. При этом он может оказаться совсем неподходящих и цикл придётся повторить. Или может оказаться просто хуже прошлого и эффективность отдела снизится. Поэтому, когда сотрудник приходит просить прибавку, руководитель оценивает может ли этот сотрудник уйти или только блефует, насколько легко его будет заменить, какой урон компании будет нанесён его уходом. Потом руководитель оценивает стоимость расширения ФОТ - есть ли резервы, какой сейчас ROI, будет ли больший ROI от реинвестиции этих средств во что-то другое? Если уход сотрудника будет стоить меньше, чем увеличение ФОТа, сотруднику откажут.

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

    Из этого вывод, стратегия проста - увеличивайте собственный профессиональный уровень на столько, чтобы свободно менять компанию, как только вас что-то перестало устраивать.
    Ответ написан
    4 комментария
  • Как определить виртуальная ли банковская карта?

    gobananas
    @gobananas
    finishhim.ru
    Нет это нельзя определить, в этом и суть виртуалки. У меня на киви, например лежит 100 тыс. рублей, я выпускаю виртуалку, кладу на неё 10 и расплачиваюсь ей вот в таких подозрительных магазинах, которым непонятно зачем мой пластик нужен (вдруг они хотят передать данные хакерам?). Я без проблем расплачиваюсь этой картой, через 3 месяца она закрывается и перевыпускается. Т.е. по вашей логике вы будете блокировать людей которые действительно заботятся о своей безопасности за подозрительную активность ))
    Ответ написан
    8 комментариев
  • Что почитать или/и что посмотреть (видео уроки) по ОС?

    MedVedar
    @MedVedar
    e-commerce developer
    Почитать Эндрю Таненбаума
    Ответ написан
    Комментировать
  • К нашей программе создали и выложили кряк - что делать?

    @McBernar
    1. Порадоваться :)
    2. Обновить алгоритм покупки
    3. Написать досудебное письмо сайтам с кряком или их хостерам
    Ответ написан
    5 комментариев
  • Как подобрать примитивный парсер?

    fox_12
    @fox_12 Куратор тега Python
    Расставляю биты, управляю заряженными частицами
    Парсер xml, либо html вам в помощь
    >>> import xml.etree.ElementTree as ET
    >>> root = ET.fromstring('<img src="some.jpg"></img>')
    >>> root
    <Element 'img' at 0x104bd5458>
    >>> root.get('src')
    'some.jpg'
    >>> root.tag
    'img'


    Хочется велосипедов - сделайте сами магию:
    >>> def some_magic(patt, str_in):
    ...     import re
    ...     patt = patt.replace('%s', '(.*)')
    ...     res = re.match(patt, str_in)
    ...     return res.groups()
    ... 
    >>>
    >>> print(some_magic('<%s=\"%s\">', '<img src="some.jpg">')) 
    ('img src', 'some.jpg')
    Ответ написан
    7 комментариев
  • Как подобрать примитивный парсер?

    Есть простой модуль parse.
    import parse
    s = '<img src="some.jpg">'
    p = '<{}="{}">'
    parse.parse(p, s)

    На выходе получите список найденных подстрок.
    Ответ написан
    1 комментарий