国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 系統(tǒng) > Linux > 正文

Linux RPM包驗(yàn)證和數(shù)字證書(數(shù)字簽名)

2024-08-27 23:57:03
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
執(zhí)行 rpm -qa 命令可以看到,linux 系統(tǒng)中裝有大量的 RPM 包,且每個(gè)包都含有大量的安裝文件。因此,為了能夠及時(shí)發(fā)現(xiàn)文件誤刪、誤修改文件數(shù)據(jù)、惡意篡改文件內(nèi)容等問(wèn)題,Linux 提供了以下兩種監(jiān)控(檢測(cè))方式:
  • RPM 包校驗(yàn):其實(shí)就是將已安裝文件和 /var/lib/rpm/ 目錄下的數(shù)據(jù)庫(kù)內(nèi)容進(jìn)行比較,確定文件內(nèi)容是否被修改。
  • RPM 包數(shù)字證書校驗(yàn):用來(lái)校驗(yàn) RPM 包本身是否被修改。

Linux RPM 包校驗(yàn)

RPM 包校驗(yàn)可用來(lái)判斷已安裝的軟件包(或文件)是否被修改,此方式可使用的命令格式分為以下 3 種。

[root@localhost ~]# rpm -Va

-Va 選項(xiàng)表示校驗(yàn)系統(tǒng)中已安裝的所有軟件包。

[root@localhost ~]# rpm -V 已安裝的包名

-V 選項(xiàng)表示校驗(yàn)指定 RPM 包中的文件,是 verity 的首字母。

[root@localhost ~]# rpm -Vf 系統(tǒng)文件名

-Vf 選項(xiàng)表示校驗(yàn)?zāi)硞€(gè)系統(tǒng)文件是否被修改。

例如我們校驗(yàn) apache 軟件包中所有的安裝文件是否被修改,可執(zhí)行如下命令:

[root@localhost -]# rpm -V httpd

可以看到,執(zhí)行后無(wú)任何提示信息,表明所有用 apache 軟件包安裝的文件均未改動(dòng)過(guò),還和從原軟件包安裝的文件一樣。

接下來(lái)嘗試對(duì) apache 的配置文件 /etc/httpd/conf/httpd.conf 做適當(dāng)修改,修改格式如下:

[root@localhost ~]#vim /etc/httpd/conf/httpd.conf
...省略部分內(nèi)容...
Directorylndex index.html index.html.var index.php
#這句話是定義apache可以識(shí)別的默認(rèn)網(wǎng)頁(yè)文件名。在后面加入了index.php
#這句話大概有400行左右
…省略部分內(nèi)容...

由于我們還未學(xué)習(xí)如何配置 apache,為防止其崩潰,這里僅嘗試修改 apache 的默認(rèn)網(wǎng)頁(yè)文件。按照以上格式對(duì)文件進(jìn)行修改后保存退出,再次使用 rpm -V 命令對(duì) apache 軟件包進(jìn)行驗(yàn)證:

[root@localhost ~]# rpm -V httpd
S.5....T. c /etc/httpd/conf/httpd.conf

可以看到,結(jié)果顯示了文件被修改的信息。該信息可分為以下 3 部分:
  1. 最前面的 8 個(gè)字符(S.5....T)都屬于驗(yàn)證信息,各字符的具體含義如下:
    • S:文件大小是否改變。
    • M:文件的類型或文件的權(quán)限(rwx)是否改變。
    • 5:文件MD5校驗(yàn)和是否改變(可以看成文件內(nèi)容是否改變)。
    • D:設(shè)備的主從代碼是否改變。
    • L:文件路徑是否改變。
    • U:文件的屬主(所有者)是否改變。
    • G:文件的屬組是否改變。
    • T:文件的修改時(shí)間是否改變。
    • .:若相關(guān)項(xiàng)沒(méi)發(fā)生改變,用 . 表示。
  2. 被修改文件類型,大致可分為以下幾類:
    • c:配置文件(configuration file)。
    • d:普通文檔(documentation)。
    • g:"鬼"文件(ghost file),很少見,就是該文件不應(yīng)該被這個(gè) RPM 包包含。
    • l:授權(quán)文件(license file)。
    • r:描述文件(read me)。
  3. 被修改文件所在絕對(duì)路徑(包含文件名)。

由此,S.5....T. c S.5....T. c /etc/httpd/conf/httpd.conf 表達(dá)的完整含義是:配置文件 httpd.conf 的大小、內(nèi)容、修改時(shí)間被人為修改過(guò)。

注意,并非所有對(duì)文件做修改的行為都是惡意的。通常情況下,對(duì)配置文件做修改是正常的,比如說(shuō)配置 apache 就要修改其配置文件,而如果驗(yàn)證信息提示對(duì)二進(jìn)制文件做了修改,這就需要小心,除非是自己故意修改的。

Linux RPM數(shù)字證書驗(yàn)證

