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

推荐订阅源

Hacker News: Ask HN
Hacker News: Ask HN
U
Unit 42
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
人人都是产品经理
人人都是产品经理
IT之家
IT之家
P
Privacy International News Feed
C
CXSECURITY Database RSS Feed - CXSecurity.com
酷 壳 – CoolShell
酷 壳 – CoolShell
Jina AI
Jina AI
C
Cybersecurity and Infrastructure Security Agency CISA
爱范儿
爱范儿
Cyberwarzone
Cyberwarzone
罗磊的独立博客
Latest news
Latest news
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园_首页
美团技术团队
G
GRAHAM CLULEY
Help Net Security
Help Net Security
S
Secure Thoughts
博客园 - Franky
博客园 - 叶小钗
Application and Cybersecurity Blog
Application and Cybersecurity Blog
T
Tailwind CSS Blog
Microsoft Security Blog
Microsoft Security Blog
S
Security Archives - TechRepublic
博客园 - 司徒正美
Schneier on Security
Schneier on Security
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
P
Palo Alto Networks Blog
T
Threat Research - Cisco Blogs
C
CERT Recently Published Vulnerability Notes
Hacker News - Newest:
Hacker News - Newest: "LLM"
Forbes - Security
Forbes - Security
Google Online Security Blog
Google Online Security Blog
A
About on SuperTechFans
Y
Y Combinator Blog
Stack Overflow Blog
Stack Overflow Blog
V
Visual Studio Blog
D
Docker
Martin Fowler
Martin Fowler
P
Proofpoint News Feed
Engineering at Meta
Engineering at Meta
S
Securelist
N
News | PayPal Newsroom
Project Zero
Project Zero
云风的 BLOG
云风的 BLOG
Blog — PlanetScale
Blog — PlanetScale
Recent Commits to openclaw:main
Recent Commits to openclaw:main
B
Blog RSS Feed

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

Ловим музу за клавиатуру: как айтишнику стать автором Что умеет Midjourney в 2026? Мой немного грустный разбор этого шикарного инструмента Никто не любит писать тесты, но ИИ может исправить это IPv8 выглядит как мечта. Поэтому почти наверняка не взлетит Производители вернули в продажу материнки с DDR3. Что происходит? Управление агентом с телефона через Telegram теперь в KodaCode От координации к лидерству: как меняется роль руководителя разработки Я сделала родителям бизнес вместо пенсии: зарабатываем 70 тысяч, мама не даёт продать В три раза быстрее приемка товара и оптимизация трудозатрат на 73%: как «РСТ-Инвент» помог Gulliver Group ИИ-шечный мир победил? О влиянии искусственного интеллекта на игропром Кремль снижает давление на Телеграмм пока Европа строит интернет по паспорту Как CEO, CTO и CIO за 8 часов собрали ИИ-директора, который умеет держать позицию под давлением Как (не) потерять домен за выходные Вместо 8 разных VPS: как я организовал практику студентам на одном сервере Почему твой Open Source проект не замечают? R&D: искусство управления неопределенностью в разработке AI-дефляция: вакансий для разработчиков больше, а рост зарплат — худший за 15 лет Мы отдали управление роботами OpenClaw. Что из этого вышло Галактический ID: система идентификации для всех форм разумной жизни Шесть основ бизнес-анализа: начинаем с вопроса «Кто в игре?» Код-ревью, в котором дело не в коде Данные переехали. Команда — нет Системной подход к сдаче 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 миллионов точек без потерь
RMS: упрощаем сотрудникам жизнь в поиске Internet-ID
Александр · 2026-06-15 · via Все публикации подряд на Хабре

Простой

5 мин

14

Привет! Я — Саша Басун, инженер направления пользовательских ИТ-сервисов в «Петрович-Тех». Сегодня я пришёл к вам с историей о том, как вывод значения ключа из реестра Windows может упростить обработку заявок в отделе технической поддержки.

Если коротко: помощь со стороны нашей техподдержки нередко начиналась с мема «Давайте поможем Даше найти Internet-ID на рабочем столе». Тут нет-нет, да все стадии от гнева до принятия пройти придётся. В итоге после заявки, которая пришла уже мне, родилось маленькое, но изящное решение на C#. 

Я вообще люблю проблемы, которые в океане глобальных процессов теряются настолько, что плавают примерно в районе дна Марианской впадины. То со сканером в Kyocera разберусь, то пойму как запускать скрипты в FortiClient, то в Windows любой тип ссылок с любым приложением свяжу. А теперь под руки попалась задача с RMS Host.

Что такое RMS

RMS (Remote Manipulator System) — программа для удалённого администрирования. Проще говоря — аналог TeamViewer, Anydesk и подобных решений. На фоне ассортимента можно долго дискутировать, достаточно ли хорош RMS или нет.

Но меня устраивает. Базовые функции для администрирования у него есть: удалённое управление, просмотр, удалённый запуск командной строки, передача файлов, чат с пользователем.

У RMS есть два популярных клиентских приложения — агент и хост. И в плане интерфейса с агентом проблем нет. Запускаешь, на экране отображается ID и пароль. Сообщаешь данные техподдержке. А вот к хосту есть вопросик. И сразу даже не скажешь: это баг или фича?

В чём проблема?

С точки зрения администрирования RMS Host удобен тем, что после установки на ПК он запускается в виде службы. В отличии от агента тут работает интеграция с Active Directory. Казалось бы, подключайся по IP или имени ПК, и будет тебе счастье. Но бывают случаи, когда подключиться получается только по Internet-ID.

 Я уже говорил, что в агенте с этим всё наглядно и понятно. А чтобы вывести на экран Internet-ID в хосте, нужно немножко пострадать.

