diff --git a/packages/plugins/plugin-lib/src/ssh/ssh-access.ts b/packages/plugins/plugin-lib/src/ssh/ssh-access.ts index 9e4786e3..60c9d90a 100644 --- a/packages/plugins/plugin-lib/src/ssh/ssh-access.ts +++ b/packages/plugins/plugin-lib/src/ssh/ssh-access.ts @@ -63,6 +63,17 @@ export class SshAccess extends BaseAccess { }) passphrase!: string; + @AccessInput({ + title: "伪终端", + helper: "如果登录报错:all authentication methods failed,可以尝试开启伪终端模式进行keyboard-interactive方式登录", + value:false, + component: { + name: "a-switch", + vModel: "checked", + }, + }) + pty = false; + @AccessInput({ title: "socks代理", helper: "socks代理配置,格式:socks5://user:password@host:port", diff --git a/packages/plugins/plugin-lib/src/ssh/ssh.ts b/packages/plugins/plugin-lib/src/ssh/ssh.ts index a86b7464..7000d570 100644 --- a/packages/plugins/plugin-lib/src/ssh/ssh.ts +++ b/packages/plugins/plugin-lib/src/ssh/ssh.ts @@ -170,7 +170,9 @@ export class AsyncSsh2Client { // } return new Promise((resolve, reject) => { this.logger.info(`执行命令:[${this.connConf.host}][exec]: \n` + script); - this.conn.exec(script, { pty: true, env: opts.env }, (err: Error, stream: any) => { + // pty 必须为false, 否则返回值会带上 所有输出,影响返回结果判断, 比如 root#: xxxx + // 当使用keyboard-interactive 登录时,需要pty + this.conn.exec(script, { pty: this.connConf.pty ?? false, env: opts.env }, (err: Error, stream: any) => { if (err) { reject(err); return; @@ -475,7 +477,7 @@ export class SshClient { script = envScripts.join(newLine) + newLine + script; } } - return await conn.exec(script as string, { env: options.env }); + return await conn.exec(script as string, {}); }, }); }