passh:自动化密码输入工具,让命令行操作更便捷
passh𝐬𝐬𝐡𝐩𝐚𝐬𝐬 is 𝒃𝒓𝒐𝒌𝒆𝒏 by design项目地址:https://gitcode.com/gh_mirrors/pa/passh
passh 是一个轻量级的开源工具,用于在终端中自动输入密码或回答其他预定义的问题。这个项目源于作者对自动化OpenWRT路由器配置的需求,现在已经在多种操作系统上得到了验证和应用。它不仅解决了SSH登录时密码自动输入的问题,还能帮助你在许多场景下自动化交互式命令执行。
项目技术分析
passh 的核心是利用pty(假终端)技术,模拟真实终端的行为,从而能够像人一样向程序提供输入,如密码。它支持从环境变量或文件读取密码,避免直接在命令行中暴露敏感信息,并且可以设置正则表达式匹配特定的密码提示,确保只有正确的提示才会输入密码。
此外,passh 还具备以下特性:
- 多次密码输入控制:通过参数
-c
限制最多输入多少次密码。 - 不区分大小写匹配:使用
-i
选项进行不区分大小写的密码提示匹配。 - 自动回答"Yes"或"No"的问题:使用
-y
选项应对确认性质的交互。
代码部分引用了《Advanced Programming in the UNIX Environment》(APUE)一书中的pty相关代码,保证了代码的稳定性和可靠性。
项目及技术应用场景
- 在OpenWRT等资源有限的嵌入式设备上自动运行需要密码认证的命令,如启动SSH代理服务器。
- 在Linux、macOS、FreeBSD甚至AIX等系统上,简化命令行操作,避免手动输入密码。
- 轻松实现非交互式的远程命令执行,例如通过
ssh
执行命令或复制文件。 - 在自动化脚本中,使用passh自动化处理交互式问题,如在unison同步过程中自动确认更新。
- 为命令行界面的应用程序提供自动化输入,比如启动带有自定义配置的bash会话。
项目特点
- 简单易用:通过简单的命令行参数即可定制自动化行为。
- 广泛兼容性:已在多个平台(包括OpenWRT、Linux、macOS、FreeBSD、AIX和Cygwin)上测试并通过。
- 安全性:通过指定外部文件或环境变量来存储密码,而不是直接在命令行中显示。
- 高度可配置:可以通过正则表达式匹配特定的密码提示,并设置超时等待时间。
总的来说,passh 是一个实用的终端自动化工具,无论是日常操作还是自动化脚本,都能显著提高你的工作效率。如果你经常与命令行打交道,那么passh 绝对值得你试试看!
passh𝐬𝐬𝐡𝐩𝐚𝐬𝐬 is 𝒃𝒓𝒐𝒌𝒆𝒏 by design项目地址:https://gitcode.com/gh_mirrors/pa/passh
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考