环境:
windows > git > bash
场景:
在编写一个自动将本地文件通过sftp上传到服务的脚本时,每次都要通过命令行输入密码,就很不方便,找了很多办法都需要安装其他命令,但是公司是内网开发,条件不允许。
解决方案:
-
打开 Git Bash 终端并输入以下命令:
ssh-keygen
-
按Enter键三次以接受默认的文件名和位置。
-
输入一个密码短语(可选)。如果不想使用密码短语,可以直接按Enter键。
-
使用以下命令将公钥复制到远程服务器:
ssh-copy-id user@ip
-
输入远程服务器的密码,现在,可以使用以下命令连接到远程服务器,而无需输入密码:
sftp user@ip
注意:
如果没有安装ssh-copy-id命令,则可以手动将公钥复制到远程服务器。将公钥复制到远程服务器的步骤如下:
- 打开公钥文件(~/.ssh/id_rsa.pub)并将其内容复制到剪贴板。
- 在远程服务器上,打开目录~/.ssh/,如果目录不存在,则创建该目录。
- 在 ~/.ssh/ 目录下创建一个文件名为 authorized_keys 的文件。
- 将公钥内容粘贴到 authorized_keys 文件中,并保存该文件。
现在,您可以使用以下命令连接到远程服务器,而无需输入密码:
sftp user@ip