如何使用set_mode将权限应用于文件



如果我的理解是正确的,下面的代码应该会生成一个可执行文件。但事实并非如此;它会被创建,但指定的权限不会被应用。我做错了什么?

use std::fs;
use std::os::unix::PermissionsExt;

fn main() {
    fs::File::create("somefile").unwrap()
        .metadata().unwrap()
        .permissions()
        .set_mode(0o770);
}

使用OpenOptions:

use std::fs;
use std::os::unix::OpenOptionsExt;
fn main() {
    fs::OpenOptions::new()
        .create(true)
        .write(true)
        .mode(0o770)
        .open("somefile")
        .unwrap();
}

您还可以对现有路径使用set_permissions

use std::fs;
use std::os::unix::fs::PermissionsExt;
fn main(){
     fs::set_permissions("/path", fs::Permissions::from_mode(0o655)).unwrap();
}

最新更新