Git是一个分布式版本控制系统,用于跟踪和管理项目代码的变化。它是由Linus Torvalds于2005年创建的,旨在帮助开发者更好地协作、追踪代码的更改,并轻松地回滚到之前的版本。
Git相比传统的集中式版本控制系统,具有许多优势。它不仅允许每个开发者都拥有完整的项目副本(本地仓库),还能在不依赖中央服务器的情况下进行工作。这使得Git在网络连接不稳定或服务器不可用的情况下依然能够进行版本控制和开发工作。
在使用Git之前,了解一些基本概念是非常重要的。
Git仓库是存储代码和版本历史的地方。它包含了项目的所有文件以及与这些文件相关的元数据。每个项目通常都有一个主仓库,可以在本地计算机或托管服务(如GitLab)上创建。
提交是Git中最基本的操作之一。它代表了对项目代码的一次更改。每次提交都有一个唯一的标识符(SHA-1哈希值),用于跟踪和引用该次更改。
分支是Git中用于独立开发某个功能或解决某个问题的副本。默认情况下,每个项目都有一个主分支(通常是"master"或"main"),而其他功能分支则从主分支上创建。分支的好处在于可以让团队成员并行工作,不会干扰彼此的代码。
合并是将一个分支的更改合并到另一个分支的过程。当一个功能开发完成或问题解决后,可以将相关的分支合并回主分支,使得主分支也拥有这些更改。
远程仓库是存储在网络或服务器上的Git仓库副本。通过与远程仓库交互,团队成员可以共享代码、协作开发,并将本地的更改推送到远程仓库或拉取远程仓库的最新更改。
在开始使用Git之前,首先需要安装Git并进行一些基本配置。
安装Git: 根据你的操作系统,下载并安装Git。Git可以在Windows、Mac和Linux等多种平台上运行。安装完成后,在命令行终端中输入 git --version
可以验证是否安装成功,并查看Git的版本信息。
配置Git: 在安装Git后,需要配置用户名和邮箱地址,这些信息将出现在你的提交记录中。
在命令行终端中输入以下命令,并将其中的用户名和邮箱地址替换为你自己的信息:
git config --global user.name "Your Name"
git config --global user.email "[email protected]"
现在,你已经安装并配置好了Git,可以开始使用Git来跟踪和管理你的项目代码了。接下来,我们将学习如何初始化仓库、进行提交和创建分支等基本操作。
如果对命令内容不熟悉可以使用
git --help
以及
git help 特定指令进行查询
在软件开发中,云端代码仓库是团队协作和代码托管的关键工具。下面介绍几个常见的云端代码仓库平台:GitHub、Gitee和华为CodeHub。
GitHub是全球最大的开源代码托管平台,于2008年成立。它提供了一个简单易用的在线Git仓库管理系统,以及许多强大的协作功能。GitHub主要特点包括:
Gitee(码云)是中国最大的代码托管平台,成立于2013年。它类似于GitHub,提供了Git仓库托管和团队协作的功能。Gitee的主要特点包括:
华为CodeHub是由华为公司推出的云端代码托管平台,用于代码存储和团队协作。它主要面向华为内部开发,不过也支持注册个人账户。CodeHub的主要特点包括:
GitHub、Gitee和华为CodeHub都是功能强大的云端代码仓库平台,提供了团队协作、代码托管和持续集成等功能,便于开发者在云端进行代码管理和协作。根据项目需求、地理位置和企业政策等因素,开发者可以选择适合自己的代码托管平台。
在CentOS上安装GitLab
安装依赖软件包:
打开终端并执行以下命令,安装GitLab的依赖软件包:
sudo yum install -y curl policycoreutils-python openssh-server postfix
sudo systemctl enable sshd postfix
sudo systemctl start sshd postfix
sudo firewall-cmd --permanent --add-service=http
sudo systemctl reload firewalld
这里安装了curl、policycoreutils-python、openssh-server、postfix等软件包,它们是GitLab运行所必需的。
添加GitLab软件源并安装GitLab:
在终端中执行以下命令来添加GitLab的软件源并安装GitLab:
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | sudo bash
sudo EXTERNAL_URL="http://your-gitlab-domain.com" yum install -y gitlab-ee
注意,将 http://your-gitlab-domain.com
替换为你实际的GitLab域名或IP地址。
配置并启动GitLab:
安装完成后,运行以下命令配置并启动GitLab:
sudo gitlab-ctl reconfigure
这将配置GitLab并启动所有必需的服务。
设置管理员用户名和密码:
前提条件:需要保证Gitlab、Redis同时处于启动状态。可以运行
gitlab-ctl start
或者gitlab-ctl restart
命令进行启动或者重启。
在终端中执行以下命令,设置GitLab管理员用户名和密码:
gitlab-rails console -e production
# 低版本可以尝试使用下面一句命令:
gitlab-rails console production
进入GitLab控制台后,执行以下命令来设置管理员用户名和密码:
user = User.where(id: 1).first
user.username = 'your_admin_username'
user.password = 'your_admin_password'
user.password_confirmation = 'your_admin_password'
user.save!
exit
将 your_admin_username
和 your_admin_password
替换为你自己的管理员用户名和密码。
注意:
GitLab默认启用了密码策略检查,以提高账号的安全性。这种检查会阻止使用容易被猜测或常见的密码。你需要选择一个更强大且不易被破解的密码。
以下是一些创建密码时的建议:
- 长度: 选择至少8个字符的密码。更长的密码更安全。
- 混合字符: 使用大小写字母、数字和特殊字符的组合。例如,使用大写字母、小写字母、数字和特殊字符(例如:
@#$%^&*
)。- 避免常见词汇和短语: 避免使用容易被猜测的常见词汇、日期、个人信息和常见短语作为密码。
- 不要重复使用密码: 避免在多个平台和账号上使用相同的密码。使用密码管理器来生成和存储随机且独一无二的密码。
配置域名:
在 /etc/gitlab/gitlab.rb
文件中配置你的域名:
sudo nano /etc/gitlab/gitlab.rb
在文件中添加以下内容,将 your-gitlab-domain.com
替换为你实际的GitLab域名或IP地址:
external_url 'http://your-gitlab-domain.com'
保存文件并退出。
重新配置并重启GitLab:
运行以下命令重新配置并重启GitLab,使域名配置生效:
sudo gitlab-ctl reconfigure
sudo gitlab-ctl restart
现在,你已经成功安装并配置了GitLab服务,管理员用户名、密码和域名也已经设置完成。你可以通过浏览器访问你的GitLab域名或IP地址,并使用管理员账号登录进行进一步的配置和管理。请记得根据实际情况修改相关配置,并遵循官方文档和最佳实践进行安装和配置。
Git是一个强大的版本控制系统,它可以帮助开发者跟踪和管理项目的代码变化。在本节中,我们将介绍Git的基本操作,包括初始化仓库、添加文件、提交更改和查看历史记录。
在开始使用Git之前,我们需要初始化一个新的本地Git仓库。在你的项目目录下打开终端,执行以下命令:
git init
这将在当前目录创建一个新的Git仓库,并在项目根目录下生成一个隐藏文件夹.git
,用于存储Git的配置和版本历史信息。
我们可以是用
git status
查看git目录下文件的提交和控制状态
在将文件纳入Git版本控制之前,我们需要将文件添加到暂存区(Staging Area)。执行以下命令来添加文件:
git add <filename>
或者,如果你希望一次性将所有修改过的文件都添加到暂存区,可以使用以下命令:
git add .
一旦文件添加到暂存区,我们可以将这些更改提交到本地仓库,生成本地版本。执行以下命令进行提交:
提交方法有三种:
第一种:手动添加记录
git commit
然后会打开vi工具,需要对提交内容进行一个说明,可以使用esc退出编辑,:wq保存编辑
第二种:
git commit -m "Commit message"
Commit message
是本次提交的描述信息,可以简洁地说明这次提交的内容和目的。
注意:当修改或者添加文件或者删除文件后还是要执行git add 然后查看你的状态,再进行git commit操作
第三种:
可以将两步骤操作合成一步执行
git commit -am '备注'
注意次步骤只能add和提交已经被追踪的文件,可以理解为只能进行修改和删除操作的添加和提交
Git Log 是一个用于查看 Git 提交历史的命令。它可以显示项目中每个提交的详细信息,包括作者、日期、提交哈希和提交说明等。在本篇教学笔记中,我们将介绍七种常用的 Git Log 操作。
git log
命令用于显示项目的提交历史。默认情况下,它会按照时间顺序列出所有的提交记录,最新的提交会显示在最上面。每个提交记录包括提交哈希、作者、提交日期和提交说明。
git log
git log -p -2
命令会显示最近的两个提交记录,并显示每个提交的具体变动内容。这样可以查看每个提交引入了哪些修改。
git log -p -2
git log --author
命令允许我们按照提交作者的名字筛选提交记录。这在多人协作的项目中非常有用,可以快速查找某个作者的提交历史。
git log --author="John Doe"
git log --oneline
命令会以简洁的方式显示提交历史,每个提交只占一行,只显示提交哈希和提交说明。
git log --oneline
git log --graph
命令可以绘制 ASCII 图形展示分支合并历史,更直观地查看分支的合并情况。
git log --graph
git log --pretty=oneline
命令将提交历史以自定义的格式显示,这里使用了 oneline
格式。
git log --pretty=oneline
git log --pretty=format
命令允许我们以更灵活的方式自定义提交历史的输出格式。我们可以使用特定的占位符来展示提交信息。
git log --pretty=format:"%h - %an, %ar : %s"
上面的命令将以类似于 “提交哈希 - 作者名,相对时间 : 提交说明” 的格式显示提交历史。
在 Git 中,可以使用 git diff
命令来比较修改前后的区别。这个命令可以帮助我们查看工作目录和暂存区之间的差异,或者查看暂存区和最新提交之间的差异。下面介绍两种常用的 Git Diff 操作。
git diff
命令用于比较工作目录中的修改和暂存区之间的差异。它会显示出文件的具体修改内容,包括添加、删除和修改的行。
git diff
上述命令会显示出工作目录中未暂存的修改与当前的暂存区的差异。
git diff --staged
或 git diff --cached
命令用于比较暂存区和最新提交之间的差异。它会显示出已暂存的修改与最新提交的差异。
git diff --staged
上述命令会显示出已暂存的修改与最新提交之间的差异。
这两种 Git Diff 操作可以帮助我们了解修改前后的区别,帮助我们审查和理解所做的修改。注意,在使用 git diff
命令时,可以通过添加文件路径参数来限制对特定文件的差异比较。
请记住,Git Diff 只显示修改的内容,而不会更改任何文件或提交任何更改。它仅用于显示差异信息以帮助开发者进行代码审查和版本控制
在 Git 中,我们可以通过 .gitignore
文件来指定要忽略的文件和目录,这些被忽略的文件将不会被加入到版本控制中。以下是几种常用的文件忽略方式:
.gitignore
文件是一个文本文件,用于列出要忽略的文件和目录。我们可以在该文件中添加模式来匹配要忽略的文件或目录。
示例 .gitignore
文件内容:
HELP.md
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
/node_modules
表示忽略项目根目录下的 node_modules
目录及其内容。通常,该目录包含大量的第三方依赖库,不应该被加入版本控制,因为它们可以通过 package.json
和 package-lock.json
或 yarn.lock
这样的文件来重建。
*.log
表示忽略所有以 .log
为后缀的文件。这在项目中通常用于忽略日志文件,因为日志文件通常会不断增长并占据空间,不适合加入版本控制。
*.zip
表示忽略所有以 .zip
为后缀的文件。这在项目中通常用于忽略压缩文件,因为它们可能是生成的或者用于分发而不应该包含在版本控制中。
如果某些文件已经被错误地提交到版本控制中,并且希望将它们从版本控制中移除但保留在工作目录中,可以使用 git rm
命令的 --cached
选项。这将把指定文件从暂存区中删除,但会保留在本地工作目录中。
git rm -r --cached .
上述命令会将当前目录下所有文件从暂存区中删除,包括之前错误提交到版本控制的文件。
记住,在忽略文件之前,请确保它们未被提交到版本控制中。因为一旦文件被提交,.gitignore
对其将不再起作用,需要使用 git rm
命令将其从版本控制中移除。
在 Git 中,可以使用不同的命令和策略来还原文件或提交。下面是一组完整的 Git 还原操作内容,包括还原修改的文件、还原暂存的文件和还原提交历史。
如果你在工作目录中对文件做了修改,但尚未将其添加到暂存区,可以使用以下命令来还原该文件:
git checkout -- [filename]
这个命令会将 [filename]
文件还原到最近一次提交时的状态。注意,该操作将丢失工作目录中对文件的修改,请在执行前确认。
如果你已经将某个文件添加到暂存区,但又希望将其还原到最近一次提交时的状态,可以使用以下命令:
git reset HEAD [filename]
该命令将会将 [filename]
文件从暂存区中移除,但保留其在工作目录中的修改。
然后,你可以使用以下命令来还原工作目录中的文件到最近一次提交的状态:
git checkout -- [filename]
这个命令会将 [filename]
文件还原到最近一次提交时的内容,丢弃工作目录中的修改。
还可以借助git checkout回复版本到之前的内容
git checkout [版本号] -- [fileName]
如果你想还原到之前的某个提交状态,可以使用以下命令:
git log
这个命令会显示提交历史记录,并获取你想要还原的提交的哈希值。
然后,使用以下命令来还原到指定的提交状态:
git reset --hard [commit-hash]
这个命令会将当前分支指向指定的提交,丢弃之后的所有提交。请谨慎使用,因为这会删除之后的提交记录。
注意:还原提交历史的操作是不可逆的,请确保你理解这一点,并在执行前备份你的代码或联系项目的其他开发者。
这是一组完整的 Git 还原操作内容,包括还原修改的文件、还原暂存的文件和还原提交历史。根据你的具体需求,选择适当的还原策略来恢复文件或提交。记住,在执行任何 Git 还原操作之前,最好先确认你的操作,以免丢失重要的更改或提交。
使用 git reset --hard HEAD^
命令可以将当前分支的 HEAD 指针和工作目录恢复到上一次的提交状态。这个命令将会丢弃最近一次的提交及其后的所有提交。
git reset --hard HEAD^
上述命令中的 HEAD^
表示上一次的提交,通过执行该命令,你会回退到上一次的提交状态。
类似地,使用 git reset --hard HEAD^^
命令可以将当前分支的 HEAD 指针和工作目录恢复到倒数第二次的提交状态。这个命令会丢弃最近两次的提交及其后的所有提交。
git reset --hard HEAD^^
上述命令中的 HEAD^^
表示倒数第二次的提交,通过执行该命令,你会回退到倒数第二次的提交状态。
另一种方式是使用提交的哈希值来还原到特定的提交状态。你可以使用 git log
命令来获取需要还原的提交的哈希值。
git log
获取到需要还原的提交的哈希值后,可以使用以下命令进行还原:
git reset --hard [hashcode]
上述命令中的 [hashcode]
是你需要还原到的特定提交的哈希值。
请注意,在执行还原操作前,确保已备份重要的代码和提交。还原操作是不可逆的,并且会丢失未保存的修改和之后的提交记录
查看指针版本号:
git reflog
分支是Git中非常强大的功能之一,它允许你在项目上独立地开发某个功能或修复问题,而不影响主分支的稳定性。在本节中,我们将学习如何创建分支、切换分支、合并分支以及解决合并冲突。
在 Git 中,分支是非常有用的功能,可以让我们在项目开发中轻松管理不同的代码版本。下面是一组常用的 Git 分支操作命令,包括创建、切换和删除分支。
要创建一个新的分支,可以使用以下命令:
git branch [branch_name]
这将在当前提交所在的位置创建一个名为 [branch_name]
的新分支,但你仍然停留在当前分支中。
要切换到已经存在的分支,可以使用以下命令:
git checkout [branch_name]
这将使你切换到名为 [branch_name]
的已存在分支,并将你的工作目录切换到该分支上。
或者,如果你想一次性创建并切换到一个新的分支,可以使用以下命令:
git checkout -b [branch_name]
这将创建一个新分支 [branch_name]
并将你的工作目录切换到该分支上。
如果你想删除一个已经合并的分支,可以使用以下命令:
git branch -d [branch_name]
这将删除名为 [branch_name]
的已合并分支。如果分支未合并(尚未合并到主分支),使用 -d
选项将无法删除,这是为了防止意外删除未合并的更改。
如果你确定要删除未合并的分支,可以使用以下命令:
git branch -D [branch_name]
这将强制删除名为 [branch_name]
的未合并分支。请谨慎使用 -D
选项,因为它将不可逆转地删除分支。
但是其实在删除分支时,可以恢复分支,比如在删除分支时描述了hash值和分支名称
我们可以新建分支进行恢复
git branch master 9cfb21e
只要分支的名称和hash值写的和删除的版本一致即可
git branch
在 Git 中,合并分支是将一个分支的更改合并到另一个分支的过程。这样可以将不同分支上的代码和修改合并为一个新的提交,从而将功能或修复应用到主分支或其他目标分支。下面是一般情况下合并分支的操作:
首先,需要切换到你想要合并到的目标分支。例如,如果你想将 Feature 分支合并到主分支(通常是 main
或 master
分支),可以使用以下命令:
git checkout main
使用以下命令来合并源分支(例如 Feature 分支)到目标分支(主分支):
git merge feature
上述命令将把 Feature 分支上的更改合并到当前所在的主分支中。
解决 Git 合并分支时的冲突问题是开发中常见的任务。当两个分支同时修改了相同的文件的相同部分时,Git 无法自动确定应该保留哪个更改,从而产生冲突。以下是解决合并冲突的步骤:
git merge [branch_name]
进行合并首先,使用 git merge [branch_name]
命令将目标分支和源分支进行合并。比如,要将 Feature 分支合并到主分支(通常是 main
或 master
分支),可以执行以下命令:
git checkout main # 切换到主分支
git merge feature # 合并 Feature 分支到主分支
git status
查看冲突原因执行合并后,如果存在冲突,可以使用 git status
命令查看冲突的文件和原因:
git status
git status
将会显示冲突的文件列表,并告诉你需要解决冲突。
git merge --abort
放弃合并如果在合并过程中遇到问题或想放弃合并,可以使用 git merge --abort
命令回到合并前的状态,忽略合并:
git merge --abort
打开发生冲突的文件,Git 会用 <<<<<<<
、=======
和 >>>>>>>
标记冲突的部分。你需要手动编辑文件,决定要保留哪些更改和如何解决冲突。修改完冲突后的文件后,保存文件。
git add
添加解决冲突后的文件完成冲突的解决后,使用 git add
命令将解决冲突后的文件标记为已解决:
git add [resolved_file1] [resolved_file2] # 添加解决冲突后的文件
git commit
提交解决冲突的更改最后,使用 git commit
命令提交解决冲突后的更改:
git commit -m "Resolve merge conflicts" # 提交解决冲突后的更改
现在,冲突已经解决,合并成功完成。
在 Git 中,可以使用不同的选项来查看版本历史的线图,展示提交之间的关系和分支结构。下面是几个常用的命令来查看版本线图:
使用 git log
命令可以显示完整的提交历史,包括每个提交的详细信息,但不会以图形化的方式展示版本线图。
git log
使用 git log --oneline
命令可以以简洁的方式显示提交历史,每个提交只显示一行,包括提交哈希和提交说明。
git log --oneline
使用 git log --oneline --graph
命令可以显示提交历史的线图,以图形化方式展示分支结构。
git log --oneline --graph
使用 git log --oneline --graph --all
命令可以显示包括所有分支在内的提交历史的线图。
git log --oneline --graph --all
使用 git log --oneline --graph -[number]
命令可以限制显示的提交数量。替换 [number]
为你想要显示的提交数量,例如,要显示最近的5个提交,可以使用:
git log --oneline --graph -5
这将显示最近的5个提交的线图。
以上命令中的 --oneline
选项将简化输出,使得线图更加紧凑易读。而 --graph
选项将显示提交历史的线图,帮助你更好地理解项目的版本结构。
远程仓库是存储在网络或服务器上的Git仓库,它允许团队成员共享代码、协作开发,并保留代码的备份。在本节中,我们将学习如何关联远程仓库、推送更改、拉取更改以及解决合并冲突。
在将本地仓库与远程GitLab仓库关联之前,你需要在GitLab上创建一个空白仓库。然后,在本地仓库目录中执行以下命令:
git remote add origin <remote-repository-url>
将
替换为你的远程GitLab仓库的URL。这个命令将在本地仓库中添加一个名为 origin
的远程仓库别名。
当你在本地仓库做了一些更改,并希望将这些更改推送到远程仓库时,执行以下命令:
git push origin <branch-name>
这将把
分支的更改推送到远程仓库中。如果你想将所有本地分支的更改都推送到远程仓库,可以使用 --all
参数:
git push --all origin
当你的团队成员在远程仓库中做了一些更改,并且你希望获取这些最新更改时,执行以下命令:
git pull origin <branch-name>
这将从远程仓库的
分支获取最新更改,并将它们合并到你当前所在的本地分支。
在拉取远程仓库更改时,有时会发生冲突。这通常是因为你的本地更改与远程仓库的更改在相同的位置产生了冲突。解决冲突的步骤与之前在分支合并时解决冲突的步骤类似。
首先,Git会在冲突文件中标记出冲突的地方。你需要编辑这些文件,解决冲突并保存更改。然后,执行以下命令来完成合并:
git commit -m "Merge remote-tracking branch 'origin/branch-name'"
以上命令将合并完成的更改提交到本地分支。
注意: 当解决冲突时,要仔细检查代码确保没有错误,确保最终提交的代码是正确的。
通过上述远程仓库的操作,你可以与团队成员协作开发,并及时获取最新的代码更改。远程仓库使得多人协作开发变得更加容易和高效,同时保证代码的一致性和安全性。记得在推送和拉取代码前,先进行提交,确保工作区是干净的,这样可以避免冲突和意外的代码更改。
GitLab是一个功能强大的代码托管平台,它提供了丰富的功能来支持团队协作和持续集成/持续交付。在本节中,我们将学习如何搭建本地GitLab服务器、创建项目、添加成员、使用Issue跟踪问题和任务、处理合并请求以及简介持续集成和持续交付的概念。
要在本地搭建GitLab服务器,你可以使用Omnibus安装包或者源代码进行安装。这里我们以Omnibus安装包为例,简要介绍搭建步骤:
请注意,详细的搭建步骤可以参考GitLab官方文档或其他教程。
在成功搭建本地GitLab服务器后,你可以在GitLab上创建新的项目。登录到GitLab,并按照以下步骤创建项目:
在项目创建完成后,你可以邀请其他人加入项目并进行协作开发。按照以下步骤添加成员:
GitLab提供了强大的Issue跟踪功能,用于记录和管理项目中的问题和任务。在项目页面的"Issues"选项卡中,你可以创建新的Issue、分配责任人、设置优先级、标签等。
Merge Requests是GitLab中用于提交和处理代码合并的功能。开发者可以通过创建Merge Requests将自己的代码提交到主分支,并经过其他成员的审查和讨论后,最终合并到主分支中。
持续集成(CI)和持续交付(CD)是现代软件开发中重要的流程。GitLab提供了内置的CI/CD工具,帮助你在代码提交时自动构建、测试和部署项目。通过配置.gitlab-ci.yml
文件,你可以定义CI/CD流程并实现自动化的构建和部署。
以上就是GitLab操作的一些关键步骤。通过搭建本地GitLab服务器,创建项目并邀请成员,你可以实现团队的协作开发。使用Issue跟踪问题和Merge Requests处理代码合并,使开发过程更加有序和高效。并且,通过配置CI/CD流程,你可以实现持续集成和持续交付,提高软件交付的速度和质量。记得根据实际需求和项目规模,灵活使用GitLab的功能来支持你的开发流程。
ssh-keygen
(2)
然后出现【Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/Lenovo/.ssh/id_rsa):】,按【回车】,
(3)
会出现【Created directory ‘/c/Users/Lenovo/.ssh’.
Enter passphrase (empty for no passphrase):】提示输入密码(此时密码是不可见状态),
(4)
【Enter same passphrase again:】,重复输入密码,按回车,
.ssh中有一个文件【id_rsa.pub】,创建的密钥就储存在这里,但是不能双击打开,
用windows的命令行,进入.ssh 中的
用命令【more id_rsa.pub】获取内容,下面这串就是你的密钥(可以复制下来)。
Git中添加密钥
1)刚才复制下来的密钥粘贴到【公钥】框内,标题可以自己起,