15

我想将输入提供给 Cisco AnyConnect vpncli.exe(v2.3) 的命令行界面,以自动化其(重新)连接。它不接受用户名和密码作为命令行参数,而是通过命令行界面从用户交互读取这些参数。

问题是管道输入vpncli.exe似乎不适用于密码。它适用于除密码之外的所有内容。所以做这样的事情是行不通的:

vpncli.exe < input.txt
type input.txt | vpncli.exe

该应用程序只是卡在它要求输入密码的地方。


以下是用户输入参数的正常(工作)执行示例:

示例 vpncli.exe 运行

请注意密码字符如何转换为*.


使用 AutoIt 或 AutoHotKey 之类的工具将输入发送到命令提示符窗口是可行的,但笨拙且脆弱(如果工具由于某种原因无法进入命令提示符窗口,则不起作用)。


有没有办法使用 PowerShell 将输入发送到此类交互式 CLI 应用程序?

(或者使用任何其他脚本语言或其他方式?)

4

2 回答 2

11

你需要创建一个普通的文本文件,比如

连接 myvpnhost
myloginname
mypassword

将其保存为 myfile.dat (例如),然后调用

"%ProgramFiles%\Cisco\Cisco AnyConnect 安全移动客户端\vpncli.exe" -s < myfile.dat

于 2015-01-20T14:55:28.500 回答
8

至少有两种方法可以读取 Windows 控制台应用程序中的输入。

  • ReadConsole:从键盘或重定向(文档)读取输入。
  • ReadConsoleInput: 只读取原始击键(文档)。

vpncli.exe应用程序用于ReadConsoleInput读取密码,这种重定向密码的方式不起作用。不过,您可以使用WriteConsoleInput. 我有一个小的 Python 脚本可以做到这一点:

import subprocess
import win32console

ANYCONNECT_BIN = 'c:\\Program Files\\Cisco\\Cisco AnyConnect Secure Mobility Client\\vpncli.exe'

def write_console_input(text):
  stdin = win32console.GetStdHandle(win32console.STD_INPUT_HANDLE)
  ir = win32console.PyINPUT_RECORDType(win32console.KEY_EVENT)
  ir.KeyDown = True
  for ch in text:
    ir.Char = unicode(ch)
    stdin.WriteConsoleInput([ir])

def main():
  proc = subprocess.Popen([ANYCONNECT_BIN,'connect','VPN'],stdin=subprocess.PIPE)
  proc.stdin.write('%s\n%s\n' % ('GROUP', 'USERNAME'))
  write_console_input('%s\n' % 'PASSWORD')
  ret = proc.wait()
  print ret

if __name__ == '__main__':
  main()
于 2012-08-03T07:20:35.130 回答