git 公钥权限问题Permission denied (publickey,keyboard-interactive).

本文详细介绍了当使用Git进行clone操作时遇到权限错误的具体解决步骤,包括如何正确配置SSH密钥,修改密钥文件名以及如何验证配置是否成功。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

git clone的时候报错:

Permission denied (publickey,keyboard-interactive).

fatal: Could not read from remote repository.

Please make sure you have the correct access rights

and the repository exists.

前提:公钥的生成和上传都重做了,但是还是提示这个。 下面的方法是针对你公钥这些都OK了的情况。

复现:ssh-keygen -f ~/.ssh/myname  

          提示:Your identification has been saved in /home/zorro/.ssh/myname  

                   Your public key has been saved in /home/zorro/.ssh/myname.pub  ---注1  (我这个命令生成的就是这个文件                                                                                                                                      名)

之后  ssh-add ~/.ssh/myname (正常情况下 做到这里 再在web上upload就ok了)

------------------------------------------------------------------------------------------

好了 重点来了 这时候你需要看一下ssh_config 这个文件里的

                  IdentityFile ~/.ssh/identity

                  IdentityFile ~/.ssh/id_rsa ---这个是不是和注1 不一样?

                  IdentityFile ~/.ssh/id_dsa 

如果是, 当然我们最好不要改配置文件,那么

      1.把你~/.ssh/下面生成的那俩文件 myname改成id_rsa      

mv myname id_rsa

mv myname.pub id_rsa.pub

      2.ssh-add  id_rsa.pub

如果这里报错:Could not open a connection to your authentication agent.

执行: eval `ssh-agent`  之后再add

------------------------------------------------------------------------------------------

ssh -T git@github.com      ----用这个来测试一下  最后一行不报错,那么ok了。

 

tips:所有要输密码的地方可以都回车,这样省事。

==================

如果以上还不行,请打开你的git网页,里面有个push的权限设置项,改为all users就行了 。

 

 

### 解决 Git 权限被拒 (`Permission denied (publickey)`) 问题 当执行 `git push` 命令时收到类似于以下错误信息时: ``` ERROR: Permission denied (publickey). fatal: Could not read from remote repository. Please make sure you have the correct access rights and the repository exists. ``` 这通常表明客户端未能通过基于 SSH 的身份验证。以下是具体分析以及解决方法: #### 1. **确认本地是否有有效的 SSH 密钥** 检查当前用户的主目录下是否存在 `.ssh/id_rsa` 和 `.ssh/id_rsa.pub` 文件。如果没有找到这些文件,说明尚未创建过 SSH 密钥对。可以运行以下命令生成一对新密钥: ```bash ssh-keygen -t rsa -b 4096 -C "your_email@example.com" ``` 完成之后会得到两个文件:一个是私钥(`.ssh/id_rsa`),另一个是公钥(`.ssh/id_rsa.pub`)。务必妥善保管好私钥[^1]。 #### 2. **向目标服务器添加公钥** 登录到 `linked-z.com` 提供的服务管理界面或联系管理员,将刚刚生成的公钥内容复制粘贴进去。一般情况下,在个人资料设置里会有专门用于保存 SSH Keys 的区域[^2]。 #### 3. **启动并加载 SSH Agent** 为了使系统能够自动提供正确的私钥给远程服务进行验证,需要先激活 SSH agent 并注册刚才提到的那个私钥: ```bash eval "$(ssh-agent -s)" ssh-add ~/.ssh/id_rsa ``` #### 4. **测试连接** 再次尝试建立安全通道来检验一切是否正常工作: ```bash ssh -T git@linked-z.com ``` 成功的话应该能看到类似这样的欢迎语句:“Hi [username]. You've successfully authenticated...” #### 5. **重设远端 URL** 最后一步就是确保项目里的配置指向的是经过更新后的地址形式。假如之前用错了格式或者域名拼写有问题,则可通过下面这条指令修正它: ```bash git remote set-url origin ssh://git@linked-z.com/[team]/[project].git ``` --- ### 注意事项 - 若仍然无法解决问题,请仔细核查每一步骤的操作细节,并考虑更换其他可用的身份凭证方式比如 HTTPS token 认证等作为临时替代方案。 - 对于某些特殊场景下的复杂需求而言,也许还需要额外定制化一些高级选项参数才能彻底根治此类难题[^3]。 ```python # Python 示例代码片段展示如何读取SSH公钥文件内容以便后续上传至Web接口 with open('/home/user/.ssh/id_rsa.pub', 'r') as file: public_key_content = file.read().strip() print(public_key_content) ```
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值