 
- Java.lang - Home
- Java.lang - Boolean
- Java.lang - Byte
- Java.lang - Character
- Java.lang - Character.Subset
- Java.lang - Character.UnicodeBlock
- Java.lang - Class
- Java.lang - ClassLoader
- Java.lang - Compiler
- Java.lang - Double
- Java.lang - Enum
- Java.lang - Float
- Java.lang - InheritableThreadLocal
- Java.lang - Integer
- Java.lang - Long
- Java.lang - Math
- Java.lang - Number
- Java.lang - Object
- Java.lang - Package
- Java.lang - Process
- Java.lang - ProcessBuilder
- Java.lang - Runtime
- Java.lang - RuntimePermission
- Java.lang - SecurityManager
- Java.lang - Short
- Java.lang - StackTraceElement
- Java.lang - StrictMath
- Java.lang - String
- Java.lang - StringBuffer
- Java.lang - StringBuilder
- Java.lang - System
- Java.lang - Thread
- Java.lang - ThreadGroup
- Java.lang - ThreadLocal
- Java.lang - Throwable
- Java.lang - Void
- Java.lang Package Useful Resources
- Java.lang - Useful Resources
- Java.lang - Discussion
Java SecurityManager checkRead() Method
Description
The Java SecurityManager checkRead(String file, Object context) method throws a SecurityException if the specified security context is not allowed to read the file specified by the string argument. The context must be a security context returned by a previous call to getSecurityContext.
If context is an instance of AccessControlContext then the AccessControlContext.checkPermission method will be invoked with the FilePermission(file,"read") permission. If context is not an instance of AccessControlContext then a SecurityException is thrown. 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, Object context)
Parameters
- file − the system-dependent file name. 
- context − a system-dependent security context. 
Return Value
This method does not return a value.
Exception
- SecurityException − if the specified security context is not an instance of AccessControlContext (e.g., is null), or does not have permission to read 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.security.AccessControlContext;
import java.security.AccessController;
public class SecurityManagerDemo extends SecurityManager {
   public static void main(String[] args) {
      // get current context
      AccessControlContext con = AccessController.getContext();
      // 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", con);
      // print a message if we passed the check
      System.out.println("Allowed!");
   }
}
Output
Let us compile and run the above program, this will produce the following result −
Exception in thread "main" java.lang.UnsupportedOperationException: The Security Manager is deprecated and will be removed in a future release at java.base/java.lang.System.setSecurityManager(System.java:430) at com.tutorialspoint.SecurityManagerDemo.main(SecurityManagerDemo.java:14)
Note − Security Manager has been deprecated since version 17 and marked for removal.