gpt4 book ai didi

javascript - 创建将收听 Telegram channel 的应用程序

转载 作者:行者123 更新时间:2023-12-01 15:10:09 40 4
gpt4 key购买 nike

首先请注意这与创建机器人无关 .

我的目标是创建一个应用程序,该应用程序将简单地收听我将为其提供的帐户订阅的任意数量的 Telegram channel ,并检索发送到这些 channel 的所有消息(就像我是一个普通用户一样)。我的猜测是我需要

  • 使用我帐户的电话号码验证自己
  • 能够为每个 channel 设置回调监听器或为所有传入消息设置通用监听器

  • 我一直在寻找 telegram api几天以来,我对它的工作原理感到非常困惑。放弃它后,我开始寻找现成的实现,主要用于 NodeJS但仍然无法找到具体的解决方案。我正在用 telegram-js api 测试一些东西但直接使用 node 运行它没用。它需要在浏览器中运行吗?有没有更简化的方法呢?最好是有良好文档的东西。

    PS:我主要精通 Java 和 Javascript,所以我优先考虑基于这些语言的库。

    编辑:

    这是我编写的代码(基本上复制了一个示例)
    var { Telegram } = require("../libs/telegram");
    var TypeLanguage = require("telegram-tl-node") ;
    var MTProto = require("telegram-mt-node");

    var schema = require("../libs/api-schema.json");

    const APP_ID = "111111";
    const APP_HASH = "fb6da8f6abdf876abd6a9d7bf6";
    const SERVER = { host: "111.111.111.11", port: "443" };
    const config = {
    id: APP_ID,
    hash: APP_HASH,
    version: '0.0.1',
    lang_code: 'en',
    authKey: null
    };

    let telegram = new Telegram(MTProto, TypeLanguage);
    telegram.useSchema(schema);
    addPublicKeys(telegram);

    let connection = new MTProto.net.HttpConnection(SERVER);

    let client = telegram.createClient();
    client.setConnection(connection);

    connection.connect(function() {
    let ready = client.setup(config);
    ready.then(function(client) {
    // it never resolves this promise
    function callback(response) {
    console.log(response);
    }
    client.callApi("help.getConfig").then(callback, callback);
    });
    });

    它使用这两个库:
    telegram-mt-node
    telegram-tl-node

    最佳答案

    迟到的答案,但可能会帮助其他人。

    您可以使用 mtproto-core使用常规 Telegram 帐户进行身份验证并收听更新(或对 Telegram 客户端做任何您可以做的事情,真的)

    这是我编写的一个示例脚本,用于监听来自用户订阅的 channel / super 组的新消息:

    const { MTProto, getSRPParams } = require('@mtproto/core');
    const prompts = require('prompts');

    const api_id = ...; // insert api_id here
    const api_hash = ' ... '; // insert api_hash here

    async function getPhone() {
    return (await prompts({
    type: 'text',
    name: 'phone',
    message: 'Enter your phone number:'
    })).phone
    }

    async function getCode() {
    // you can implement your code fetching strategy here
    return (await prompts({
    type: 'text',
    name: 'code',
    message: 'Enter the code sent:',
    })).code
    }

    async function getPassword() {
    return (await prompts({
    type: 'text',
    name: 'password',
    message: 'Enter Password:',
    })).password
    }


    const mtproto = new MTProto({
    api_id,
    api_hash,
    });

    function startListener() {
    console.log('[+] starting listener')
    mtproto.updates.on('updates', ({ updates }) => {
    const newChannelMessages = updates.filter((update) => update._ === 'updateNewChannelMessage').map(({ message }) => message) // filter `updateNewChannelMessage` types only and extract the 'message' object

    for (const message of newChannelMessages) {
    // printing new channel messages
    console.log(`[${message.to_id.channel_id}] ${message.message}`)
    }
    });
    }


    // checking authentication status
    mtproto
    .call('users.getFullUser', {
    id: {
    _: 'inputUserSelf',
    },
    })
    .then(startListener) // means the user is logged in -> so start the listener
    .catch(async error => {

    // The user is not logged in
    console.log('[+] You must log in')
    const phone_number = await getPhone()

    mtproto.call('auth.sendCode', {
    phone_number: phone_number,
    settings: {
    _: 'codeSettings',
    },
    })
    .catch(error => {
    if (error.error_message.includes('_MIGRATE_')) {
    const [type, nextDcId] = error.error_message.split('_MIGRATE_');

    mtproto.setDefaultDc(+nextDcId);

    return sendCode(phone_number);
    }
    })
    .then(async result => {
    return mtproto.call('auth.signIn', {
    phone_code: await getCode(),
    phone_number: phone_number,
    phone_code_hash: result.phone_code_hash,
    });
    })
    .catch(error => {
    if (error.error_message === 'SESSION_PASSWORD_NEEDED') {
    return mtproto.call('account.getPassword').then(async result => {
    const { srp_id, current_algo, srp_B } = result;
    const { salt1, salt2, g, p } = current_algo;

    const { A, M1 } = await getSRPParams({
    g,
    p,
    salt1,
    salt2,
    gB: srp_B,
    password: await getPassword(),
    });

    return mtproto.call('auth.checkPassword', {
    password: {
    _: 'inputCheckPasswordSRP',
    srp_id,
    A,
    M1,
    },
    });
    });
    }
    })
    .then(result => {
    console.log('[+] successfully authenticated');
    // start listener since the user has logged in now
    startListener()
    });
    })


    您可以找到 api_id 的值和 api_hash来自 https://my.telegram.org .

    在第一次运行时,脚本会提示用户输入电话号码、代码和密码。
    [+] You must log in
    √ Enter your phone number: ... <phone_number>
    √ Enter the code sent: ... <code>
    √ Enter Password: ... <2FA password>

    并且在认证结束后
    示例运行输出:
    [+] starting listener
    [13820XXXXX] Ja
    [13820XXXXX] Bis bald guys��
    [13820XXXXX] Ja. �
    [13820XXXXX] Bis später
    [13820XXXXX] Jaaa�

    我检查身份验证状态的方式是 from here .

    值得一试的替代库在撰写本文时处于事件状态(可用于创建相同的行为): Airgram (tdlib) 和 GramJs

    关于javascript - 创建将收听 Telegram channel 的应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47809485/

    40 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com