com.liferay.petra.io.ProtectedObjectInputStream Maven / Gradle / Ivy
The newest version!
/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*/
package com.liferay.petra.io;
import com.liferay.petra.lang.ClassResolverUtil;
import com.liferay.petra.string.StringUtil;
import java.io.IOException;
import java.io.InputStream;
import java.io.InvalidClassException;
import java.io.ObjectInputStream;
import java.io.ObjectStreamClass;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
/**
* @author Mika Koivisto
*/
public class ProtectedObjectInputStream extends ObjectInputStream {
public ProtectedObjectInputStream(InputStream inputStream)
throws IOException {
super(inputStream);
}
/**
* @throws ClassNotFoundException
* @throws IOException
*/
protected Class> doResolveClass(ObjectStreamClass objectStreamClass)
throws ClassNotFoundException, IOException {
String name = objectStreamClass.getName();
Thread thread = Thread.currentThread();
return ClassResolverUtil.resolve(name, thread.getContextClassLoader());
}
@Override
protected Class> resolveClass(ObjectStreamClass objectStreamClass)
throws ClassNotFoundException, IOException {
if (_restrictedClassNames.contains(objectStreamClass.getName())) {
throw new InvalidClassException(
"Reject resolving of restricted class " +
objectStreamClass.getName());
}
return doResolveClass(objectStreamClass);
}
private static final Set _restrictedClassNames;
static {
List restrictedClassNames = StringUtil.split(
System.getProperty(
ProtectedObjectInputStream.class.getName() +
".restricted.class.names"));
_restrictedClassNames = new HashSet<>(restrictedClassNames);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy