惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

L
LINUX DO - 最新话题
Spread Privacy
Spread Privacy
Cyberwarzone
Cyberwarzone
The Hacker News
The Hacker News
P
Privacy & Cybersecurity Law Blog
S
Securelist
P
Palo Alto Networks Blog
PCI Perspectives
PCI Perspectives
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Apple Machine Learning Research
Apple Machine Learning Research
S
SegmentFault 最新的问题
Help Net Security
Help Net Security
月光博客
月光博客
博客园 - 【当耐特】
IT之家
IT之家
Cloudbric
Cloudbric
Know Your Adversary
Know Your Adversary
V
V2EX
Security Latest
Security Latest
Application and Cybersecurity Blog
Application and Cybersecurity Blog
The Last Watchdog
The Last Watchdog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
C
Check Point Blog
酷 壳 – CoolShell
酷 壳 – CoolShell
AI
AI
Vercel News
Vercel News
C
Cyber Attacks, Cyber Crime and Cyber Security
MongoDB | Blog
MongoDB | Blog
V
Visual Studio Blog
Google DeepMind News
Google DeepMind News
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
WordPress大学
WordPress大学
T
Tailwind CSS Blog
美团技术团队
博客园 - 三生石上(FineUI控件)
NISL@THU
NISL@THU
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
T
Tor Project blog
S
Security Affairs
J
Java Code Geeks
B
Blog RSS Feed
G
Google Developers Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
T
Troy Hunt's Blog
aimingoo的专栏
aimingoo的专栏
Forbes - Security
Forbes - Security
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
腾讯CDC
罗磊的独立博客
宝玉的分享
宝玉的分享

Все публикации подряд на Хабре