Для сисадмина или сотрудника техподдержки логика действий понятна: нужно открыть трей, нажать правой кнопкой мыши на иконку хоста, выбрать пункт «Настройка Internet-ID соединения». И вот заветные цифры перед нами. А вот как это выглядит при работе с пользователями.

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

После того, как мы нашли трей, начинаем искать хост. «У вас там должен быть RMS Host. У него значок голубенький. Или ещё может быть красным или серым. Наведите на иконку, там имя приложения появится», — у хоста цвет иконки зависит от состояния работы. Отлично, хост мы нашли. Просим нажать на него правой кнопкой мыши и выбрать нужный пункт.

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

Поиск решения

На форуме программы я искал решение в надежде, что получить значение Internet-ID можно при помощи какого-нибудь ключа. И в более свежих версиях такой ключ появился — «-printid». Проблема только в том, что для выполнения этой операции требуются права администратора. А в домене, как вы понимаете, у пользователя таких прав нет.

Всё на том же форуме я нашёл более ранний ответ, который гласил, что подобной функции в приложении нет. А сам Internet-ID хранится в реестре в XML формате. Окей, раз он там хранится, давайте его оттуда и вытащим.

Упрощаем жизнь

Параметры RMS Host хранятся в ветке HKEY_LOCAL_MACHINE\SOFTWARE\TektonIT\RMS Host\Host\Parameters, а сам Internet-ID находится в одноименном бинарном ключе.

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

  1. Перевести значение ключа в XML формат

  2. Спарсить Internet-ID из тега <internet_id></internet_id>

  3. Вывести полученный результат сотруднику на экран.

Достать значение из ключа реестра можно разными способами, но для удобства пользователей на помощь пришли C# и Windows Forms. Скомпилированное приложение весит крохи, а благодаря NET Framework запускается без сторонних библиотек.

Первым делом в проекте создаём форму, в которую добавляем textbox и присваиваем ей имя. Например, textBoxInternetId. Далее в редакторе формы прописываем следующий код:

Form1.cs

using Microsoft.Win32;
using System;
using System.Text;
using System.Windows.Forms;
using System.Xml;

namespace RMSID
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            // Вызываем наш основной метод для чтения данных
            GetRMSInternetID();
        }

        private void GetRMSInternetID()
        {
            // Ветка реестра, где находятся настройки программы
            const string RMSsubKeyPath = @"SOFTWARE\TektonIT\RMS Host\Host\Parameters";

            // Ключ, где хранится Internet-ID
            const string RMSInternetIDKey = "InternetId";

            try
            {
                // Открываем ветку реестра 
                using (RegistryKey baseKey = RegistryKey.OpenBaseKey(RegistryHive.LocalMachine, RegistryView.Registry64))
                using (RegistryKey key = baseKey.OpenSubKey(RMSsubKeyPath))
                {
                    if (key != null)
                    {
                        // Получаем значение ключа
                        object valueObj = key.GetValue(RMSInternetIDKey);

                        if (valueObj is byte[] binaryData && binaryData.Length > 0)
                        {
                            // Обработка BOM (Byte Order Mark)
                            byte[] bomUtf8 = { 0xEF, 0xBB, 0xBF };
                            byte[] dataToDecode = binaryData;
                            if (binaryData.Length >= 3 &&
                                binaryData[0] == bomUtf8[0] &&
                                binaryData[1] == bomUtf8[1] &&
                                binaryData[2] == bomUtf8[2])
                            {
                                dataToDecode = new byte[binaryData.Length - 3];
                                Array.Copy(binaryData, 3, dataToDecode, 0, dataToDecode.Length);
                            }

                            // Декодирование и парсинг XML
                            string xmlString = Encoding.UTF8.GetString(dataToDecode);
                            XmlDocument doc = new XmlDocument();
                            doc.LoadXml(xmlString);

                            // Извлечение значения <internet_id>
                            XmlNode internetIdNode = doc.SelectSingleNode("//internet_id");
                            if (internetIdNode != null)
                            {
                                // Отображаем результат в текстовом поле
                                textBoxInternetId.Text = internetIdNode.InnerText;
                            }
                            else
                            {
                                // Если вдруг тег <internet_id> не найден
                                textBoxInternetId.Text = "Элемент <internet_id> не найден.";
                            }
                        }
                        else
                        {
                            // если в ветке реестра нет ключа InternetId.
                            // Можно написать ошибку, но я оставил поле пустым.
                            textBoxInternetId.Text = $"";
                        }
                    }
                    else
                    {
                        textBoxInternetId.Text = $"Ветка реестра '{RMSsubKeyPath}' не найдена.";
                    }
                }
            }
            catch (Exception ex)
            {
                textBoxInternetId.Text = $"Ошибка: {ex.Message}";
            }
        }
    }
}

Запускаем, проверяем. И вот результат:

Распространяем программу на рабочие столы, например, через групповую политику. Теперь сотрудников можно просить запустить «ярлык» на рабочем столе. И ничего не нужно искать в трее.

Наслаждаемся результатом

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

Очень люблю, когда несколько строчек кода экономят силы, время и нервы. Надеюсь, это решение или похожее на него в скором будущем появится в самом RMS. Если есть замечания или предложения по коду — пишите в комментариях. 

Спасибо!