RPM 包校驗(yàn)方法只能用來(lái)校驗(yàn)已安裝的 RPM 包及其安裝文件,如果 RPM 包本身就被動(dòng)過(guò)手腳,此方法將無(wú)法解決問(wèn)題,需要使用 RPM 數(shù)字證書驗(yàn)證方法。

簡(jiǎn)單的理解,RPM 包校驗(yàn)其實(shí)就是將現(xiàn)有安裝文件與最初使用 RPM 包安裝時(shí)的初始文件進(jìn)行對(duì)比,如果有改動(dòng)則提示給用戶,因此這種方式無(wú)法驗(yàn)證 RPM 包本身被修改的情況。

數(shù)字證書,又稱數(shù)字簽名,由軟件開發(fā)商直接發(fā)布。Linux 系統(tǒng)安裝數(shù)字證書后,若 RPM 包做了修改,此包攜帶的數(shù)字證書也會(huì)改變,將無(wú)法與系統(tǒng)成功匹配,軟件無(wú)法安裝。

可以將數(shù)字證書想象成自己的簽名,是不能被模仿的(廠商的數(shù)字證書是唯一的),只有我認(rèn)可的文件才會(huì)簽名(只要是廠商發(fā)布的軟件,都符合數(shù)字證書驗(yàn)證);如果我的文件被人修改了,那么我的簽名就會(huì)變得不同(如果軟件改變,數(shù)字證書就會(huì)改變,從而通不過(guò)驗(yàn)證。當(dāng)然,現(xiàn)實(shí)中人的手工簽名不會(huì)直接改變,所以數(shù)字證書比手工簽名還要可靠)。

使用數(shù)字證書驗(yàn)證 RPM 包的方法具有如下 2 個(gè)特點(diǎn):
  1. 必須找到原廠的公鑰文件,然后才能進(jìn)行安裝。
  2. 安裝 RPM 包會(huì)提取 RPM 包中的證書信息,然后和本機(jī)安裝的原廠證書進(jìn)行驗(yàn)證。如果驗(yàn)證通過(guò),則允許安裝;如果驗(yàn)證不通過(guò),則不允許安裝并發(fā)出警告。

數(shù)字證書默認(rèn)會(huì)放到系統(tǒng)中/etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6位置處,通過(guò)以下命令也可驗(yàn)證:

#系統(tǒng)中的數(shù)字證書位置
[root@localhost ~]# ll /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
-rw-r--r--.1 root root 1706 6 月 26 17:29 /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6


安裝數(shù)字證書的命令如下:

[root@localhost ~]# rpm --import /efc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
--import表示導(dǎo)入數(shù)字證書


數(shù)字證書安裝完成后,可使用如下命令進(jìn)行驗(yàn)證:

[root@localhost ~]# rpm -qa|grep gpg-pubkey
gpg-pubkey-c105b9de-4e0fd3a3

可以看到,數(shù)字證書已成功安裝。在裝有數(shù)字證書的系統(tǒng)上安裝 RPM 包時(shí),系統(tǒng)會(huì)自動(dòng)驗(yàn)證包的數(shù)字證書,驗(yàn)證通過(guò)則可以安裝,反之將無(wú)法安裝(系統(tǒng)會(huì)報(bào)錯(cuò))。

數(shù)字證書本身也是一個(gè) RPM 包,因此可以用 rpm 命令查詢數(shù)字證書的詳細(xì)信息,也可以將其卸載。查詢數(shù)字證書詳細(xì)信息的命令如下:

[root@localhost ~]# rpm -qi gpg-pubkey-c105b9de-4e0fd3a3
#查詢數(shù)字證書包的詳細(xì)信息
Name : gpg-pubkey
Relocations: (not relocatable)
Version : c105b9de Vendor: (none)
Release : 4e0fd3a3 Build Date: 2012年11月12日 星期一 23時(shí)05分20秒
Install Date: 2012年11月12日星期一23時(shí)05分20秒 Build Host: local host
Group : Public Keys
Source RPM: (none)
Size : 0
License: pubkey
…省略部分輸出…
-----END PGP PUBLIC KEY BLOCK----


卸載數(shù)字證書可以使用 -e 選項(xiàng),命令如下:

[root@localhost ~]# rpm -e gpg-pubkey-c105b9de-4ead3a3

雖然數(shù)字證書可以手動(dòng)卸載,但不推薦大家將其卸載。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 莲花县| 青铜峡市| 枣强县| 内黄县| 聂拉木县| 罗江县| 谷城县| 应城市| 永靖县| 芜湖市| 威信县| 万山特区| 东台市| 五华县| 宜宾市| 寻甸| 安塞县| 蒙山县| 柘荣县| 亳州市| 鄂托克前旗| 延边| 延川县| 金乡县| 龙川县| 出国| 灵宝市| 耿马| 九江县| 崇阳县| 玛曲县| 灵川县| 武隆县| 晋中市| 财经| 上高县| 寻乌县| 昌江| 琼中| 汤阴县| 且末县|