0N/A/*
0N/A * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved.
0N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0N/A *
0N/A * This code is free software; you can redistribute it and/or modify it
0N/A * under the terms of the GNU General Public License version 2 only, as
0N/A * published by the Free Software Foundation.
0N/A *
0N/A * This code is distributed in the hope that it will be useful, but WITHOUT
0N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
0N/A * version 2 for more details (a copy is included in the LICENSE file that
0N/A * accompanied this code).
0N/A *
0N/A * You should have received a copy of the GNU General Public License version
0N/A * 2 along with this work; if not, write to the Free Software Foundation,
0N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0N/A *
873N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
0N/A * or visit www.oracle.com if you need additional information or have any
0N/A * questions.
0N/A */
0N/A
0N/A/**
868N/A * @test
0N/A * @bug 4804972
0N/A * @summary Ensure JKS keystore implementation fail early when users
2086N/A * attempt to store SecretKeys.
0N/A */
0N/Aimport javax.crypto.SecretKey;
0N/Aimport javax.crypto.spec.SecretKeySpec;
1280N/Aimport java.security.KeyStore;
0N/Aimport java.security.Security;
1280N/Aimport java.security.Key;
0N/Aimport java.security.KeyStoreException;
0N/A
1280N/Apublic class TestJKSWithSecretKey {
0N/A
2086N/A private static char[] passwd = { 'p','a','s','s','w','d'};
2086N/A
2086N/A public static void main (String[] args) throws Exception {
2086N/A SecretKey key = new SecretKeySpec(new byte[8], "DES");
1787N/A
1280N/A KeyStore ks = KeyStore.getInstance("JKS");
1280N/A ks.load(null, passwd);
1280N/A
1280N/A try {
1280N/A // store the SecretKey
1280N/A ks.setKeyEntry("test_encrypt_key", key, passwd, null);
1338N/A throw new Exception("Should throw KeyStoreException when " +
0N/A "storing SecretKey into JKS keystores");
0N/A } catch (KeyStoreException kse) {
0N/A // expected exception thrown; swallow
1280N/A }
0N/A }
1280N/A}
1280N/A