TypeError:登录蒸汽时未定义undefined

时间:2018-09-04 12:48:52

标签: javascript node.js node-modules steam

我正在从事蒸汽项目。为此,我正在使用node-steam模块。我在登录部分不满意。 我在尝试使用node-steam登录到Steam帐户时收到此异常 异常如下:

Uncaught TypeError: undefined is not a function   MYAPP/node_modules/adm-zip/zipFile.js:8 
Module.exports  /MYAPP/node_modules/adm-zip/zipFile.js:8 
module.exports /MYAPP/node_modules/adm-zip/adm-zip.js:25
handlers.(anonymous function) /MYAPP/node_modules/steam/lib/steam_client.js:252 
SteamClient._netMsg`enter code here`Received /MYAPP/node_modules/steam/lib/steam_client.js:157
emitOne events.js:75
emit events.js:150
Connection._readPacket /MYAPP/node_modules/steam/lib/connection.js:50
emitNone events.js:65
EMIT events.js:147
emitReadable__  _stream_readable.js:408  
emitReadable   _stream_readable.js:402
readableAddChunk _stream_readable.js:157
Readable.push _stream_readable.js:109
onread net.js:510
Error: Disconnected
at SteamClient._disconnected (/MYAPP/node_modules/steam/lib/steam_client.js:186:24)
at emitOne (events.js:75:13)
at Connection.emit (events.js:150:7)
at TCP.close (net.js:457:12)

我的源代码如下:

var fs = require('fs');
var Steam = require('steam');
var crypto = require('crypto');

var serverlist = [] //server list here
Steam.servers = serverlist;

var steamClient = new Steam.SteamClient();
var steamUser = new Steam.SteamUser(steamClient);

steamClient.connect();

steamUser.on('updateMachineAuth', function (sentry, callback) {
    console.log('writing to file sentry');
    fs.writeFileSync('sentry', sentry.bytes);
    callback({ sha_file: getSHA1(sentry.bytes) });
});

function getSHA1(bytes) {
    var shasum = crypto.createHash('sha1');
    shasum.end(bytes);
    return shasum.read();
}

steamClient.on('connected', function () {    
    steamUser.logOn({
        account_name: “XXXXXXXX”,
        password: “XXXXXXXX”,
        // un-comment this when providing secondary auth-code from email
        auth_code: ‘XXX’,
        sha_sentryfile: getSHA1(fs.readFileSync('sentry'))
    });
});

steamUser.on('loggedOn', function () {
    console.log('Logged in!');
});


steamClient.on('debug', function (response) {
    console.log("debug: " + response);
});

steamClient.on('logOnResponse', function (response) {
    console.log(">>logOnResponse");
    console.log(response);

if (response.eresult == Steam.EResult.OK) {
    console.log('Logged in!');
    // Your code here
}

});

steamClient.on('error', function (error) {
    console.log(error.stack);
    alert("yes error");
});

steamClient.on('servers', function (servers) {
    alert(servers);
    // fs.writeFile('servers', JSON.stringify(servers));
});

steamClient.on('disconnected', function (s) {
    alert(s);
});

以下是我安装的版本。

节点版本:v10.8.0 NPM版本:6.4.1 Steam版本:1.4.0 操作系统:Mac

请帮助我解决此问题。

1 个答案:

答案 0 :(得分:0)

正在产生undefined is not a function错误,因为您正在alert中调用函数node

那是无效的,因为在节点中没有这样的函数被调用,并且由于您在errorHandler中也具有该函数,因此应用程序死亡。

如果要删除的函数alert是创建的,并且“警告”该函数将console.log()发生错误,则该错误将消失。

尝试将此功能添加到您的代码中或删除所有警报功能:

const alert = () => {
  console.log(arguments)
}
相关问题