Ловим музу за клавиатуру: как айтишнику стать автором Что умеет Midjourney в 2026? Мой немного грустный разбор этого шикарного инструмента Никто не любит писать тесты, но ИИ может исправить это IPv8 выглядит как мечта. Поэтому почти наверняка не взлетит Производители вернули в продажу материнки с DDR3. Что происходит? Управление агентом с телефона через Telegram теперь в KodaCode От координации к лидерству: как меняется роль руководителя разработки Я сделала родителям бизнес вместо пенсии: зарабатываем 70 тысяч, мама не даёт продать В три раза быстрее приемка товара и оптимизация трудозатрат на 73%: как «РСТ-Инвент» помог Gulliver Group ИИ-шечный мир победил? О влиянии искусственного интеллекта на игропром Кремль снижает давление на Телеграмм пока Европа строит интернет по паспорту Как CEO, CTO и CIO за 8 часов собрали ИИ-директора, который умеет держать позицию под давлением Как (не) потерять домен за выходные Вместо 8 разных VPS: как я организовал практику студентам на одном сервере Почему твой Open Source проект не замечают? R&D: искусство управления неопределенностью в разработке AI-дефляция: вакансий для разработчиков больше, а рост зарплат — худший за 15 лет Мы отдали управление роботами OpenClaw. Что из этого вышло Галактический ID: система идентификации для всех форм разумной жизни Кто решает судьбу вашего проекта? Разбираем заинтересованные стороны. BABOK #1 Код-ревью, в котором дело не в коде Данные переехали. Команда — нет Системной подход к сдаче OSWE в 2025 Почему комната управления реактором покрашена в цвет морской пены 4 YAML-файла вместо PySpark: как аналитикам строить пайплайны без разработчиков LLM-агент для поиска свободных доменов: автоматизируем подбор Когда, зачем и как правильно начинать новую сессию в Claude Code? Как я заставил нейросеть писать макросы для FreeCAD Анатомия ИИ‑агента для подбора персонала. От тысячи резюме к топ‑10 за минуты Опыт разработчика как экономика внимания Автономность как точка невозврата: кто будет субъектом в цифровом будущем Обучение ИИ в «диких» условиях: как рутинные действия превращаются в датасеты Как измерить LLM для задач кибербеза: обзор открытых бенчмарков Где хранить код? Сравнение GitHub, GitLab и Bitbucket Математика объясняет, почему нормальное распределение встречается повсюду Почему ваш FinOps не работает: 12 тезисов от практиков Как подписать проектную документацию УКЭП с использованием бесплатных лицензий Pilot Адаптивное администрирование Sigla Vision Я грузил уран в бочки, а потом 20 лет строил ИТ в атомной отрасли Чем позвонить с Эвереста? История и обзор спутниковой связи. Часть 2 Как языковая модель помогает контролировать качество инструктажей по охране труда в металлургии Как не передать на desktop свой IP в РКН Анатомия SAP Privileges: как устроено управление правами в macOS MoneyDev: Сказка про три главных слова Обновлённый токенизатор видео K-VAE 2.0 от Сбера Как сделать диспетчеризацию дома на 1284 квартиры почти бесплатно Как мы разогнали железную дорогу Мы дали агентам рутину. Теперь надо решить — что делать с освободившимся временем Токсичный контент, промпт-хакинг и защита ИИ — всё о Guardrails для LLM Умный город начинается с точного взгляда: как «Фалькон Тех» меняет пространство к лучшему Навайбкодил приложение для анализа графов Почему Дюну так интересно читать? Упрощаем работу с рутиной или как стать Гендальфом Белым Деконструкция Go: CPU, RAM и что там происходит. Go Assembler база. Часть 1.1 Какие профессии исчезнут из-за ИИ, а какие появятся? И что с этим делать Как мы построили IT-отдел, где хочется расти: архитектурные встречи, прозрачные метрики и книжные подарки Rufler: Делаем из Claude Code автономный рой через один YAML-конфиг Sing-box и белый список приложений Как построить надёжный обмен сообщениями в микросервисах: лучшие практики для enterprise OpenAI строит MLM-пирамиду, а McKinsey и Accenture помогают ей в этом Дом, который не построил Фишер (Часть 2) «Сверхзвуковой математик» против «Вдумчивого логиста»: битва алгоритмов 3D-упаковки Мультимодальные модели – грубый и дорогой инструмент Разговоры ничего не стоят. Код тоже Проверки физических лиц: с кого начнет ФНС Топ-10 бесплатных нейросетей для создания видео в 2026 году Первые слои кода: как наши решения сегодня определяют архитектуру ИИ на десятилетия Разработка нового статического анализатора: PVS-Studio JavaScript Поиск уязвимостей ПО: базовый минимум или роскошный максимум Почему оценка персонала не работает как инструмент управления Как мы разработали ИИ-ассистента и сократили рутину продуктовой команды на 50% Как я ушел из найма, нажарил косточек и продал на маркетплейсах на 168 млн в год Когда 1С:ERP уже внедрена, а нормального производственного плана всё ещё нет Как я сделал Claude мультимодальным, подключив к нему Qwen Omni Как приглашение на вакансию мечты превращается в атаку Infrastructure as Code: философия и лучшие практики IaC Тестируем Yandex Code Assistant на задаче, в которой нужно хранить секреты nxs-universal-chart v3.0: новое поколение универсального Helm-чарта Callback Injection: Техника, которая отправила Microsoft Defender в глухой нокаут «Все идеи на стол»: митап как способ вывести проект из тупика Сегодня я узнал нечто новое о GPU благодаря багу в своей игре Как заставить LLM ̶ ̶г̶а̶л̶л̶ю̶ ̶ эволюционировать Карта событий как фундамент аналитики: практический кейс для E-commerce Что выбрать для AI: x86, ARM или RISC-V? Дайджест железа за март Роль соматических мутаций в развитии аутоиммунных заболеваний: путь к избирательной терапии Mythos от Anthropic — тревожный сигнал для всех, а не только для банков Guardrails для LLM на Java: как приручить промпт‑инъекции и токсичные ответы Green-VLA: как мы собрали VLA-модель для реального антропоморфного робота и не потеряли обобщение Финансовая гонка вооружений: почему умные люди добровольно в ней участвуют Эра ИИ-агентов наступила: выбираем лучшего цифрового сотрудника # Практический опыт внедрения WinCC Redundancy на производственном предприятии Сделал MVP за 3 дня, а потом неделю прикручивал оплату. Оно того стоило? Физика против Маска: почему Starship V3 может оказаться ещё одной катастрофой Нефть Венесуэлы: крупнейшие запасы в мире, но не крупнейшая нефтяная держава JPA 4. Переосмысление Hibernate Почему зеркальная фотокамера Nikon D5 десятилетней давности идеально подошла для миссии «Артемида-2» Проект «Уровень-Спутник» или как мы сделали платформу для гидрологов «Замедлиться, чтобы ускориться»: почему ИИ повышает цену ошибок в требованиях и архитектуре Как с нуля поднять трафик IT-компании на 1657% при бюджете 55 тыс. и выжить Pixel-perfect Downsampling — идеальная отрисовка 50 миллионов точек без потерь
Как получить api_id на my.telegram.org из России без VPN (и почему с VPN не получится)
Мария Черноярова · 2026-06-15 · via Все публикации подряд на Хабре

Простой

4 мин

177

Если вам нужны api_id и api_hash для какого-нибудь пет-проекта на Telethon или Pyrogram, а телефон у вас на российский номер - добро пожаловать в клуб. Сайт my.telegram.org из России не открывается. Включаете VPN - открывается, код приходит, доходите до экрана создания приложения, жмёте Create - ERROR. И так по кругу.

Я потратила на это часа четыре, прежде чем нашла в комментариях на GitHub объяснение, почему так происходит и как это обойти. Спойлер: проблема не в VPN, проблема в DNS. Решение - одна строчка в файле hosts, без всякого VPN.

Зачем мне понадобились api_id и api_hash

Я пишу парсер вакансий из Telegram-каналов для собственного проекта. Для доступа к Telegram API через клиентскую библиотеку (Telethon в моём случае) нужны два ключа: api_id и api_hash. Получить их можно только одним способом - зайти на my.telegram.org, авторизоваться по номеру телефона и создать приложение в личном кабинете. Регистрация бота через @BotFather тут не подходит: боты не могут читать каналы как обычные подписчики. Нужен именно пользовательский API.

Что не работало

