相关资料:

如何使用git通过ssh协议拉取gitee上的项目代码——如何正确的免密使用git


不论是gitee还是GitHub都有两种公钥设置,一种是ssh公钥,另一种则是GPG公钥。ssh公钥是为了在进行git pull和git push操作时进行免密验证的;而GPG公钥是在git tag和git commit时进行验证的。不过需要注意的是,如果不进行ssh公钥设置,那么在进行git pull和git push时都是需要在每次操作的时候进行用户名和密码认证的,因此进行ssh公钥验证会使git的操作简化,但是GPG公钥如果不进行设置是不会有任何影响的,不会对git的tag和commit操作有任何影响,完全可以在无验证的情况下进行git tag和git commit操作,如果你对git项目中的tag和commit操作进行了GPG的公钥设置,那么在每次进行git tag和git commit操作的时候可以手动加入指定GPG私钥签名的的参数,这样推送到远端的代码就会显示已被GPG验证的信息,否则git的tag和commit操作在远端会显示签名状态为未验证。

可以说,设置git的ssh公钥会简化git pull和git push的密码验证,但是设置git的GPG公钥则会增加git的操作步骤。

git的ssh公钥是为了确认你有访问并修改git远端仓库的资格,但是git的远端代码库往往是多人合作的,也就是说同时可以有多个人对git的远端仓库进行代码的提交和修改,这个时候这几个合作者之间的身份是无法确认的,比如一个项目有A、B、C三个人合作,这三个人均有可以访问代码库的ssh公钥,但是对于每一次的git的tag和commit操作是无法确认到底是A、B、C三个人中到底是哪一个操作的(用户名和邮箱并不是信息不变的,无法作为身份的唯一验证的),而这个时候项目的总负责人就可以通过设置GPG公钥来实现对每一次的tag和commit进行身份验证,这样合并到远端代码库中的所有操作都可以定位到具体人,这样即使有人恶意添加后门代码或者是删库我们也是可以直接定位到具体的操作者的。这也是git的GPG公钥设置的意义,如果是个人维护的项目就没有必要进行GPG公钥的设置了,否则就是为自己的操作增加工作罢了,但是对于多人合作的项目还是很有必要添加GPG公钥认证的。

给出Gitee的ssh公钥和GPG公钥设置页面:


关于Tag的使用以及GPG秘钥生成和使用,详细见:

  1. 如何在 Gitee 上使用 GPG
  2. GitHub GPG签名 Tag签名 Verified认证,防伪造的github commits
  3. git tag详解

这里只给出基本操作:

GPG秘钥生成:

gpg --full-generate-key --pinentry-mode=loopback

GPG公钥导出:

gpg --armor --export 8086B4D21B3118A83CC16CEBB0A02972E266DD6D

为本地主机的git配置刚才生成的GPG私钥:

git config --global user.signingkey 8086B4D21B3118A83CC16CEBB0A02972E266DD6D

将导出的GPG公钥填入到Gitee和Github的配置中。

在本地的git项目中对commit操作进行GPG私钥签名:

git commit -S -m "YOUR COMMIT MESSAGE"
git log --show-signature # 查看签名状态

在本地的git项目中对tag操作进行GPG私钥签名:

git tag -s v1.0.0 -m "version comments"
git push origin v1.0.0
# v1.0.0您可以自行定义

需要注意,git tag -s v1.0.0 -m "version comments" 是使用GPG私钥签名,

git tag -a v1.0.0 -m "version commets"是不使用GPG私钥签名。

也就是说,-s是使用GPG私钥签名打tag,-a是不使用GPG私钥签名打tag。


GPG秘钥的生成:


PS. 不论是SSH公钥和GPG公钥的验证都有一前提,那就是私钥是保存在个人手上的,并且是不会被泄露的,因为谁持有私钥谁就具有相应的操作权限。

