# 水杉码园学生使用手册(进阶版) [toc] ## 一、前言 水杉码园是一个代码托管与协作平台,利用开源项目Gitea进行搭建,运行快速、使用体验良好,支持跨平台以及多种功能。 通过对开源平台Gitea的深度定制,让教育与项目协作相结合,更符合学校的教学场景,更有利于教师和学生的课外互动、学生与学生的作业协作;让教育与激励相结合,调动学生的参与热情,科学公正地评判平时成绩;让教育与数据相结合,从学生出发到学生中去,通过自有平台的数据采集与分析,重新审视现有的教育模式,更好地解决教育问题。 本文主要介绍如何在VSCode中集成使用Git,以及如何在仓库托管平台上进行代码托管与协作。 ## 二、Git **1、Git是什么** Git是一个版本控制系统工具,它可以帮你管理项目,记录每一次提交的变化,以方便你在发生错误时进行回滚。它几乎所有的控制操作都可以在本地执行,不需要网络开销的好处是Git的操作十分迅速。 **2、安装Git** 访问 https://git-scm.com/downloads ,根据自己的机器平台下载合适的安装包后进行安装。 **3、添加到Path** 打开终端,输入git并回车。如果有git信息,则说明已经将git添加到path中,否则请找到git安装位置,然后添加到你系统的path中。各系统方式不同,请自行查阅资料。 正常情况下的反应如下: ![git1](image/git1.png) **4、详细Git教程** 参考:https://www.liaoxuefeng.com/wiki/896043488029600/ **5、Git命令简介** ① 创建仓库 `$ git init` 这会将当前目录创建为一个仓库,并产生一个新的名为.git的文件夹,其中存储着版本控制信息,我们不需要去在意里面具体是什么。这样,我们就创建好了一个空的仓库。 ② 添加文件并查看仓库 现在让我们尝试在我们新的空仓库(就是你创建的文件夹下)中添加一个新的文件,可以是一个word,可以是一份c语言源文件,其他什么文件都可以。当你添加了一个文件后,我们使用下面的命令去查看当前的仓库情况: `$ git status` 终端会显示出你目前在master分支上还没有过提交,并且有一个文件还未被git追踪。 ![](image/git8.png) ③ 追踪、提交文件 接着我们使用下面命令去追踪文件: `$ git add .` 注意add后面这个点不要漏了,这代表加入所有未被追踪的文件到git中。然后使用下面的命令去提交我们这次文件改动,顺带写上一些信息表示我们这次提交的主要内容。 `$ git commit -m "my first file"` 注意使用选项-m去加上提交的信息,如果直接使用git commit会调用编辑器让你继续输入你这次提交的主要信息。 ④ 查看分支 紧接着,你可以在终端中输入如下命令查看分支: `$ git branch` 结果应该如下图所示: ![](image/git9.png) 注意,如果你发现没有任何输出,那就说明上面的commit操作你还没成功,因为我们刚刚创建的仓库是空的,在Git中分支必须指向一个commit。如果还没有commit任何文件,那么就看不到分支。当我们第一次提交后就会自动将master分支作为我们的主要分支,指向你的第一次提交。然后你再使用一次git branch命令就能查看分支,并且分支名字前面带*的就是当前所处的分支。 ⑤ 创建并切换分支 Master分支一般更多是用来保存完整的项目内容,当你进行开发或者修改bug的时候应该切换到新的分支进行开发工作。你可以使用下面命令创建一个新的分支: `$ git branch dev` 这样,你就创建了一个名为dev的分支。 你可以使用下面命令切换分支: `$ git checkout dev` 这样你就切换回了master分支。你也可以把这两步操作合并一下,用这个命令: `$ git checkout -b dev` 这样你就会创建dev分支然后切换过去。 **6、常用Git命令** - **新建代码库** ```shell # 在当前目录新建一个Git代码库 $ git init # 新建一个目录,将其初始化为Git代码库 $ git init [project-name] # 下载一个项目和它的整个代码历史 $ git clone [url] ``` - **配置** ```shell # 显示当前的Git配置 $ git config --list # 编辑Git配置文件 $ git config -e [--global] # 设置提交代码时的用户信息 $ git config [--global] user.name "[name]" $ git config [--global] user.email "[email address]" ``` - **增加/删除文件** ```shell # 添加指定文件到暂存区 $ git add [file1] [file2] ... # 添加指定目录到暂存区,包括子目录 $ git add [dir] # 添加当前目录的所有文件到暂存区 $ git add . # 添加每个变化前,都会要求确认 # 对于同一个文件的多处变化,可以实现分次提交 $ git add -p # 删除工作区文件,并且将这次删除放入暂存区 $ git rm [file1] [file2] ... # 停止追踪指定文件,但该文件会保留在工作区 $ git rm --cached [file] # 改名文件,并且将这个改名放入暂存区 $ git mv [file-original] [file-renamed] ``` - **代码提交** ```shell # 提交暂存区到仓库区 $ git commit -m [message] # 提交暂存区的指定文件到仓库区 $ git commit [file1] [file2] ... -m [message] ``` - **分支** ```shell # 列出所有本地分支 $ git branch # 列出所有远程分支 $ git branch -r # 列出所有本地分支和远程分支 $ git branch -a # 新建一个分支,但依然停留在当前分支 $ git branch [branch-name] # 新建一个分支,并切换到该分支 $ git checkout -b [branch] # 切换到指定分支,并更新工作区 $ git checkout [branch-name] # 建立追踪关系,在现有分支与指定的远程分支之间 $ git branch --set-upstream [branch] [remote-branch] # 合并指定分支到当前分支 $ git merge [branch] ``` - **远程同步** ```shell # 下载远程仓库的所有变动 $ git fetch [remote] # 显示所有远程仓库 $ git remote -v # 显示某个远程仓库的信息 $ git remote show [remote] # 增加一个新的远程仓库,并命名 $ git remote add [shortname] [url] # 取回远程仓库的变化,并与本地分支合并 $ git pull [remote] [branch] # 上传本地指定分支到远程仓库 $ git push [remote] [branch] # 强行推送当前分支到远程仓库,即使有冲突 $ git push [remote] --force # 推送所有分支到远程仓库 $ git push [remote] --all ``` ## 三、Visual Studio Code 1、安装VSCode 访问 https://code.visualstudio.com/Download 下载符合您机器平台的安装包后进行安装。 2、界面介绍 VSCode打开后的界面如下图所示: ![VSCode 主界面](image/vscode.png) A区是侧边活动栏,B区是底部栏,C区是编辑区域,D区是面板区域,E区是状态栏,当然顶部还有一个菜单栏。VSCode区域划分的非常友好,对文件进行编辑的同时也可以在面板区域中查看终端的输出信息等。 3、插件介绍 能够让VSCode火爆的原因就是它拥有庞大的插件库,在A区的活动栏中选择插件活动,就可以在市场中搜索你想要的插件。它可以帮你实现代码高亮、自动补全、格式校验等功能,对编辑代码有着非常好的帮助。 ## 四、Git SSH配置 使用SSH的方式拉取仓库中的代码或资料需要进行如下配置,使用HTTP的方式拉取仓库中的代码或资料可以本章节的配置。 两种方式的主要区别在于git clone时使用的URL不同。 ![image-20210306195002341](image/image-20210306195002341.png) 1、查看邮箱,并配置Git信息 登录水杉码园,单击水杉码园首页右上角的头像,单击“个人信息”。 ![](image/gitea2.png) 查看你水杉码园账户的对应邮箱,等下要用。 ![](image/gitea3.png) 打开终端,输入以下命令用以设置你本地git的姓名和邮箱信息。请确保邮箱和刚刚水杉码园中查看到的邮箱相同。 `$ git config --global user.name "Your Name"` `$ git config --global user.email yourmail@example.com` 设置完后可以通过下面命令查看姓名和邮箱: `$ git config user.name` `$ git config user.email` 正常情况下的输出如图所示: ![](image/git2.png) 2、在本地(你的笔记本电脑)生成SSH密钥 在命令行输入ssh-keygen -t rsa -C ‘你的邮箱地址’后回车,如下: ![](image/git3.png) 红框中是提示你要将密钥存放在哪里,括号里的是默认的存放路径,请记住这个路径,我们之后需要这个路径找到密钥。 接着直接按回车,如果你之前也按照默认的路径生成过SSH密钥,会出现如下图中的情况,询问你是否要覆盖。 ![](image/git4.png) 输入y覆盖原有的密钥,或者之前没有生成过密钥,就会出现如下图中情况: ![](image/git5.png) 直接回车不用管,如下: ![](image/git6.png) 直接回车不用管,之后如下: ![](image/git7.png) 可以看到你的密钥已经创建成功。 3、上传密钥到水杉码园 登陆水杉码园后,在右上角头像的下拉框中点击设置 ![](image/gitea4.png) 在标签中选择SSH/GPG密钥 ![](image/gitea5.png) 在管理SSH密钥卡片右侧点击增加密钥 ![](image/gitea6.png) 打开你的id_rsa.pub文件,将里面所有的内容复制到密钥内容一栏中,然后给这个密钥取一个名字,比如:我的MacBook。点击绿色的增加密钥按钮后,就成功添加了SSH密钥。 ![](image/gitea7.png) 4、新建远程仓库 点击头像边上的加号,接着点击创建仓库 ![](image/gitea8.png) 为仓库取一个名字后点击下面的创建仓库按钮,就可以正常创建仓库了,如果你不想让别人看到你的仓库内容,记得设置你的仓库为私有。 ![](image/gitea9.png) 5、你的仓库SSH地址 当你创建完仓库后,你会跳转到仓库的主页,如下图所示: ![](image/gitea10.png) 上图红框中,选择SSH,就可以看到你仓库的SSH地址,这个之后会用到。 ## 五、VS Code集成Git使用 1、拉取仓库 打开VSCode,在左边选择git活动。 ![](image/vscode2.png) 点击上图红框中的按钮,然后在弹出的框中复制你刚才仓库的SSH地址,然后回车。 ![](image/vscode3.png) 选择仓库的存放地址,即可将仓库拉取到本地。接着右下角会弹出一个是否打开该仓库的提示,点击open打开该仓库。 2、修改仓库文件 你可以随意修改仓库文件,只要添加了一些新的文件或者有了一些新的修改即可。 ![](image/vscode4.png) 我们添加了两个源文件用于进行接下去的步骤 3、暂存修改的文件 按下图进行操作,这会将你所有的修改放入暂存区 ![](image/vscode5.png) 4、提交暂存的文件 按下图进行操作,将暂存区的修改文件进行提交。这不是提交到远程仓库,是提交到本地git,产生一个新的commit。 ![](image/vscode6.png) 紧接着,在弹出的框中,输入你这次提交的备注信息,用于说明你这次commit主要的内容是什么。 ![](image/vscode7.png) 5、推送到水杉码园远程仓库 ![](image/vscode8.png) 即可正确推送到水杉码园。 6、切换分支 通常我们不是只在一个分支上开发,master分支用来存放当前开发的稳定分支。可以按照下图产生并切换到新分支。 ![](image/vscode9.png)