001/* 002 * Licensed to the Apache Software Foundation (ASF) under one or more 003 * contributor license agreements. See the NOTICE file distributed with 004 * this work for additional information regarding copyright ownership. 005 * The ASF licenses this file to You under the Apache License, Version 2.0 006 * (the "License"); you may not use this file except in compliance with 007 * the License. You may obtain a copy of the License at 008 * 009 * https://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017 018package org.apache.commons.codec.digest; 019 020import java.security.MessageDigest; 021 022/** 023 * Standard {@link MessageDigest} algorithm names from the <cite>Java Cryptography Architecture Standard Algorithm Name 024 * Documentation</cite>. 025 * <p> 026 * This class is immutable and thread-safe. 027 * </p> 028 * <ul> 029 * <li>Java 8 and up: SHA-224.</li> 030 * <li>Java 9 and up: SHA3-224, SHA3-256, SHA3-384, SHA3-512.</li> 031 * </ul> 032 * 033 * @see <a href="https://docs.oracle.com/javase/8/docs/technotes/guides/security/StandardNames.html#MessageDigest"> 034 * Java 8 Cryptography Architecture Standard Algorithm Name Documentation</a> 035 * @see <a href="https://docs.oracle.com/en/java/javase/11/docs/specs/security/standard-names.html#messagedigest-algorithms"> 036 * Java 11 Cryptography Architecture Standard Algorithm Name Documentation</a> 037 * @see <a href="https://docs.oracle.com/en/java/javase/17/docs/specs/security/standard-names.html#messagedigest-algorithms"> 038 * Java 17 Cryptography Architecture Standard Algorithm Name Documentation</a> 039 * @see <a href="https://docs.oracle.com/en/java/javase/21/docs/specs/security/standard-names.html#messagedigest-algorithms"> 040 * Java 21 Cryptography Architecture Standard Algorithm Name Documentation</a> 041 * 042 * @see <a href="https://dx.doi.org/10.6028/NIST.FIPS.180-4">FIPS PUB 180-4</a> 043 * @see <a href="https://dx.doi.org/10.6028/NIST.FIPS.202">FIPS PUB 202</a> 044 * @since 1.7 045 */ 046public class MessageDigestAlgorithms { 047 048 /** 049 * The MD2 message digest algorithm defined in RFC 1319. 050 */ 051 public static final String MD2 = "MD2"; 052 053 /** 054 * The MD5 message digest algorithm defined in RFC 1321. 055 */ 056 public static final String MD5 = "MD5"; 057 058 /** 059 * The SHA-1 hash algorithm defined in the FIPS PUB 180-2. 060 */ 061 public static final String SHA_1 = "SHA-1"; 062 063 /** 064 * The SHA-224 hash algorithm defined in the FIPS PUB 180-3. 065 * <p> 066 * Present in Oracle Java 8. 067 * </p> 068 * 069 * @since 1.11 070 */ 071 public static final String SHA_224 = "SHA-224"; 072 073 /** 074 * The SHA-256 hash algorithm defined in the FIPS PUB 180-2. 075 */ 076 public static final String SHA_256 = "SHA-256"; 077 078 /** 079 * The SHA-384 hash algorithm defined in the FIPS PUB 180-2. 080 */ 081 public static final String SHA_384 = "SHA-384"; 082 083 /** 084 * The SHA-512 hash algorithm defined in the FIPS PUB 180-2. 085 */ 086 public static final String SHA_512 = "SHA-512"; 087 088 /** 089 * The SHA-512 hash algorithm defined in the FIPS PUB 180-4. 090 * <p> 091 * Included starting in Oracle Java 9. 092 * </p> 093 * 094 * @since 1.14 095 */ 096 public static final String SHA_512_224 = "SHA-512/224"; 097 098 /** 099 * The SHA-512 hash algorithm defined in the FIPS PUB 180-4. 100 * <p> 101 * Included starting in Oracle Java 9. 102 * </p> 103 * 104 * @since 1.14 105 */ 106 public static final String SHA_512_256 = "SHA-512/256"; 107 108 /** 109 * The SHA3-224 hash algorithm defined in the FIPS PUB 202. 110 * <p> 111 * Included starting in Oracle Java 9. 112 * </p> 113 * 114 * @since 1.11 115 */ 116 public static final String SHA3_224 = "SHA3-224"; 117 118 /** 119 * The SHA3-256 hash algorithm defined in the FIPS PUB 202. 120 * <p> 121 * Included starting in Oracle Java 9. 122 * </p> 123 * 124 * @since 1.11 125 */ 126 public static final String SHA3_256 = "SHA3-256"; 127 128 /** 129 * The SHA3-384 hash algorithm defined in the FIPS PUB 202. 130 * <p> 131 * Included starting in Oracle Java 9. 132 * </p> 133 * 134 * @since 1.11 135 */ 136 public static final String SHA3_384 = "SHA3-384"; 137 138 /** 139 * The SHA3-512 hash algorithm defined in the FIPS PUB 202. 140 * <p> 141 * Included starting in Oracle Java 9. 142 * </p> 143 * 144 * @since 1.11 145 */ 146 public static final String SHA3_512 = "SHA3-512"; 147 148 /** 149 * Gets all constant values defined in this class. 150 * 151 * @return all constant values defined in this class. 152 * @since 1.11 153 */ 154 public static String[] values() { 155 // Do not use a constant array here as that can be changed externally by accident or design 156 return new String[] { 157 MD2, MD5, SHA_1, SHA_224, SHA_256, SHA_384, 158 SHA_512, SHA_512_224, SHA_512_256, SHA3_224, SHA3_256, SHA3_384, SHA3_512 159 }; 160 } 161 162 private MessageDigestAlgorithms() { 163 // cannot be instantiated. 164 } 165 166}