All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jetbrick.io.resource.Resource Maven / Gradle / Ivy

/**
 * Copyright 2013-2016 Guoqiang Chen, Shanghai, China. All rights reserved.
 *
 *   Author: Guoqiang Chen
 *    Email: [email protected]
 *   WebURL: https://github.com/subchen
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package jetbrick.io.resource;

import java.io.File;
import java.io.InputStream;
import java.net.URI;
import java.net.URL;
import java.nio.charset.Charset;

public interface Resource {
    public static final String URL_PREFIX_CLASSPATH = "classpath:";
    public static final String URL_PREFIX_FILE = "file:";
    public static final String URL_PREFIX_JAR = "jar:";
    public static final String URL_PREFIX_ZIP = "zip:";
    public static final String URL_PROTOCOL_FILE = "file";
    public static final String URL_PROTOCOL_JAR = "jar";
    public static final String URL_PROTOCOL_ZIP = "zip";
    public static final String URL_PROTOCOL_VFS = "vfs";
    public static final String URL_SEPARATOR_JAR = "!/";

    /**
     * 代表 Resource 名称,默认是 url/file (包含路径)
     */
    public String getRelativePathName();

    public void setRelativePathName(String relativePathName);

    /**
     * @deprecated replaced by {@link #getRelativePathName()}
     */
    @Deprecated
    public String getPath();

    /**
     * 打开文件输入流.
     */
    public InputStream openStream() throws ResourceNotFoundException;

    /**
     * 获取文件内容.
     */
    public byte[] toByteArray() throws ResourceNotFoundException;

    /**
     * 获取文件内容.
     */
    public char[] toCharArray(Charset charset) throws ResourceNotFoundException;

    /**
     * 获取文件内容.
     */
    public String toString(Charset charset) throws ResourceNotFoundException;

    /**
     * 文件对象.
     */
    public File getFile() throws UnsupportedOperationException;

    /**
     * URI 对象.
     */
    public URI getURI() throws UnsupportedOperationException;

    /**
     * URL 对象.
     */
    public URL getURL() throws UnsupportedOperationException;

    /**
     * 文件名(不包含路径)
     */
    public String getFileName();

    /**
     * 是否存在
     */
    public boolean exist();

    /**
     * 是否是一个目录
     */
    public boolean isDirectory();

    /**
     * 是否是一个文件
     */
    public boolean isFile();

    /**
     * 文件大小 (byte 长度).
     *
     * @return 如果文件不存在,返回 -1.
     */
    public long length();

    /**
     * 最后修改时间.
     *
     * @return 如果文件不存在,返回 0.
     */
    public long lastModified();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy