Access restriction: The type 'Application' is not API (restriction on required library rt.jar)
Asked Answered
C

22

208

Here is the code:

package mscontroller;

import javax.swing.*;
import com.apple.eawt.Application;

public class Main {
    public static void main(String[] args)
    {
        Application app = new Application();
        app.setEnabledAboutMenu(true);

        AMEListener listener = new AMEListener();
        app.addApplicationListener(listener);
        JFrame mainFrame = new JFrame("Application Menu Example");
        mainFrame.setSize(500, 500);
        mainFrame.setVisible(true);
    }
}

here is the error:

Exception in thread "main" java.lang.Error: Unresolved compilation
problems:   Access restriction: The type 'Application' is not API
(restriction on required library
'/Library/Java/JavaVirtualMachines/jdk1.8.0_11.jdk/Contents/Home/jre/lib/rt.jar')
    Access restriction: The constructor 'Application()' is not API
(restriction on required library
'/Library/Java/JavaVirtualMachines/jdk1.8.0_11.jdk/Contents/Home/jre/lib/rt.jar')
    Access restriction: The type 'Application' is not API (restriction on
required library
'/Library/Java/JavaVirtualMachines/jdk1.8.0_11.jdk/Contents/Home/jre/lib/rt.jar')
    Access restriction: The method
'Application.setEnabledAboutMenu(boolean)' is not API (restriction on
required library
'/Library/Java/JavaVirtualMachines/jdk1.8.0_11.jdk/Contents/Home/jre/lib/rt.jar')
    AMEListener cannot be resolved to a type    AMEListener cannot be
resolved to a type

    at mscontroller.Main.main(Main.java:9)

eclipse says this:

Access restriction: The type 'Application' is not API (restriction on required library '/Library/Java/JavaVirtualMachines/jdk1.8.0_11.jdk/Contents/Home/jre/lib/rt.jar')

