1.RPM包校验

    <1>rpm -V 已安装的包名

    <2>选项:

          -V    校验制定RPM包中的文件(verify)

    <3>说明:

        <1>若没有显示任何内容,则证明包正常,则没有被修改过

        <2>一旦有显示,则证明包被修改过,

          且会在相应位置显示出被修改过的属性所代表的字母(.说明该属性没有被修改)

-----------------------------------------------------------------------------------------------------------------

    验证内容中8个信息的具体内容如下:

      S    文件大小是否改变

      M    文件的类型或文件的权限(rwx)是否改变

      5    文件MD5校验和是否改变(可以看成文件内容是否改变)

      D    设备的主从代码是否改变

      L    文件路径是否改变

      U    文件的属主(所有者)是否改变

      G    文件的属组是否改变

      T    文件的修改时间是否改变

-----------------------------------------------------------------------------------------------------------------

    文件类型:

      c    配置文件(config file)

      d    普通文档(documentation)

      g    “鬼”文件(ghost file),很少见,就是该文件不应该被这个rpm包包含

      L    授权文件(license file)

      r    描述文件(read me)

-----------------------------------------------------------------------------------------------------------------

        <3>若出现鬼文件,有可能是出现漏洞或被攻击的可能

        <4>该命令用于验证你的文件与官方提供的文件是否相同,从而判断系统文件是否被做过修改

  2.RPM包中文件提取

    <1>rpm2cpio 包全名 | cpio -idv .文件绝对路径

    <2> --- rpm2cpio    //将rpm包转换为cpio格式的命令

        --- cpio      //是一个标准工具,它用于创建软件档案文档和从档案文件中提取文件

    <3>若由于误操作,不小心删除某些重要系统命令,如ls等,

      可以通过rpm包提取文件的方法进行恢复

    <4>命令: cpio 选项 < [文件|设备] //可以使用重定向也可以使用管道符

      选项:

          -i    copy-in模式,还原

          -d    还原时自动创建新目录

          -v    显示还原过程

-----------------------------------------------------------------------------------------------------

    <1>比如,不小心删除了ls命令

        where is ls

        mv /bin/ls  /tmp  //由于是做实验,不要真的删除,剪切就好

    <2>此时就无法使用ls命令了

    <3>接着可以使用cpio从rpm包中提取文件进行恢复

    <4>首先 查询ls命令属于哪个软件包

        rpm -qf /bin/ls

    <5>接着造成误删除ls命令的假象

        mv /bin/ls /tmp/

    <6>提取rpm包中的ls命令到当前所在目录下

      rpm2cpio /mnt/cdrom/Packages/coreutils-8.4-19.el6.i686.rpm | cpio -idv ./bin/ls

      .表示提取到当前目录,因此要考虑当前所在位置

      ./bin/ls表示我要提取这个文件

    <7>把ls命令复制回/bin/目录,修复文件丢失

3-5 RPM包校验的更多相关文章

  1. [Linux] 023 RPM 包校验与文件提取

    1. RPM 包校验 $ rpm -V 已安装的包名 选项 释义 -V (verify) 校验指定 RPM 包中的文件 (1) 验证内容中的 8 个信息的具体内容如下 信息名称 释义 S 文件大小是否 ...

  2. Linux系列(33)- rpm命令管理之RPM包校验提取(5)

    校验 格式 rpm -V 已安装的包名 选项: - -V:校验指定RPM包中的文件(verify) 例子 rpm -V httpd 后, 无任何提示, 代表该文件没有被做任何修改 # 判断本地的apa ...

  3. RPM包校验和提取

    一.RPM包校验 [root@localhost Packages]# rpm -V 已安装的包名 #选项: #    -V    校验指定RPM包中的文件(verify) [root@localho ...

  4. RPM包安装软件 -- 详细解读

    一.RPM包命名规则 1.RPM包在哪 RPM包在光盘中 2.RPM包命名原则 httpd-2.2.15-15.e16.centos.1.i686.rpm httpd 软件包名 2.2.15 软件版本 ...

  5. Linux下RPM包的安装

    Linux下RPM包安装 二进制包(RPM包.系统默认包) RPM安装 rpm -ivh 包全名(查询依赖网址:http://www.rpmfind.net) -i(install):安装 -v(ve ...

  6. rpm包软件管理

    一.rpm介绍 linux服务器中所有的软件包安装方式有两种,一种是源码安装.另一种是二进制包安装(rpm)源码包安装的好处是适合不同的发行版本的linux,缺点是在编译过程中花费的时间很长,二进制包 ...

  7. RPM包和YUM仓库管理

    1.RPM包管理 RPMRPM Package Manger,前身Redhat Package Manger,由红帽开发用于软件包的安装升级卸载与查询有一个完整的数据库体系,每个RPM包的所有信息都固 ...

  8. 『学了就忘』Linux软件包管理 — 43、RPM包的校验和证书

    目录 1.RPM包的校验 (1)RPM包校验基本命令 (2)校验某个系统文件是否被修改举例 (3)验证内容中8个信息的具体内容 (4)文件类型有哪些 2.RPM包的证书 (1)数字证书 (2)数字证书 ...

  9. linux rpm之已安装包校验、rpm包中文件提取

    已安装包校验 rpm -V 已安装的包名-V 校验指定rpm包中的文件 rpm -V pth没有任何提示,说明自安装后没有做过任何修改 rpm包中文件提取 比如对一个系统配置文件误操作,可以根据这个文 ...

随机推荐

  1. VS设置背景色减缓眼睛疲劳

    工具--选项--字体和颜色--(纯文本)项背景色--自定义... 色调:85 饱和度:123 亮度:205 可自己微调 字体设为10.

  2. Browser GetImage

    using Microsoft.Win32; using System; using System.ComponentModel; using System.Drawing; using System ...

  3. json_decode 与 json_encode 的区别

    1.json_decode对JSON格式的字符串进行编码 2.json_encode对变量进行 JSON 编码 3.unset()是注销定义的变量 4.urlencode()函数原理就是首先把中文字符 ...

  4. stm32 dac 配置过程

    DAC模块的通道1来输出模拟电压,其详细设置步骤如下: 1)开启PA口时钟,设置PA4为模拟输入. STM32F103ZET6的DAC通道1是接在PA4上的,所以,我们先要使能PORTA的时钟,然后设 ...

  5. hdu 2061

    PS:  以为找个简单来恢复信心..结果碰到那么傻逼的题目... 题意:给出学分和成绩,算GPA...关键是注意换行....它要求的换行我觉得超级奇怪...除了第一个正常,其他的输入完之后先一个换行. ...

  6. python3爬虫初探(五)之从爬取到保存

    想一想,还是写个完整的代码,总结一下前面学的吧. import requests import re # 获取网页源码 url = 'http://www.ivsky.com/tupian/xiaoh ...

  7. iOS提交AppStore被拒原因

    1. Terms and conditions(法律与条款) 1.1 As a developer of applications for the App Store you are bound by ...

  8. array_walk() 函数

    array_walk() 函数对数组中的每个元素应用回调函数.如果成功则返回 TRUE,否则返回 FALSE. 典型情况下 function 接受两个参数.array 参数的值作为第一个,键名作为第二 ...

  9. JQuery 实现倒计时

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  10. 解决magento添加产品在前台不显示问题

    有时候我们在magento系统添加产品,前台不显示,最模板分析可能 以下几个原因: 1 添加新品要重新index一下,magento是静态的.html页面,不reindex不出来的.在System→I ...