Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/avast/apkverifier
APK Signature verification in Go. Supports scheme v1, v2 and v3 and passes Google apksig's testing suite.
https://github.com/avast/apkverifier
android apk signature-verification
Last synced: 3 days ago
JSON representation
APK Signature verification in Go. Supports scheme v1, v2 and v3 and passes Google apksig's testing suite.
- Host: GitHub
- URL: https://github.com/avast/apkverifier
- Owner: avast
- License: lgpl-3.0
- Created: 2017-12-06T09:35:34.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-07-29T09:31:01.000Z (6 months ago)
- Last Synced: 2025-01-05T02:09:34.813Z (10 days ago)
- Topics: android, apk, signature-verification
- Language: Go
- Homepage:
- Size: 729 KB
- Stars: 82
- Watchers: 30
- Forks: 27
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hacking-lists - avast/apkverifier - APK Signature verification in Go. Supports scheme v1, v2 and v3 and passes Google apksig's testing suite. (Go)
README
# apkverifier
[![GoDoc](https://godoc.org/github.com/avast/apkverifier?status.svg)](https://godoc.org/github.com/avast/apkverifier)
[![Build Status](https://travis-ci.org/avast/apkverifier.svg?branch=master)](https://travis-ci.org/avast/apkverifier)APK signature verification, should support all algorithms and both scheme v1 and v2,
including downgrade attack protection.**Works with Go 1.17 or higher.**
Documentation on [GoDoc](https://godoc.org/github.com/avast/apkverifier)
go get github.com/avast/apkverifier
## Vendored stuff
Because Android can handle even broken x509 cerficates and ZIP files, apkverifier is using the ZipReader from apkparser
package and vendors `crypto/x509` in `internal/x509andr` and [github.com/fullsailor/pkcs7](https://github.com/fullsailor/pkcs7)
in the `fullsailor/pkcs7` folder.
The last two have some changes to handle some not-entirely-according-to-spec certificates.## Example
```go
package mainimport (
"fmt"
"github.com/avast/apkverifier"
"os"
)func main() {
res, err := apkverifier.Verify(os.Args[1], nil)
if err != nil {
fmt.Fprintf(os.Stderr, "Verification failed: %s\n", err.Error())
}fmt.Printf("Verification scheme used: v%d\n", res.SigningSchemeId)
cert, _ := apkverifier.PickBestApkCert(res.SignerCerts)
if cert == nil {
fmt.Printf("No certificate found.\n")
} else {
fmt.Println(cert)
}
}```