Cabrera answered 9/8, 2014 at 20:35 Comment(8)
Try running this using Java 7.Turf
Check these for relevancy: #860687 , #9267132Cyrano
Not using Xcode (yet)Cabrera
I'm not to familiar to java the guy doesn't give an exact path. What does he mean by: com/sun/xml/internal/**Cabrera
Could you interpret what path he's talking about? Thank you! In the future I will switch to either xCode or netbeans. The guy above said to try java 7 should I?Cabrera
Are you building this in maven? the file path typically references the path in your local maven repository where the jar is kept.Blackdamp
i had a similar problem when i imported a java 1.8 luna project into mars. made a new project in mars and copied src/ in. all the red goes away.Snowcap
The "access restriction" error may also happen in Bonita Studio. This is most probably due to a missing dependency for the project (Menu Development -> Manage dependencies -> import...).Indus
S
316

This happened to me as well, and the answers given here already were not satisfying, so I did my own research.

Background: Eclipse access restrictions

Eclipse has a mechanism called access restrictions to prevent you from accidentally using classes which Eclipse thinks are not part of the public API. Usually, Eclipse is right about that, in both senses: We usually do not want to use something which is not part of the public API. And Eclipse is usually right about what is and what isn't part of the public API.

Problem

Now, there can be situations, where you want to use public Non-API, like sun.misc (you shouldn't, unless you know what you're doing). And there can be situations, where Eclipse is not really right (that's what happened to me, I just wanted to use javax.smartcardio). In that case, we get this error in Eclipse.

Solution

The solution is to change the access restrictions.

  • Go to the properties of your Java project,
    • i.e. by selecting "Properties" from the context menu of the project in the "Package Explorer".
  • Go to "Java Build Path", tab "Libraries".
  • Expand the library entry
  • select
    • "Access rules",
    • "Edit..." and
    • "Add..." a "Resolution: Accessible" with a corresponding rule pattern. For me that was "javax/smartcardio/**", for you it might instead be "com/apple/eawt/**".
Simulant answered 29/3, 2015 at 12:42 Comment(9)
I have Eclipse Mars (4.5.0) and there are no access rules in Java Build Path -> Libraries. FWIW there's a bigger hammer (you can turn them all off) in Preferences -> Java -> Compiler -> Errors / Warnings -> Deprecated and Restricted API.Foamy
I have Eclipse Mars.1 Release (4.5.1). For me both solution worked. The answer from Christian and the comment from Jonathan. In the tab Libraries you have to open the one among the listed "JARs and class folders" to see the "Access rules" belongs to it.Gussy
This does NOT work for me. Eclipse Luna. Tried JDK 1.8, 1.7, added access rules, clean project, the errors keep coming back. Also tried suggestion of @JonathanRoss - access rules for forbidden and discouraged references are ALREADY set to Warning, but I get errors.Rutherfordium
This does NOT work for me. Eclipse Luna. Tried JDK 1.8, 1.7, added access rules, clean project, the errors keep coming back. Also tried suggestion of @JonathanRoss - first at Project Level. There, although Project-level configs for Forbidden/Discouraged APIs were set to Warning, I still got errors. I then tried (as Jonathan suggested) going through preferences for workspace level settings, and THERE, Forbidden APIs were set to Error. Changing to warning there did make problem go away, but project level setting should have overridden, think that is a bug in Eclipse.Rutherfordium
I wasn't allowed to modify access restriction in my case: Eclipse Neon with a maven jar project on jar "jfxrt.jar".Sandi
What is the nonpublic API? I mean I would think all APIs would be public. I searched google for "private API" but not sure what I found is the same thing.Samora
@Samora thanks for asking that question. The term non-public API is rubbish, I've updated it to public Non-API. I hope that clarifies. If not, just ask again.Simulant
There is a much simpler alternative: removing and adding back the JRE System Library, as pointed out in https://mcmap.net/q/53652/-access-restriction-on-class-due-to-restriction-on-required-library-rt-jarRadford
@Radford That solution only works if the class in question is part of rt.jar. If the access restriction happened on a different jar on the classpath, removing and adding back rt.jar will not solve the issue. Also, adding back rt.jar will grant access to all packages from rt.jar, which is usually not what you want Eclipse to do. It would make you lose the warning about accessing public Non-API.Simulant
D
99

I was having the same problem. When I initially created the java project in Eclipse I specified JRE 8. When I went into the project's build path and edited the JRE System Library, the Java 8 execution environment was selected. When I chose to use an "Alternate JRE" (still java 8) it fixed the error for me.

Dumfries answered 4/2, 2015 at 21:39 Comment(6)
I'd preferred a global fix, but it's better than all the other answers that enable restricted API globally. (I don't want to accidentally use sun.* in my javafx application).Stopgap
Thanks, this cleared all warnings in my project. Eclipse was complaining about all classes that were provided by JavaFX (jfxrt.jar)Farquhar
Confirmed...I changed JRE 8 u60 with...JRE 8 u60. Apparently, this rebuild being triggered, as opposed to any other way to do so, has the side-effect of fixing the issue. (For a more detailed explanation on how to change this setting, see Nikhil Mahajan's answer here: #6882122 .)Adrianadriana
Thank you! With this strategy i was able to sucessfully compile the spark java framework.Hymenopteran
Strangely this worked. I only have one JDK installed. How weird.Creek
Anyone know how to apply this automatically in Gradle? Whenever I do a Gradle > Refresh, it just override it back to the Java 1.8.Rumpf
W
77

Adding javafx accessible permission in eclipse oxygen go to project> properties> java build path> libraries> then expand the libraries and double click on> Access rules there you set the permission Resolution : Accessible Rule Pattern : javafx/**

enter image description here

enter image description here

enter image description here

Warfore answered 1/10, 2017 at 15:0 Comment(0)
G
23

To begin with (and unrelated), instantiating the Application class by yourself does not seem to be its intended use. From what one can read from its source, you are rather expected to use the static instance returned by getApplication().

Now let's get to the error Eclipse reports. I've ran into a similar issue recently: Access restriction: The method ... is not API (restriction on required project). I called the method in question as a method of an object which inherited that method from a super class. All I had to do was to add the package the super class was in to the packages imported by my plugin.

However, there is a lot of different causes for errors based on "restriction on required project/library". Similar to the problem described above, the type you are using might have dependencies to packages that are not exported by the library or might not be exported itself. In that case you can try to track down the missing packages and export them my yourself, as suggested here, or try Access Rules. Other possible scenarios include:

  • Eclipse wants to keep you from using available packages that are not part of the public Java API (solution 1, 2)
  • Dependencies are satisfied by multiple sources, versions are conflicting etc. (solution 1, 2, 3)
  • Eclipse is using a JRE where a JDK is necessary (which might be the case here, from what your errors say; solution) or JRE/JDK version in project build path is not the right one

This ended up as more like a medley of restriction-related issues than an actual answer. But since restriction on required projects is such a versatile error to be reported, the perfect recipe is probably still to be found.

Gera answered 31/10, 2014 at 13:38 Comment(0)
C
21

We had to change our application to build against the JDK 1.8 using Window->Preferences->Java->Installed JREs. However, after changing that, the JRE System Library specified in the Project Explorer was still incorrect. To fix this, right click on "JRE System Library [wrong-jre-here]" and change from Execution environment: to "Workspace Default (yer-default-here)"

enter image description here

Crocoite answered 7/5, 2018 at 23:20 Comment(0)
F
18

I had this problem because the project facet associated with my project was the wrong java version.

To fix this is I did the following:

  1. Right click on the project and select Properties
  2. Select 'Project Facets' and change version of java to something greater than 1.4.
  3. Click [Apply]

This will rebuild your project and hopefully the error will be resolved.

Foliate answered 10/4, 2015 at 1:28 Comment(0)
M
14

It worked: Project Properties -> ProjectFacets -> Runtimes -> jdk1.8.0_45 -> Apply

Moulton answered 11/5, 2016 at 17:51 Comment(1)
system hung up :(Natashianatassia
P
14

In the Eclipse top menu bar:

Windows -> Preferences -> Java -> Compiler -> Errors/Warnings -> 
Deprecated and restricted API -> Forbidden reference (access rules): -> change to warning
Permanganate answered 16/11, 2016 at 7:27 Comment(0)
M
10

If you're having this same issue using Spring Tool Suite:

The Spring Tool Suite's underlying IDE is, in fact, Eclipse. I've gotten this error just now trying to use some com.sun.net classes. To remove these errors and prevent them from popping up in the Eclipse Luna SR1 (4.4.2) platform of STS:

  • Navigate to Project > Properties
  • Expand the Java Compiler heading
  • Click on Errors/Warnings
  • Expand deprecated and restricted API
  • Next to "Forbidden reference (access rules)" select "ignore"
  • Next to "Discouraged reference (access rules)" select "ignore"

You're good to go.

Morgun answered 9/6, 2015 at 12:51 Comment(0)
C
7

Had the same problem. Here's how I solved it: Go to Package Explorer. Right click on JRE System Library and go to Properties. In the Classpath Container > Select JRE for the project build path select the third option (Workspace default JRE).

Source : https://thenewboston.com/forum/topic.php?id=3917

Cos answered 23/4, 2017 at 14:20 Comment(1)
Thanks... using the answer proposed by C Hujer I actually found there were "162 rules (non-modifiable)" for the file jfxrt.jar!Flotage
P
6

We use IBM Rational Application Developer (RAD) and had the same problem.

ErrorMessage:

Access restriction: The type 'JAXWSProperties' is not API (restriction on required library 'C:\IBM\RAD95\jdk\jre\lib\rt.jar')

Solution:

go to java build path and under Library tab, remove JRE System Library. Then again Add Library --> JRE System Library

Poodle answered 14/1, 2019 at 15:40 Comment(0)
P
5

Go to the following setting:

Window -> Preferences -> Java-Compiler-Errors/Warnings-Deprecated and restricted API-Forbidden reference (access rules)

Set it to Warning or Ignore.

Perimeter answered 21/9, 2016 at 7:56 Comment(0)
C
4

In Eclipse Mars.2 Release (4.5.2):
Project Explorer -> Context menu -> Properties -> JavaBuildPath -> Libraries
select JRE... and press Edit: Switch to Workspace JRE (jdk1.8.0_77)

Works for me.

Culprit answered 6/12, 2016 at 12:59 Comment(0)
V
4

Even if its old question, for me in Eclipse I just right click on Src folder and properties (Alt+Enter) and the check for the Ignore optional compile problems removed the error.

enter image description here

Vest answered 20/4, 2020 at 13:58 Comment(0)
S
3

I have eclipse JRE 8.112 , not sure if that matters but what i did was this:

  1. Right clicked on my projects folder
  2. went down to properties and clicked
  3. clicked on the java build path folder
  4. once inside, I was in the order and export
  5. I checked the JRE System Library [jre1.8.0_112]
  6. then moved it up above the one other JRE system library there (not sure if this mattered)
  7. then pressed ok

This solved my problem.

Saponify answered 14/1, 2017 at 15:4 Comment(0)
E
3

I simply just add e(fx)clipse in eclipse marketplace. Easy and simple

Enunciate answered 6/5, 2017 at 3:2 Comment(1)
Exactly, despite its description mentionning Java FX 2 and FXML, ef(x)clipse also configures Eclipse so it considers jfxrt.jar as an API.Zagreus
M
3

Remove Existing/Configured System Library: Eclipse(IDE) -> Project Explorer -> Project Name-> (Option) Build Path -> Configure Build Path -> Java Build Path -> Libraries -> (Select) JRE System Library [(For me)jre1.8.0_231] -> Remove.

Currently you are at same location: Eclipse(IDE) -> Project Explorer -> Project Name-> (Option) Build Path -> Configure Build Path -> Java Build Path -> Libraries

Now Add Same System Library Again: Add Library -> JRE System Library -> Workspace default JRE ((For me)jre1.8.0_231) -> Finish -> Apply -> Close.

Now wait to finish it.

Marxist answered 28/9, 2020 at 22:38 Comment(0)
M
2

What worked for me was adding the access restricted package to the MANIFEST.MF file. In Eclipse, the "Access Restricted" errors showed up in the Problems tab for several files. I just right clicked on each error, clicked "Quick Fix", and chose "Add '[package]' to imported packages".

Matilda answered 18/8, 2021 at 16:27 Comment(0)
L
1

I'm using eclipse neon 3. I just wanted to use javafx.application.Application, so I followed Christian Hujer's answer above and it worked. Just some tips: the access rules are very similar to the import statement. For me, the access rules I added was "javafx/application/**". Just replace the dot in the import statement with forward slash and that's the rule. Hope that helps.

Lust answered 7/5, 2017 at 21:28 Comment(0)
N
1

I had a little different problem. In Project - Properties - Libraries - JRE library, I had the wrong JRE lib version. Remove and set the actual one, and voila - all Access restriction... warnings are away.

Nickelous answered 18/4, 2019 at 20:30 Comment(0)
G
1

If someone is having this issue only in your CI tool while running maven, what did the trick for me was to explicitly define the execution environment in your MANIFEST.MF.

In my case, I did this by inserting the following line in my OSGi bundle manifest file:

Bundle-RequiredExecutionEnvironment: JavaSE-1.8
Graminivorous answered 21/9, 2019 at 2:14 Comment(0)
D
0

I had faced the same error on Eclipse 4.20.0 with JRE 1.8. To get rid of this compilation error, do the following:

Project --> Properties --> Java Compiler --> Errors/Warnings --> Deprecated and Restricted API --> Forbidden Reference (access rules) -->  ignore
Denominational answered 25/3, 2022 at 7:15 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.