Попытка 1. Открыть my.telegram.org без VPN. Сайт просто не открывается. Браузер крутит колесо, потом говорит “не удалось установить соединение”. Это нормально: домен заблокирован.

Попытка 2. Включить Hiddify, сервер в Нидерландах. Сайт открывается мгновенно, ввожу номер, приходит код в Telegram, попадаю в личный кабинет. Жму Create application, заполняю поля, отправляю - ERROR. Без подробностей. Просто красная плашка.

Попытка 3. Поменять название приложения на нейтральное. Вместо MyParser пишу TestApp, в описании - три слова без триггерных слов вроде “scraper” или “parser”. Тот же ERROR.

Попытка 4. Чистый профиль браузера, другой браузер, режим инкогнито. Без изменений.

В какой-то момент стало понятно, что проблема не в названии приложения и не в куках. Антифрод Telegram при создании приложения проверяет соответствие: страна номера телефона должна совпадать со страной IP-адреса. Номер у меня российский, IP через Hiddify - голландский. Они не сходятся, и заявка отклоняется.

Получается замкнутый круг: без VPN сайт не открывается, с VPN не создаётся приложение. Логичный вывод - нужен российский IP, но при этом сайт должен открыться. И тут начался долгий вечер с гуглом (нейронки ответ не находили).

Момент, когда всё встало на место

В одном из issue на GitHub нашла короткий комментарий, который объяснил: блокировка my.telegram.org в России работает на уровне DNS, а не DPI.

Короткое отступление: когда вы вводите в браузере my.telegram.org, браузер сначала спрашивает у DNS-сервера: “какой у этого имени IP-адрес?”. DNS-сервер по умолчанию - это сервер вашего провайдера. Он отвечает (или не отвечает) IP, и только потом браузер устанавливает соединение с этим IP.

DNS-блокировка - это когда провайдер на запрос “дай IP для my.telegram.org” отвечает либо отказом, либо подсовывает левый IP (например, страничку-заглушку Роскомнадзора). Браузеру некуда стучаться, сайт не открывается.

DPI (Deep Packet Inspection) - это когда провайдер смотрит внутрь самих сетевых пакетов: куда они идут, что в них, по какому протоколу. DPI работает уже на уровне трафика, а не на уровне резолва имени.

Трафик к my.telegram.org - это обычный HTTPS поверх TLS, ровно такой же, как у любого банка, любого магазина, любого корпоративного сервиса. Если бы провайдер фильтровал этот трафик по содержимому, легло бы пол-инета. Значит, режут на самом дешёвом этапе - на разрешении имени.

А раз так, то DNS можно обойти. Не через VPN - а просто прописав IP-адрес домена напрямую в файле hosts. Тогда браузер вообще не пойдёт спрашивать провайдера, он возьмёт IP из локального файла и установит соединение с российского адреса. Антифрод увидит совпадение страны номера и IP - и пропустит создание приложения.

Решение

Полная инструкция. Делается один раз, занимает пять минут.

Шаг 1. Отключить VPN. Это важно: нам нужен именно российский IP, который провайдер выдаёт по умолчанию.

Шаг 2. Открыть файл hosts.

На macOS:

sudo nano /etc/hosts

На Windows: открыть “Блокнот” от имени администратора, через него открыть файл

C:\Windows\System32\drivers\etc\hosts

Без прав администратора файл откроется только на чтение.

Шаг 3. Добавить в конец файла строку:

149.154.167.220 my.telegram.org

Этот IP - один из адресов инфраструктуры Telegram. Теперь система при запросе домена будет брать его прямо из hosts, не обращаясь к DNS-серверу провайдера.

Шаг 4. Сохранить файл. В nano - Ctrl+O, Enter, Ctrl+X.

Шаг 5. Сбросить DNS-кэш. Браузер и операционная система могут помнить старый (неудачный) ответ DNS, поэтому кэш нужно почистить.

На macOS:

sudo dscacheutil -flushcache
sudo killall -HUP mDNSResponder

На Windows:

ipconfig /flushdns

Шаг 6. Полностью закрыть и заново открыть браузер. Не просто вкладку - весь процесс.

Шаг 7. Зайти на my.telegram.org. Авторизоваться по номеру, ввести код, создать приложение. На этот раз должно быть без ERROR. На странице появятся App api_id и App api_hash.

Шаг 8. Откатить hosts. Это обязательный шаг. Открываете тот же файл, удаляете строку с 149.154.167.220 my.telegram.org, сохраняете. Если этого не сделать, то когда Telegram однажды сменит IP этого домена (а он сменит - у них огромная инфраструктура и балансировка), сайт у вас перестанет открываться вообще, и вы будете полчаса искать, почему.

Что в итоге

Парсер заработал. На всю операцию с hosts ушло минут пять - после четырёх часов ресерча в гугле

Честная оговорка: способ работает на момент написания статьи. Если Telegram сменит IP-адрес 149.154.167.220 или если в России начнут фильтровать my.telegram.org не только по DNS, но и DPI поверх - придётся искать другой обход. Но пока что для всех, кому нужны api_id и api_hash с российским номером, это самый короткий путь. Должно сработать!