Git命令与Git-cli
1. 安装Git-cli
winget install --id GitHub.cli
注:以上命令用于在Windows平台CMD执行快捷安装,若需安装其他平台的Git-cli及详细内容,win安装文件一般下载amd64 installer的版本,请访问:https://github.com/cli/cli
2. 使用Git-cli进行身份验证
执行下列命令会进行身份验证并将本地gh工具与远程GitHub账户进行关联
gh auth login
注:执行该命令后会有以下提示
选择平台,这里我选GitHub,并回车
Where do you use GitHub? [Use arrows to move, type to filter]
>GitHub.com
Other
选择Git操作的协议,这里我选HTTPS,并回车
What is your preferred protocol for Git operations on this host? [Use arrows to move, type to filter]
>HTTPS
SSH
输入Y或n,确认是否使用GitHub凭证对Git进行身份验证,这里输入Y并回车
Authenticate Git with your GitHub credentials? (Y/n)
选择认证方式,使用何种方式进行认证,使用浏览器进行认证?还是使用Token进行认证?这里我选Login with a web browser,并回车
How would you like to authenticate GitHub CLI? [Use arrows to move, type to filter]
>Login with a web browser
Paste an authentication token
回车后会提示两条信息:
First copy your one-time code: B543-72FB
Press Enter to open https://github.com/login/device in your browser...
此时按回车,并按照浏览器的提示点击continue,然后将上述的验证码输入浏览器
验证码输入完成后,等待几秒,然后点击Authorize github即可完成验证(若开启了手机GitHub验证,需在手机进行授权)
操作完成后,返回CMD或Git-Bash观察,等待几秒会提示下列信息表示身份认证完成:
Authentication complete.
gh config set -h github.com git_protocol https
Configured git protocol
Logged in as xxxx
3. 使用Git-cli在GitHub上直接创建远程仓库并初始化
先在电脑上任意位置创建一个目录,这里举例为D:\Git_Repo
此时,我先进入Git_Repo目录,打开CMD执行以下命令(习惯Linux命令操作的可使用Git-Bash操作)
gh repo create myproject --private -l MIT -g "C++" --add-readme
注:执行后会输出远程仓库名如:https://github.com/xxxxxxx/myproject,此时GitHub中的远程仓库已经完成创建并初始化完成
myproject 远程仓库名
--private 设置为私有仓库
--add-readme 设置README文件
-l 设置License
-g 设置.gitignore
4. 使用Git-cli克隆GitHub中初始化完成的远程仓库
gh repo clone myproject
注:此时查看当前目录,远程仓库已经克隆到本地了
5. 进入克隆下来的仓库并进行相关操作
cd myproject
touch demo.cpp
echo "#include<iostream>" > demo.cpp
git add .
git commit -m "add a demo file"
git push origin main
至此基本的安装、认证和仓库创建操作已经结束,第5步以后的操作,按需操作即可
6. 查看本地仓库默认主分支
若未配置本地仓库默认主分支,而又先在本地创建仓库,再使用git init命令初始化仓库时,此时的本地仓库默认主分支为master
git config --global init.defaultBranch
注:若执行后无输出,则表示未配置,此时本地仓库的默认主分支可能为master,而不是main,与GitHub远程仓库的默认主分支不同步。因2020年GitHub响应社区呼吁宣布将默认分支名改为main
7. 配置本地仓库默认主分支为main
git config --global init.defaultBranch main
注:此时再执行git init初始化本地仓库,然后将本地创建的仓库推送到远程仓库时,本地仓库的默认主分支与远程仓库的默认主分支一致为main
8. 使用Git-cli删除已创建的远程仓库
gh repo delete myproject
注:在删除仓库时,会提示下列信息,此时等待你的输入,确认要删除此仓库,在冒号后输入your-username/myproject以确认删除,然后回车即可:
输入前提示:Type your-username/myproject to confirm deletion:
输入后提示:Type your-username/myproject to confirm deletion: your-username/myproject
执行删除仓库的命令时,可能会无法删除成功,并提示:
HTTP 403: Must have admin rights to Repository. (https://api.github.com/repos/Rinato-C417/myproject)
This API operation needs the "delete_repo" scope. To request it, run: gh auth refresh -h github.com -s delete_repo
提示的信息大意是:该删除操作需要delete_repo权限
此时需要执行以下命令来获取该权限:
gh auth refresh -h github.com -s delete_repo
作用是更新认证信息并请求删除仓库的delete_repo的权限,执行后需经过GitHub授权后才能继续操作
授权完成后,再次执行第8步的gh repo delete myproject删除仓库操作时,仓库此时即可删除成功
9. 使用Git-cli列出所有仓库
gh repo list
Git命令与Git-cli的更多相关文章
- 每日一条 Git 命令:git merge remote master
每日一条 Git 命令:git merge remote master 当远程的分支更新后,需要将自己的代码与远程的分支合并就用以下这个命令合并. git merge remote master 如果 ...
- git命令之git rebase 的用法
rebase 假设你现在基于远程分支"origin",创建一个叫"mywork"的分支. $ git checkout -b mywork origin 现在我 ...
- git命令之git remote的用法
git remote git remote -v git init git add xxx git commit -m 'xxx' git remote add origin ssh://softw ...
- Git 命令及git服务器
Linux 服务器上安装git yum -y install git git config --global user.name "name" git config --glo ...
- 第23月第24天 git命令 .git-credentials git rm --cached git stash clear
在git push的时候,有时候我们会想办法撤销git commit的内容 1.找到之前提交的git commit的id git log 找到想要撤销的id 2.git reset –hard id ...
- git命令之git clone用法
在使用git来进行版本控制时,为了得一个项目的拷贝(copy),我们需要知道这个项目仓库的地址(Git URL). Git能在许多协议下使用,所以Git URL可能以ssh://, http(s):/ ...
- [转]git命令之git remote的用法
git remote git remote -v git init git add xxx git commit -m 'xxx' git remote add origin ssh://softw ...
- git命令之git tag 给当前分支打标签
git tag - 标签相关操作 发表于 2011年06月29日 由 机器猫 标签可以针对某一时间点的版本做标记,常用于版本发布. 列出标签 $ git tag # 在控制台打印出当前仓库的所有标签$ ...
- git命令之git mergetool vi非正常退出.swp删除不了的问题
1.git pull命令产生无法merge的错误 使用了 git mergetool命令然后...傻逼了 进入了vi操作界面,不会操作,非正常退出... 然后就产生了.swp相关文件,死活删除不 ...
- Git命令(Git版本:Linux 2.14.3)
常用 git status 跟踪状态git commit -m "xxx" yyy.cppgit pull git pushgit mergetool --tool=meld 合并 ...
随机推荐
- SqlServer中常用的一些操作语句
我们在维护数据库数据的时候,通常会用到各种SQL语句对数据进行操作或者维护,如:查看某个数据库中有哪些用户数据表.每个数据表中总共有多少条数据-- SqlServer官方地址:https://lear ...
- DeepSeek 不再卡顿,从此告别服务器繁忙,请稍后再试(建议收藏!)
大家好,我是六哥. 由于DeepSeek真的太火了,也许你也跟我一样,常会遇到这样的情况: 真的让人抓狂,10条回复里常常有9条是"服务器blabla,请稍后重试",看到这话,就问 ...
- Arduino语法--运算符
本节介绍最常用的一些Arduino运算符,包括赋值运算符.算数运算符.关系运算符.逻辑运算符和递增/减运算符. 一. 赋值运算符 =(等于)为指定某个变量的值,例如:A=x,将x变量的值放入A变量. ...
- MONGODB数据备份与导入
主要记录下在mongo 3.0的操作 备份示例 ./mongodump -h localhost -d liongo -o ./ 还原示例 错误方式: ./mongorestore -h 127.0. ...
- 移动硬盘插入win10检测到却不显示盘符解决方法
1.开始菜单中的设置-----设备. 2.选择"蓝牙和其他设备" 3.在其他设备栏中就能看到检测到的移动硬盘,点击删除设备后重新插入移动硬盘即可在此电脑上显示盘符.
- DeepSeek-R1的“思考”艺术,你真的了解吗?
大家好~,这里是AI粉嫩特攻队!今天咱们来聊聊一个有趣的话题--DeepSeek-R1到底什么时候会"思考",什么时候又会选择"偷懒"? 最近有朋友问我:&qu ...
- 【软件开发】Doxygen使用笔记
[软件开发]Doxygen 使用笔记 Doxygen 是通过代码注释生成文档的事实标准,借用该工具可以将文档内容与代码写在一起方便维护. https://github.com/doxygen/doxy ...
- 动态能力理论&知识管理理论--商业之所见
动态能力理论:企业整合,建立和再配置内外部资源以适应快速变化环境的能力. (1)"动态"指的是适应不断变化的环境,企业必须具有不断更新自身能力的能力: (2)"能力&qu ...
- Java进阶 - [1-5] 集合容器
ArrayList add 1.先确认是否需要扩容,如果需要,则进行扩容操作ensureExplicitCapacity. 2.进行赋值 elementData[size++] = e; 扩容 1.如 ...
- SICK Ranger3源码分析——断线重连
前言 本文可在https://paw5zx.github.io/SICK-Ranger3-source-code-analysis-01/中阅读,体验更加 简单分析一下SICK Ranger3源码中断 ...