1
0
mirror of https://github.com/actix/actix-website synced 2024-11-28 18:32:39 +01:00
actix-website/content/docs/static-files.cn.md
2018-06-22 23:18:14 +08:00

1.5 KiB
Raw Blame History

title menu weight
静态文件 docs_advanced 230

单文件

可以使用自定义路径模式和NamedFile来提供静态文件服务。要匹配路径尾部我们可以使用[.*]正则表达式。

use std::path::PathBuf;
use actix_web::{App, HttpRequest, Result, http::Method, fs::NamedFile};

fn index(req: HttpRequest) -> Result<NamedFile> {
    let path: PathBuf = req.match_info().query("tail")?;
    Ok(NamedFile::open(path)?)
}

fn main() {
    App::new()
        .resource(r"/a/{tail:.*}", |r| r.method(Method::GET).f(index))
        .finish();
}

目录

StaticFiles可以用作特定目录和子目录文件服务。 StaticFiles必须注册一个App::handler()方法,否则它将无法服务子路径。

use actix_web::{App, fs};

fn main() {
    App::new()
        .handler(
            "/static",
            fs::StaticFiles::new(".")
                .show_files_listing())
        .finish();
}

该参数是根目录。默认情况下子目录的文件列表被禁用。尝试加载目录列表将返回404 Not Found响应。要启用文件列表请使用* StaticFiles :: show_files_listing* 方法。

与其显示目录的文件列表宁一种方法是重定向到特定的index文件。使用StaticFiles::index_file()方法来配置此重定向。