【问题标题】:apksigner not accepting passwordapksigner 不接受密码
【发布时间】:2017-03-31 21:53:37
【问题描述】:

到目前为止,我一直使用以下方法签署我的 apk:

jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore {keystore-file} {apk-file} {keystore-alias}

但是我正在尝试使用新的 apksigner 工具,但我无法让它工作,因为它总是告诉我密码无效。这是不可能的,因为我已经做了很多次了,jarsigner 有效,apksigner 无效。我试过的命令如下:

apksigner sign --ks {keystore-file} {apk-file}

apksigner sign --ks {keystore-file} --ks-key-alias {keystore-alias} {apk-file}

现在最奇怪的部分是我创建了一个新的密钥库来测试它,并且有了这个新的密钥库,它就可以工作了。所以我不明白有什么区别。这是通过在两者上调用“keytool -v -list -keystore {keystore-file}”获得的信息。

生产密钥库(我删除了一些文本以防万一这很危险):

Keystore type: JKS
Keystore provider: SUN

Your keystore contains 1 entry

Alias name: {keystore-alias}
Creation date: Apr 4, 2016
Entry type: PrivateKeyEntry
Certificate chain length: 1
Certificate[1]:
Owner: CN={removed-text}, OU={removed-text}, O={removed-text}, L=Unknown, ST=Unknown, C=Unknown
Issuer: CN={removed-text}, OU={removed-text}, O={removed-text}, L=Unknown, ST=Unknown, C=Unknown
Serial number: {removed-text}
Valid from: Mon Apr 04 12:39:50 CEST 2016 until: Fri Aug 21 12:39:50 CEST 2043
Certificate fingerprints:
     MD5:  {removed-text}
     SHA1: {removed-text}
     SHA256: {removed-text}
     Signature algorithm name: SHA256withRSA
     Version: 3

Extensions: 

#1: ObjectId: 2.5.29.14 Criticality=false
SubjectKeyIdentifier [
KeyIdentifier [
0000: {removed-text}
0010: {removed-text} {removed-text}                                        ....
]
]



*******************************************
*******************************************

新的测试密钥库:

Keystore type: JKS
Keystore provider: SUN

Your keystore contains 1 entry

Alias name: app
Creation date: Nov 17, 2016
Entry type: PrivateKeyEntry
Certificate chain length: 1
Certificate[1]:
Owner: CN=Foobar, OU=Foobar, O=foobar, L=Unknown, ST=Unknown, C=Unknown
Issuer: CN=Foobar, OU=Foobar, O=foobar, L=Unknown, ST=Unknown, C=Unknown
Serial number: 448c7afc
Valid from: Thu Nov 17 11:40:26 CET 2016 until: Mon Apr 04 12:40:26 CEST 2044
Certificate fingerprints:
     MD5:  3E:29:C0:3C:30:B4:DC:E0:A5:94:1D:2E:E9:86:58:CA
     SHA1: 3D:09:B4:42:A2:7C:14:C7:3E:54:33:0E:AB:75:2E:F1:19:23:00:FA
     SHA256: 7F:E0:51:F1:6A:53:45:56:42:B9:F9:38:92:69:81:7A:DA:71:FF:44:51:15:7F:F9:B4:1C:AA:2B:53:4A:89:72
     Signature algorithm name: SHA256withRSA
     Version: 3

Extensions: 

#1: ObjectId: 2.5.29.14 Criticality=false
SubjectKeyIdentifier [
KeyIdentifier [
0000: BC 1B E6 C4 6D 25 01 70   CA AC 81 34 81 4B AE 41  ....m%.p...4.K.A
0010: 10 DF D8 13                                        ....
]
]



*******************************************
*******************************************

【问题讨论】:

  • 您从 apksigner 收到的错误消息/异常是什么?此外,通过 --ks-pass pass: 和 --key-pass pass: 以不同的组合向 apksigner 提供密码会改变什么吗?试试 --ks-pass 和没有 --key-pass 和 --key-pass 和没有 --ks-pass。
  • @AlexKlyubin 好的,所以我得到的错误是一个简单的“密码验证失败”,但是在尝试了你所说的之后,在 cmd 中提供了密码,我得到了“密钥库密码的密码规范不支持” ”。我不知道哪个是密码规范,但我将密码更改为更简单的版本(没有特殊字符),现在它可以工作了。我不明白他们为什么要改变格式。无论如何,这解决了我的问题,所以如果您想将评论移至答案,我会将其标记为已接受。如果您能阐明为什么会发生这种情况,那将是一个很好的加分:D。谢谢。
  • 很高兴听到您找到了解决方法。您是否去掉了特殊字符或将它们替换为 ASCII 等效字符(例如,“a with umlaut”变成了“a”)?
  • 我删除了它们,我使用的密码只有字母数字字符。
  • 我相信我想通了。我现在已提交 code.google.com/p/android/issues/detail?id=234089 以跟踪问题并正在研究修复/解决方法。 keytool/jarsigner 中的这个问题也可能解释了与 Android Plugin for Gradle / Android Studio 发出的类似问题,无法使用某些密钥库,报告密码错误。

标签: android apk sign


【解决方案1】:

原始答案可以在问题的 cmets 上找到,我将其移至此处以便将问题标记为已回答。

虽然我仍然不确定 100% 的详细信息,但问题是我用于密钥库的密码包含特殊字符(* 和!)。将密码更改为字母数字格式后,问题就解决了。因此,apksigner 似乎不接受与 jarsigner 相同的密码格式。

【讨论】:

    【解决方案2】:

    哇,我不知道您可以在密钥库中更改密码。

    无论如何,我遇到了这个确切的问题,事实证明您不需要更改密码。诀窍是设置选项

    --ks-pass stdin --key-pass stdin
    

    这应该是默认行为,但在我的情况下,它只有在我特别包含这些时才有效。

    执行命令,系统会要求你输入密码,即使是!这样的字符也能正常工作。

    【讨论】:

    • 不幸的是,我已经尝试过但仍然无法正常工作,在这种情况下我使用的是字符¡,但我仍然认为令人沮丧的是,在我能找到的任何地方都没有记录。 jarsigner 仍然使用相同的密码,所以这不是密码的问题。
    • 为我工作,想不出如果他们确实将值 stdin 实现为“默认”,怎么会发生这种情况。
    【解决方案3】:

    这样使用

    ./apksigner sign --ks test.jks --ks-key-alias test --ks-pass pass:testtest --key-pass pass:testtest Test_Aligned.apk
    

    【讨论】:

      【解决方案4】:

      我还不能投票/评论,但是 +1 为 max 的修复:

      ./apksigner sign --ks test.jks --ks-key-alias test --ks-pass pass:testtest --key-pass pass:testtest Test_Aligned.apk
      

      为我的密码加上“pass:”前缀对我有用

      --ks-pass pass:MyPassword
      --key-pass pass:MyPassword
      

      【讨论】:

        【解决方案5】:

        这对我有用,我改变了这个:

        --ks-pass "MyPassword"

        到这里:

        --ks-pass pass:"MyPassword"

        一个奇怪的 API 可以使用......但它有效!

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2018-02-20
          • 2019-08-02
          • 1970-01-01
          • 2020-09-03
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多