Git的GPG签名 —— Tag签名 Verified验证,防伪造的gitee/github commit验证的更多相关文章

  1. git 使用详解-- tag打标签

    Git 的标签管理.跟大多数的 VCS 工具一样,git 也有在历史状态的关键点“贴标签”的功能,一般人们用这个功能来标记发布点(例如’v1.0′). 列出git中现有标签 要想列出git中现有的所有 ...

  2. Android 获取某apk的签名信息,可用作防盗版进入。

    转载请标明出处:  http://write.blog.csdn.net/postedit/45721779作者:skay 一般项目中有防盗版的需求,必须是正版软件才能使用,这就需要获取当前安装包的签 ...

  3. md5只是用来签名,签名的作用是保证数据完整不会被破坏而已。签名和加密是两回事

    md5只是用来签名,签名的作用是保证数据完整不会被破坏而已,多一个sign标签,sign的值就是md5生成的字符串.签名和加密是两回事

  4. git使用分支与tag

    查看分支:git branch 创建分支:git branch <name> 切换分支:git checkout <name> 创建+切换分支:git checkout -b ...

  5. git 如何同步本地tag与远程tag

    问题场景:同事A在本地创建tagA并push同步到了远程->同事B在本地拉取了远程tagA(git fetch)->同事A工作需要将远程标签tagA删除->同事B用git fetch ...

  6. git 远程分支和tag标签的操作

    git远程分支操作:1.创建远程分支git push --set-upstream origin develop:develop2在服务器创建远程分支devlop2,让本地的develop分支和dev ...

  7. SpringMVC学习系列-后记 结合SpringMVC和Hibernate-validator,根据后台验证规则自动生成前台的js验证代码

    在SpringMVC学习系列(6) 之 数据验证中我们已经学习了如何结合Hibernate-validator进行后台的数据合法性验证,但是通常来说后台验证只是第二道保险,为了更好的用户体验会现在前端 ...

  8. EF里如何定制实体的验证规则和实现IObjectWithState接口进行验证以及多个实体的同时验证

    之前的Code First系列文章已经演示了如何使用Fluent API和Data Annotation的方式配置实体的属性,比如配置Destination类的Name属性长度不大于50等.本文介绍E ...

  9. //解决validator验证插件多个name相同只验证第一的问题

    //解决validator验证插件多个name相同只验证第一的问题 var validatorName = function () { if ($.validator) { $.validator.p ...

  10. Asp.net MVC验证那些事(4)-- 自定义验证特性

    在项目的实际使用中,MVC默认提供的Validation Attribute往往不够用,难以应付现实中复杂多变的验证需求.比如, 在注册用户的过程中,往往需要用户勾选”免责声明”,这个checkbox ...

随机推荐

  1. wpfui:一个开源免费具有现代化设计趋势的WPF控件库

    wpfui介绍 wpfui是一款开源免费(MIT协议)具有现代化设计趋势的WPF界面库.wpfui为wpf的界面开发提供了流畅的体验,提供了一个简单的方法,让使用WPF编写的应用程序跟上现代设计趋势. ...

  2. Java对称加解密算法AES

    Java对称加解密算法AES import org.apache.commons.codec.binary.Base64; import org.apache.commons.lang3.String ...

  3. re.search()用法详解

    re.search() 是 Python 的正则表达式库 re 中的一个方法,用于在字符串中搜索与正则表达式模式匹配的第一个位置,并返回一个匹配对象.如果没有找到匹配项,则返回 None. 以下是 r ...

  4. Nuxt3 的生命周期和钩子函数(一)

    title: Nuxt3 的生命周期和钩子函数(一) date: 2024/6/25 updated: 2024/6/25 author: cmdragon excerpt: 摘要:本文是关于Nuxt ...

  5. SpringMVC原理(1)-文件上传请求

    我们文件上传接口只需要在方法参数上写MultipartFile类,mvc就可以帮我们把上传的文件封装为这个类的对 象供我们非常方便的操作,那它是怎么做的呢?我们一起来看看 我们发的请求默认都是由Dis ...

  6. OpenCV程序练习(二):图像处理基础

    一.彩色图像像素处理 代码 import cv2 import numpy as np #----------蓝色通道---------- blue=np.zeros((300,300,3),dtyp ...

  7. 【Python】基于动态规划和K聚类的彩色图片压缩算法

    引言 当想要压缩一张彩色图像时,彩色图像通常由数百万个颜色值组成,每个颜色值都由红.绿.蓝三个分量组成.因此,如果我们直接对图像的每个像素进行编码,会导致非常大的数据量.为了减少数据量,我们可以尝试减 ...

  8. [UG 二次开发 PYTHON] 添加螺纹规格

    NX 1988 系列 在添加螺纹特征时,不能自定义螺纹规格, 从网上找到的资料上讲,改一个XML文件,在文件中添加自定义的螺纹规格,从而实现需要的效果. 自己写了一个小程序,方便手动添加螺纹规格. 效 ...

  9. MyBatis xml文件头

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC & ...

  10. SpringBoot异步任务EnableAsync

    什么是一部任务和使用场景:适用于处理log.发送邮件.短信...等 下单接口->查库存 1000 余额校验 1500 风控用户 1000 启动类里面使用@EnableAsync注解开启功能,自动 ...