Java はファイルの書き込み時にファイルのアクセス許可を設定します

       最近、Nginx プロキシを使用してハードディスクから画像を直接読み込んだところ、ファイルの所有者が root で、Nginx の実行ユーザーが www- であるため、Nginx にファイルを読み取る権限がないことがわかりました。データのため、画像にアクセスできません。プログラムが画像を保存するとき、デフォルトでは root に設定されるため、この時点でファイルのアクセス許可を設定する必要があります。もちろん、Nginx の実行ユーザーを root に変更することもできますが、これによりセキュリティが危険にさらされます。

//下面是引入的包

import java.nio.file.*;
import java.nio.file.attribute.*;

// 将下面代码放在保存完图片之后
// filePath是 /mnt/image/test.png 这样的绝对路径
                        Path path = Paths.get(filePath);
                        FileOwnerAttributeView fileView = Files.getFileAttributeView(path, FileOwnerAttributeView.class);
                        UserPrincipalLookupService lookupService = FileSystems.getDefault().getUserPrincipalLookupService();
// 保证系统里要有www-data,不然会报错
                        UserPrincipal newOwner = lookupService.lookupPrincipalByName("www-data");
                        fileView.setOwner(newOwner);
// 这里的用户组是root,也可以改成自己想要的用户组
                        GroupPrincipal group = lookupService.lookupPrincipalByGroupName("root");
                        Files.getFileAttributeView(path, PosixFileAttributeView.class, LinkOption.NOFOLLOW_LINKS).setGroup(group);

ローカル プログラムが画像を保存した後、上記のプログラムを実行して www-data ユーザーに画像のアクセス許可を与えますが、ユーザー グループは root ですが、これは必要なユーザー グループに変更することもできます。

注: 上記の手順は、イメージをローカル ハードディスクに保存した後に実行する必要があります。

おすすめ

転載: blog.csdn.net/saperliu/article/details/126617815