GPG在Linux上的应用主要是实现官方发布的包的签名机制加密
GPG分为公钥及私钥spa
公钥:顾名思意,便可共享的密钥,主要用于验证私钥加密的数据及签名要发送给私钥方的数据.net
私钥:由本地保留的密钥,用于签名本地数据及验证用公钥签名的数据blog
实现原理(以Red Hat签名为例):crontab
1>RH在发布其官方的RPM包时(如本地RHEL光盘及FTP空间包),会提供一个GPG密钥文件,即所谓的公钥ip
2>用户下载安装这个RPM包时,引入RH官方的这个RPM GPG公钥,用来验证RPM包是否是RH官方签名的md5
导入GPG-KEY:get
能够去https://www.redhat.com/security/team/key/或/etc/pki/rpm-gpg查找相应的GPG密钥,并导入到RPM:rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEYit
签名及加密概念:io
签名与加密不是一个概念
签名相似于校验码,用于识别软件包是否是被修改过,最经常使用的的就是咱们的GPG及MD5签名,原方使用必定的字符(MD5)或密码(GPG私钥)与软件进行相应的运算并获得一个定长的密钥
加密是用必定的密钥对原数据进行修改,即便程序在传输中被截获,只要它不能解开密码,就不能对程序进行修改,除非破坏掉文件,那样咱们就知道软件被修改过了
RPM验证方法:
1>验证安装的整个软件包的文件rpm -V crontabs-1.10-8
2>验证软件包中的单个文件
rpm -Vf /etc/crontab
若是文件没有被修改过,则不输出任何信息
3>验证整个软件包是否被修改过
rpm -Vp AdobeReader_chs-7.0.9-1.i386.rpm
.......T /usr/local/Adobe/Acrobat7.0/Reader/GlobalPrefs/reader_prefs
S.5....T /usr/local/Adobe/Acrobat7.0/bin/acroread
4>验证签名
rpm -K AdobeReader_chs-7.0.9-1.i386.rpm
AdobeReader_chs-7.0.9-1.i386.rpm: sha1 md5 OK
验证结果含意:
S :file Size differs
M :Mode differs (includes permissions and file type)
5 :MD5 sum differs
D :Device major/minor number mis-match
L :readLink(2) path mis-match
U :User ownership differs
G :Group ownership differs
T :mTime differs