Description
The default BKS keystore use an HMAC that is only 16 bits long, which can allow an attacker to compromise the integrity of a BKS keystore. Bouncy Castle release 1.47 changes the BKS format to a format which uses a 160 bit HMAC instead. This applies to any BKS keystore generated prior to BC 1.47. For situations where people need to create the files for legacy reasons a specific keystore type "BKS-V1" was introduced in 1.49. It should be noted that the use of "BKS-V1" is discouraged by the library authors and should only be used where it is otherwise safe to do so, as in where the use of a 16 bit checksum for the file integrity check is not going to cause a security issue in itself.
Remediation
References
http://www.securityfocus.com/bid/103453
https://access.redhat.com/errata/RHSA-2018:2927
https://www.bouncycastle.org/releasenotes.html
https://www.kb.cert.org/vuls/id/306792
https://www.oracle.com/security-alerts/cpuoct2020.html
Related Vulnerabilities
CVE-2018-11802 Vulnerability in maven package org.apache.solr:solr-core
CVE-2023-48796 Vulnerability in maven package org.apache.dolphinscheduler:dolphinscheduler-master
CVE-2019-10754 Vulnerability in maven package org.apereo.cas:cas-server-core-services-api
CVE-2023-31581 Vulnerability in maven package com.usthe.sureness:sureness-core
CVE-2021-29425 Vulnerability in maven package commons-io:commons-io