一、http方式提交
1. Token 获取
setting > Developer settings > Personal access tokens > Generate new token 即可
注意token生成后务必妥善保存,后续不可再次在github网站查看token
2. 代码上传
进入本地代码仓库
git init #初始化
git add . #添加进所有文件
git commit -m “first commit” #上传缓冲区
git remote add origin https://[token]@github.com/[username]/[repo_name].git #将本地仓库和远程Github仓库连接(建议使用ssh提交,见下文)
git checkout -b main #从默认本地master分支切换到main分支
git branch -D master #删除本地master分支
git push -u origin main #上传代码到github main 分支
注意:如果github仓库已有内容,会报错,需要先pull下来到本地在push,或者使用强制上传命令 git push -u origin main -f
至此代码已上传完成。
3. 代码更新
git add .
git commit -m “update”
git push -u origin main
完成代码更新
二、ssh提交
来源:https://blog.csdn.net/little_stick_i/article/details/127511581
前言
众所周知,GitHub是我们程序员在上班或者学习的时候经常会逛的一个地方[手动狗头],而且如果我们想参与开源项目的话,GitHub也是一个很好的平台。
可问题是,提交代码到GitHub总是超时,简直烦死😭😭。
有时候我们在Gitee上看到一个好的开源项目想要参加,但是别人可能只是从GitHub同步到Gitee的,Gitee上的社区完全没人交流,那这种情况下,想参与项目贡献还是得去GitHub才行😖🤐。
为什么我们访问GitHub这么慢呢?引用网上的解释:
GitHub的CDN域名遭到DNS污染,无法使用GitHub的加速分发服务器,而它的服务器又是在国外,所以国内的访问速度就会很慢。
解决方案
我们要解决的,是使用git bash操作GitHub远程仓库时总是超时的问题,比如拉取代码、提交代码等。
大多数同学可能是使用的http协议创建的远程连接,就是当我们创建远程仓库的时候,使用的是下图里HTTPS的链接:
其实很多朋友都不知道,用SSH协议操作GitHub仓库其实是很流畅的,我已经用了半年了,真的非常流程,不需要开任何科技。
如果不确定自己是否使用的HTTP协议还是SSH协议,可以通过指令git remote -v show来查看:
像我这里同时添加了两个远程仓库,一个是GitHub(用的SSH协议),另一个是Gitee(用的HTTP协议)。
用HTTP协议连接GitHub远程仓库不行吗?
如果是对于国内的Gitee或者自己公司的Git仓库,那我们用HTTP协议作为远程仓库都是可以正常访问的。
但对于GitHub来说,那就不行了。那会让你感觉到什么叫写了代码却提交不上🤣,反复重试也只是不断超时,运气好的时候才能正常操作。
所以我们要使用SSH协议来作为GitHub远程仓库的链接。这样就会很流畅了,非常的流畅,跟用Gitee一样流畅🤣🤣。
下面给大家介绍一下SSH的配置方式,学会了就可以自己去配置啦!
配置SSH
SSH是通过公钥密钥的方式来验证身份的,密钥放在自己电脑上,公钥存到平台上,所以我们配置好之后,就不再需要使用账号密码登录了。而且你在本机生成好密钥之后,可以在多个平台使用,你只需要把公钥存放在多个平台就好了,他们可以通过密钥识别你的身份。
其实配置SSH的教程网上有很多,如果大家看我下面的教程还没明白,可以上百度再搜一些其他的教程学习
1. 检查是否存在sshkey
在C:\Users\用户名\.ssh文件夹下可以看到当前电脑的sshkey。
如果有 id_rsa 和 id_rsa.pub 两个文件,就说明已经存在了,可以跳过生成密钥对的步骤,如果找不到目录或者没有这两个文件,则需要先生成。我这里是已经有了的,为了给你们演示,我先把他们删掉😎。
2. 生成密钥对
在 cmd控制台 上使用如下命令来生成 sshkey:
ssh-keygen -t rsa -C "xxxxx@xxxxx.com"
1
注意:这里的 xxxxx@xxxxx.com 只是生成的 sshkey 的名称,并不约束或要求具体命名为某个邮箱。
网上的大部分教程均讲解的使用邮箱生成,其一开始的初衷仅仅是为了便于辨识所以使用了邮箱。
输入上面的指令并回车后会弹出一些提示:
第一次提示保存路径,一般不需要修改,直接回车就行
第二次提示输入密码短语(等于是sshkey的密码),可以有也可以没有(建议还是设置一下),注意输入密码的时候是不会回显的,这里假设我设置的是 123456
第三次是重复输入密码
完成三次操作后就生成完毕了,这时候再到.ssh的文件下面去看,能看到你的id_rsa 和 id_rsa.pub 两个文件,就说明你已经生成成功了。
注意这个 id_rsa.pub 是公钥,将来要放到GitHub上的,另一个id_rsa是私钥,等于是你的密码,保存好,不要随便发给别人。
3. 把公钥放到GitHub上
打开GitHub(打不开咋办?那先看下面的访问GitHub网页教程🤣🤣🤣)
点击头像 -> settings:
点击左边 SSH and GPGkeys,再点击右边 New SSH key:
写个标题(可以随便写,但建议写主机名),然后把刚刚生成的 id_rsa.pub 里面的内容复制过来,粘贴在下面的 key 那个框里(对没错,直接ctrl A全选复制就行):
最后点击 Add SSH key,系统会让你输入GitHub账号的密码,然后就添加完成啦!
4. 测试
我们用刚配置的sshkey拉取一下GitHub上的项目代码试试。
直接去项目里复制一下ssh的链接:
然后到本机找个文件夹打开 Git Bash,输入 git clone 指令:
这时候会让你输入密码短语,这个就是我们前面生成密钥的时候设置的东西,我设置的是 123456 ,那么输入密码,回车,就可以看到项目被成功拉取啦!这个密码只有第一次拉取项目的时候会让你输入,后面再进行别的操作就不需要弄了。
至此,我们的SSH就配置完成啦!学会的朋友可以去试试了,保证你的 clone、pull、push 等操作将会非常流畅🤣🤣
后记
本篇文章讲解了如何流畅的提交代码到GitHub,给出的解决方案是通过配置SSH密钥,如果文章中有任何错误的地方,欢迎各位在评论区指正🥰。
由于CSDN审核的原因,关于访问GitHub网页的解决方案被我删掉了,需要的朋友可以参考这篇文章:https://juejin.cn/post/7158258577113612302