Question 285 of 509
Java I/O API and Securing ApplicationsmediumMultiple ChoiceObjective-mapped

Quick Answer

The correct approach is to grant `java.io.FilePermission` in the security policy file for the specific file path. This is because Java’s `SecurityManager` enforces a sandbox model where all file operations are restricted by default; to read a file outside the application directory, you must explicitly authorize the operation by adding a `grant` entry in the policy file with the exact file path and the `read` action. Without this permission, any attempt to access the external file throws an `AccessControlException`. On the Oracle Certified Professional Java SE 17 Developer 1Z0-829 exam, this question tests your understanding of the legacy `SecurityManager` and policy file syntax—a common trap is assuming that simply setting a security manager allows all access, or confusing `FilePermission` with `SocketPermission`. Remember the mnemonic: “Policy first, permission last” — always define the path and action explicitly in the policy file before the code can read outside its home directory.

1Z0-829 Java I/O API and Securing Applications Practice Question

This 1Z0-829 practice question tests your understanding of java i/o api and securing applications. Match the stated requirement to the specific cloud service, access model, or configuration option — many options are valid in isolation but not for this scenario. After answering, compare your reasoning against the explanation and wrong-answer breakdown below. Once you have made your selection, read the full explanation to reinforce the concept and understand why each distractor is designed to mislead on exam day.

A Java application running in a secure environment needs to read a file located outside the application's directory. Which approach correctly handles security?

Question 1mediummultiple choice
Full question →

Answer choices

Why each option matters

Answer the question above first, then reveal the full breakdown to understand why each option is right or wrong.

Correct answer & explanation

Grant java.io.FilePermission in the security policy file for the specific file path

Option B is correct because in a secure Java environment, the SecurityManager enforces access controls based on the security policy file. To read a file outside the application's directory, you must explicitly grant `java.io.FilePermission` with the specific file path and the `read` action in the policy file. Without this permission, any attempt to read the file will throw a `java.security.AccessControlException`.

Key principle: Answer the scenario, not the keyword: identify the specific constraint before choosing the most familiar-sounding option.

Answer analysis

Option-by-option breakdown

For each option: why learners choose it and why it is or isn't the right answer here.

  • Use FileInputStream without any additional configuration

    Why it's wrong here

    If a security manager is enabled, it may deny access without explicit permission.

  • Grant java.io.FilePermission in the security policy file for the specific file path

    Why this is correct

    This grants the application permission to read the file under the security manager.

    Related concept

    Read the scenario before looking for a memorised answer.

  • Use java.net.URL to access the file via file:// protocol

    Why it's wrong here

    URL still requires permission and may not bypass security restrictions.

  • Set the file readable flag using File.setReadable(true)

    Why it's wrong here

    This changes file system permissions, not Java security policy.

Common exam traps

Common exam trap: answer the scenario, not the keyword

The trap here is that candidates often confuse OS-level file permissions (like `setReadable`) with Java's SecurityManager permissions, or assume that using a URL protocol bypasses security checks, when in fact the SecurityManager enforces the same policy regardless of the I/O API used.

Detailed technical explanation

How to think about this question

The Java SecurityManager uses a sandbox model where code is granted permissions via a policy file (e.g., `java.policy`). The `FilePermission` class represents access to a file or directory, and its actions include `read`, `write`, `delete`, and `execute`. When a file is accessed, the SecurityManager calls `checkPermission` with a `FilePermission` object; if the permission is not granted, an `AccessControlException` is thrown. This mechanism is critical in environments like applets or enterprise servers where untrusted code must be restricted.

KKey Concepts to Remember

  • Read the scenario before looking for a memorised answer.
  • Find the constraint that changes the correct option.
  • Eliminate answers that are true in general but not in this case.

TExam Day Tips

  • Watch for words such as best, first, most likely and least administrative effort.
  • Review why wrong options are wrong, not only why the correct option is correct.

Key takeaway

Answer the scenario, not the keyword: identify the specific constraint before choosing the most familiar-sounding option.

Real-world example

How this comes up in practice

A small business has 20 workstations on the 192.168.1.0/24 network and one public IP from its ISP. The router uses PAT (NAT overload) so all 20 devices share one public address using different source ports. NAT questions test whether you understand the four address terms and which direction each translation applies.

What to study next

Got this wrong? Here's your next step.

Identify which exam domain this question belongs to, review the core concept, then practise similar questions from the same domain.

Related practice questions

Related 1Z0-829 practice-question pages

Use these pages to review the topic behind this question. This is how one missed question becomes focused revision.

Practice this exam

Start a free 1Z0-829 practice session

Short sessions build daily habit. Longer sessions build exam-day stamina. Try a timed session to simulate real conditions.

FAQ

Questions learners often ask

What does this 1Z0-829 question test?

Java I/O API and Securing Applications — This question tests Java I/O API and Securing Applications — Read the scenario before looking for a memorised answer..

What is the correct answer to this question?

The correct answer is: Grant java.io.FilePermission in the security policy file for the specific file path — Option B is correct because in a secure Java environment, the SecurityManager enforces access controls based on the security policy file. To read a file outside the application's directory, you must explicitly grant `java.io.FilePermission` with the specific file path and the `read` action in the policy file. Without this permission, any attempt to read the file will throw a `java.security.AccessControlException`.

What should I do if I get this 1Z0-829 question wrong?

Identify which exam domain this question belongs to, review the core concept, then practise similar questions from the same domain.

What is the key concept behind this question?

Read the scenario before looking for a memorised answer.

About these practice questions

Courseiva creates original exam-style practice questions with explanations and wrong-answer analysis. It does not publish real exam questions, exam dumps, or protected exam content. Learn why practice questions differ from exam dumps →

How Courseiva writes practice questions · Editorial policy

Keep practising

More 1Z0-829 practice questions

Last reviewed: Jun 11, 2026

Question Discussion

Share a tip, memory trick, or ask about the reasoning behind this question. Do not post real exam questions, leaked content, braindumps, or copyrighted exam material. Comments are moderated and may be removed without notice.

Loading comments…

Sign in to join the discussion.

This 1Z0-829 practice question is part of Courseiva's free Oracle certification practice question bank. Courseiva provides original exam-style practice questions with explanations, topic-based practice, mock exams, readiness tracking, and study analytics to help learners prepare for the 1Z0-829 exam.