Java.lang.SecurityManager.checkRead() Method



Description

The java.lang.SecurityManager.checkRead(String file) method throws a SecurityException if the calling thread is not allowed to read the file specified by the string argument. This method calls checkPermission with the FilePermission(file,"read") permission. If you override this method, then you should make a call to super.checkRead at the point the overridden method would normally throw an exception.

Declaration

Following is the declaration for java.lang.SecurityManager.checkRead() method

public void checkRead(String file)

Parameters

file − the system-dependent file name.

Return Value

This method does not return a value.

Exception

  • SecurityException − if the calling thread does not have permission to access the specified file.

  • NullPointerException − if the file argument is null.

Example

Our examples require that the permissions for each command is blocked. A new policy file was set that allows only the creating and setting of our Security Manager. The file is in C:/java.policy and contains the following text −

grant {
   permission java.lang.RuntimePermission "setSecurityManager";
   permission java.lang.RuntimePermission "createSecurityManager";
   permission java.lang.RuntimePermission "usePolicy";
};

The following example shows the usage of lang.SecurityManager.checkRead() method.

package com.tutorialspoint;

import java.io.FileDescriptor;

public class SecurityManagerDemo extends SecurityManager {

   public static void main(String[] args) {

      // set the policy file as the system securuty policy
      System.setProperty("java.security.policy", "file:/C:/java.policy");

      // create a security manager
      SecurityManagerDemo sm = new SecurityManagerDemo();

      // set the system security manager
      System.setSecurityManager(sm);

      // perform the check
      sm.checkRead("test.txt");

      // print a message if we passed the check
      System.out.println("Allowed!");
   }
}

Let us compile and run the above program, this will produce the following result −

Allowed!
java_lang_securitymanager.htm
Advertisements