Java创建文件时出现拒绝访问

本文探讨了Java中创建文件时遇到的‘拒绝访问’异常,重点在于如何正确处理路径问题,避免因直接使用盘符路径导致的IO异常。通过实例演示了如何选择合适的文件夹路径并创建新文件。

Java创建文件时出现拒绝访问

​ 不能让盘目录直接作为保存路径,所以出现了IOxception

package com.yyr.FileText;

import java.io.File;


public class NewFile {
    public static void main(String[] args) throws Exception {
        File fl=new File("c:\\class.txt");
        System.out.println(fl.createNewFile());//创建新文件
    }
}

在这里插入图片描述

以下是我更换了路径后

package com.yyr.FileText;

import java.io.File;


public class NewFile {
    public static void main(String[] args) throws Exception {
        File fl=new File("c:\\open\\clas.txt");
        System.out.println(fl.createNewFile());//创建新文件
    }
}

在这里插入图片描述

在这里插入图片描述

Java创建文件目录后拒绝访问可能由多种原因导致,以下是几种常见的解决办法: ### 确保文件存在并创建上级目录 在填写文件路径,需写上具体的文件名称(如xx.txt),先判断当前文件是否存在,如果存在则略过,如果不存在,先创建上级目录再创建文件: ```java import java.io.File; import java.io.IOException; public class CreateFileExample { public static void main(String[] args) { // 在填写文件路径,一定要写上具体的文件名称(xx.txt),否则会出现拒绝访问。 File file = new File("./mywork/work.txt"); if (!file.exists()) { // 先得到文件的上级目录,并创建上级目录,再创建文件 file.getParentFile().mkdir(); try { // 创建文件 file.createNewFile(); } catch (IOException e) { e.printStackTrace(); } } } } ``` 这种方法可以避免因文件不存在或上级目录未创建而导致的拒绝访问问题[^1]。 ### 创建多级目录 若因为目录不存在而出现拒绝访问问题,可先判断目录是否存在,不存在则创建多级目录: ```java import java.io.File; public class CreateDirectoryExample { public static void main(String[] args) { File file1 = new File("your_directory_path"); // 要判断目录是否存在!!! if (!file1.exists()) { // 创建多级目录 file1.mkdirs(); } } } ``` 通过这种方式可以确保所需的目录结构被正确创建,避免因目录缺失而产生的访问问题[^2]。 ### 确保输出流指定目标文件而非目录 输出流必须指定目标文件,不能指定目录。以下是一个文件复制的示例,展示了如何正确使用输出流: ```java import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.FSDataInputStream; import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.Path; import org.apache.hadoop.io.IOUtils; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.net.URI; import java.net.URISyntaxException; public class FileCopyExample { public void downLoadFileTest() throws URISyntaxException, IOException { // 获取filesystem对象 FileSystem fileSystem = FileSystem.get(new URI("hdfs://master:9000"), new Configuration()); // 获取hdfs输入流 FSDataInputStream inputStream = fileSystem.open(new Path("/lee/test1.txt")); // 获取本地文件的输出流 FileOutputStream outputStream = new FileOutputStream(new File("D://Hadoop3.x课程/day02/lee/test1.txt")); // 实现文件的复制 IOUtils.copy(inputStream, outputStream); // 关闭流,先关闭输入流 IOUtils.closeQuietly(inputStream); IOUtils.closeQuietly(outputStream); fileSystem.close(); } } ``` 此示例确保了输出流指向的是具体的文件,而非目录,避免了因指定目录而导致的拒绝访问问题[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值