我正在用Java编写一个出勤程序,用于上课;我的目标是让学生将课程文件下载到他们的帐户(我们将在同一个网络上工作),然后使用他们的用户名和密码运行它们,这些密码将每天更改。我的程序运行正常,但我遇到了一个我似乎无法克服的错误。
当它在任何一天中第一次运行时,attend.java将在我的帐户的指定目录中创建一个新的文本文件,然后将运行该程序的用户名添加到file(目前它只是将程序的第一个参数附加到文件中,但我希望修改它以使其更准确,没有人可以提供错误的用户名),从而编译学生列表。
例如,运行:
>> java attend desadams cheesecake
将使用给定的密码“cheesecake”,如果它与当天的密码匹配,或者创建一个名为“(今天的日期).txt”的新文本文件,并将用户名“desadams”写入其中(如果它是为第一个运行的话)那天的时间)或者只是将用户名“desadams”附加到预先存在的“(今天的日期).txt”文件中。
我编写了自己的createFile()方法,该方法利用java.nio.file包创建具有自定义权限的文件:
public static void createFile(File file) throws IOException{
Path newFile = file.toPath();
//create new file and set permissions
/* For the purposes of this program, the new file (the attendance list) must readable and writable to everbody
* in order for this program to work properly when run from their user, because this program both reads and modif\
ies.
*/
Set<PosixFilePermission> perms = PosixFilePermissions.fromString("rwxrw-rw-");
Files.createFile(newFile);
Files.setPosixFilePermissions(newFile, perms);
//set owner
UserPrincipal owner = newFile.getFileSystem().getUserPrincipalLookupService().lookupPrincipalByName("desadams");
Files.setOwner(newFile, owner);
//set group
GroupPrincipal group = newFile.getFileSystem().getUserPrincipalLookupService().lookupPrincipalByGroupName("studen\
ts");
Files.getFileAttributeView(newFile, PosixFileAttributeView.class).setGroup(group);
}
我无法同时创建文件并设置权限,因为帐户的umask会妨碍,所以我分两步完成它并且工作正常。
现在我们遇到了我的问题:我可以从我自己的帐户编译和运行这个程序,但是由于期望从其他帐户运行它,我改变了setOwner()方法以使用任意用户名而不是我自己的用户名更好地模拟从其他帐户运行程序的条件。它失败了。尝试将所有者设置为运行程序的人以外的任何人都会导致“不允许操作”错误。
我已经知道UNIX命令 chown 不起作用,因为没有一个网络帐户可以访问root帐户,但我没想到它会阻止Java做同样的事情,虽然我认为它确实有意义。
到底有没有解决这个问题?当然,最简单的方法是每天在其他人之前自己运行程序,以便用我自己的用户名创建考勤文件然后我就不用担心确保将所有者设置为我的程序本身内的用户名;它总能找到考勤文件,因此不必使用适当的文件属性创建它。然而,虽然这可能正是我所做的,但我想知道是否有人有一个解决方案,建议如何在程序本身内设置所有者。
谢谢,对不起,这是一篇很长的帖子。
答案 0 :(得分:0)
如果用户是您系统上的sudoers,则可以让他们执行sudo java attend desadams cheesecake
。但是,我希望它们不是sudoers,因此您首先创建文件的解决方案可能是最好的。