Commit 6b05e791 by Andrew Haley

natClass.cc (initializeClass): Re-throw SecurityExceptions.

2007-01-26  Andrew Haley  <aph@redhat.com>

        * java/lang/natClass.cc (initializeClass): Re-throw
        SecurityExceptions.
        * java/lang/natVMClassLoader.cc (loadClass): checkPackageAccess.
        * java/lang/ClassLoader.java: (loadClass): Likewise.

From-SVN: r121285
parent 2631dfdd
...@@ -404,6 +404,14 @@ public abstract class ClassLoader ...@@ -404,6 +404,14 @@ public abstract class ClassLoader
protected synchronized Class loadClass(String name, boolean resolve) protected synchronized Class loadClass(String name, boolean resolve)
throws ClassNotFoundException throws ClassNotFoundException
{ {
SecurityManager sm = SecurityManager.current;
if (sm != null)
{
int lastDot = name.lastIndexOf('.');
if (lastDot != -1)
sm.checkPackageAccess(name.substring(0, lastDot));
}
// Arrays are handled specially. // Arrays are handled specially.
Class c; Class c;
if (name.length() > 0 && name.charAt(0) == '[') if (name.length() > 0 && name.charAt(0) == '[')
......
...@@ -50,6 +50,7 @@ details. */ ...@@ -50,6 +50,7 @@ details. */
#include <java/lang/NullPointerException.h> #include <java/lang/NullPointerException.h>
#include <java/lang/RuntimePermission.h> #include <java/lang/RuntimePermission.h>
#include <java/lang/System.h> #include <java/lang/System.h>
#include <java/lang/SecurityException.h>
#include <java/lang/SecurityManager.h> #include <java/lang/SecurityManager.h>
#include <java/lang/StringBuffer.h> #include <java/lang/StringBuffer.h>
#include <java/lang/VMClassLoader.h> #include <java/lang/VMClassLoader.h>
...@@ -690,6 +691,10 @@ java::lang::Class::initializeClass (void) ...@@ -690,6 +691,10 @@ java::lang::Class::initializeClass (void)
{ {
_Jv_Linker::wait_for_state(this, JV_STATE_LINKED); _Jv_Linker::wait_for_state(this, JV_STATE_LINKED);
} }
catch (java::lang::SecurityException *x)
{
throw x;
}
catch (java::lang::Throwable *x) catch (java::lang::Throwable *x)
{ {
// Turn into a NoClassDefFoundError. // Turn into a NoClassDefFoundError.
...@@ -727,6 +732,10 @@ java::lang::Class::initializeClass (void) ...@@ -727,6 +732,10 @@ java::lang::Class::initializeClass (void)
{ {
_Jv_InitClass (superclass); _Jv_InitClass (superclass);
} }
catch (java::lang::SecurityException *x)
{
throw x;
}
catch (java::lang::Throwable *except) catch (java::lang::Throwable *except)
{ {
// Caught an exception. // Caught an exception.
...@@ -745,6 +754,10 @@ java::lang::Class::initializeClass (void) ...@@ -745,6 +754,10 @@ java::lang::Class::initializeClass (void)
if (meth) if (meth)
((void (*) (void)) meth->ncode) (); ((void (*) (void)) meth->ncode) ();
} }
catch (java::lang::SecurityException *x)
{
throw x;
}
catch (java::lang::Throwable *except) catch (java::lang::Throwable *except)
{ {
if (! java::lang::Error::class$.isInstance(except)) if (! java::lang::Error::class$.isInstance(except))
......
...@@ -32,8 +32,10 @@ details. */ ...@@ -32,8 +32,10 @@ details. */
#include <java/security/ProtectionDomain.h> #include <java/security/ProtectionDomain.h>
#include <java/lang/ClassFormatError.h> #include <java/lang/ClassFormatError.h>
#include <java/lang/StringBuffer.h> #include <java/lang/StringBuffer.h>
#include <java/lang/SecurityManager.h>
#include <java/lang/Runtime.h> #include <java/lang/Runtime.h>
#include <java/util/HashSet.h> #include <java/util/HashSet.h>
#include <java/lang/SecurityException.h>
#include <java/lang/VirtualMachineError.h> #include <java/lang/VirtualMachineError.h>
java::lang::Class * java::lang::Class *
...@@ -204,6 +206,16 @@ java::lang::VMClassLoader::nativeFindClass (jstring name) ...@@ -204,6 +206,16 @@ java::lang::VMClassLoader::nativeFindClass (jstring name)
jclass jclass
java::lang::VMClassLoader::loadClass(jstring name, jboolean resolve) java::lang::VMClassLoader::loadClass(jstring name, jboolean resolve)
{ {
using namespace ::java::lang;
SecurityManager *sm = (SecurityManager *)SecurityManager::current;
if (sm)
{
jint lastDot = name->lastIndexOf('.');
if (lastDot != -1)
sm->checkPackageAccess(name->substring(0, lastDot));
}
// We try the boot loader first, so that the endorsed directory // We try the boot loader first, so that the endorsed directory
// overrides compiled-in classes. // overrides compiled-in classes.
jclass klass = NULL; jclass klass = NULL;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment