/* * Copyright (c) 2021, Oracle and/or its affiliates. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * - Neither the name of Oracle or the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream; import sun.misc.ObjectInputFilter; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; /** * Demonstrates the filter factory BasicFilterFactory. Run it with the following * command: * * java -Djdk.serialFilterFactory=BasicFilterFactory TestBasicFilter */ public class TestBasicFilter { private static byte[] createSimpleStream(Object obj) { ByteArrayOutputStream boas = new ByteArrayOutputStream(); try (ObjectOutputStream ois = new ObjectOutputStream(boas)) { ois.writeObject(obj); return boas.toByteArray(); } catch (IOException ioe) { ioe.printStackTrace(); } throw new RuntimeException(); } static class FilterNumber implements ObjectInputFilter { public Status checkInput(FilterInfo filterInfo) { Class clazz = filterInfo.serialClass(); if (clazz != null) { return (Number.class.isAssignableFrom(clazz)) ? Status.ALLOWED : Status.REJECTED; } return Status.UNDECIDED; } } public static void main(String[] args) throws IOException { // Set the JVM-wide static filter ObjectInputFilter filter1 = ObjectInputFilter.Config .createFilter("example.*;java.lang.*;!*"); ObjectInputFilter.Config.setSerialFilter(filter1); // Create another filter ObjectInputFilter filter2 = new FilterNumber(); // Create input stream byte[] intByteStream = createSimpleStream(42); InputStream is = new ByteArrayInputStream(intByteStream); ObjectInputStream ois = new ObjectInputStream(is); ObjectInputFilter.Config.setObjectInputFilter(ois, filter2); try { Object obj = ois.readObject(); System.out.println("Read obj: " + obj); } catch (ClassNotFoundException e) { e.printStackTrace(); } } }