AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 509487
Accepted
kasperd
kasperd
Asked: 2014-08-11 10:57:23 +0800 CST2014-08-11 10:57:23 +0800 CST 2014-08-11 10:57:23 +0800 CST

检查源包完整性的官方方法是什么?

  • 772

我想给 pam 添加一个功能,我想一个好的起点是下载libpam-modules源代码。下载时,我注意到此警告:gpgv: Can't check signature: public key not found

apt-get找不到公钥时,官方验证源包完整性的方法是什么?

最新版本的ubuntu-keyring和debian-keyring软件包已经安装。

有一些方法可以找到相应的公钥并安装它。然而,这本身并不能提供完整性,因为实际上它是在信任dsc文件的内容来告诉我使用哪个公钥来验证dsc文件上的签名。

文件上的 gpg 签名dsc是完整性验证的关键部分吗?中间人或恶意镜像是否可以提供恶意版本的文件,其中来自 gpg 的警告是发生不良事件的唯一迹象?或者是否apt-get有其他验证完整性的方法?

我在哪里可以找到关于安全模型的官方文档?理想情况下,我想了解从安装映像到我正在下载的源包的完整信任路径。

下载的完整输出是这样的:

$ apt-get source libpam-modules
Reading package lists... Done
Building dependency tree       
Reading state information... Done
Picking 'pam' as source package instead of 'libpam-modules'
NOTICE: 'pam' packaging is maintained in the 'Bzr' version control system at:
https://code.launchpad.net/~ubuntu-core-dev/pam/ubuntu
Please use:
bzr branch https://code.launchpad.net/~ubuntu-core-dev/pam/ubuntu
to retrieve the latest (possibly unreleased) updates to the package.
Need to get 2,043 kB of source archives.
Get:1 http://dk.archive.ubuntu.com/ubuntu/ trusty/main pam 1.1.8-1ubuntu2 (dsc) [2,510 B]
Get:2 http://dk.archive.ubuntu.com/ubuntu/ trusty/main pam 1.1.8-1ubuntu2 (tar) [1,893 kB]
Get:3 http://dk.archive.ubuntu.com/ubuntu/ trusty/main pam 1.1.8-1ubuntu2 (diff) [147 kB]
Fetched 2,043 kB in 6s (316 kB/s)                                              
gpgv: Signature made Fri 31 Jan 2014 11:12:23 PM CET using RSA key ID 64792D67
gpgv: Can't check signature: public key not found
dpkg-source: warning: failed to verify signature on ./pam_1.1.8-1ubuntu2.dsc
apt
  • 2 2 个回答
  • 4177 Views

2 个回答

  • Voted
  1. Best Answer
    kasperd
    2014-08-12T06:54:44+08:002014-08-12T06:54:44+08:00

    无需验证文件上的 gpg 签名即可验证源包的完整性dsc。

    每个安装源都有一对名为Release和的文件Release.gpg。这两个文件是哈希树的根,可用于验证存档中所有内容的完整性。gpg 签名Release是唯一需要验证的签名。

    dsc在将文件放入存储库并通过 间接签名之前,文件上的签名可能起到重要作用Release.gpg。一旦文件在存储库中,dsc就可以忽略文件上的签名。

    以下是我如何手动验证完整性。据我所知,apt-get source进行相同的验证。

    1. 下载http://dk.archive.ubuntu.com/ubuntu/dists/trusty/Release和http://dk.archive.ubuntu.com/ubuntu/dists/trusty/Release.gpg。
    2. 使用检查签名gpg --keyring /etc/apt/trusted.gpg --verify Release.gpg Release(公钥也可以在中找到/usr/share/keyrings/ubuntu-archive-keyring.gpg)
    3. 下载http://dk.archive.ubuntu.com/ubuntu/dists/trusty/main/source/Sources.gz
    4. 比较从sha256sum Sources.gz和获得的哈希值grep main/source/Sources.gz Release
    5. 比较从sha256sum pam_1.1.8-1ubuntu2.dsc和获得的哈希值zcat Sources.gz | grep pam_1.1.8-1ubuntu2.dsc
    6. dsc验证在文件中找到的哈希值:cat pam_1.1.8-1ubuntu2.dsc | sed -e 's/^ //;s/ [1-9][0-9]* / /' | sha256sum -c
    • 3
  2. saiarcot895
    2014-08-11T12:01:43+08:002014-08-11T12:01:43+08:00

    您看到该警告的原因是因为源包是由开发人员自己的密钥签名的,而您从 repo 获得的二进制包是由 repo 签名密钥签名的。由于ubuntu-keyring只给出了最终 repo 的密钥环(debian-keyring实际上还提供了其所有维护者apt的公钥),找不到密钥并认为包未经身份验证。

    因此,这里的解决方案是从密钥服务器导入密钥。您还可以在 Launchpad 上查找源包(pam在此处),单击对包进行最后更改的人的电子邮件地址,然后从那里检查密钥指纹。

    在这种情况下,最后一个更改包裹的人是 Stéphane Graber,而他的钥匙恰好在debian-keyring(具体来说,在/usr/share/keyrings/debian-maintainers.gpg)中。您可以安装该debian-keyring软件包,从该密钥环中导出他的密钥,然后将该密钥导入您自己的密钥环中,以便apt验证它是否已正确签名。

    • 1

相关问题

  • 如何编写 shell 脚本来安装应用程序列表?

  • 如何查看存档中可用的软件包的所有版本?

  • 是否可以说出我安装的哪些软件包不在原版安装中?

  • 如何删除 PPA?

  • 使用 apt-get upgrade 时如何强制安装内核更新?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve