通过先unlink()后close()创建安全的临时文件
来源:互联网 发布:淘宝店铺手机端 编辑:程序博客网 时间:2024/05/17 21:52
使用POSIX(Portable Operating System Interface)标准文件操作函数可以创建安全的临时文件:
- 使用open()创建临时文件。
- 马上调用unlink()删除文件,该临时文件将被从当前目录中去除;但inode会等到所有打开的文件描述符都关闭(reference count = 0)时才被删除。在此之前变成一个孤儿(orphan inode),使用ls 或者 du 都无法查看到该文件;但是对所在的文件系统进行df 还是可以知道该文件的存在。
- 使用完毕后调用close()关闭文件,这样文件就会在文件系统中完全消失。
这样创建的临时文件具有如下安全性:
- 如果程序崩溃,操作系统会关闭该程序打开的所有文件。该临时文件会在关闭时消失,而不会依然保留在文件系统中。
- 用户无法对该文件进行存取,也就无法对里面的内容进行监控、过滤等动作。
当然还有其他方式:加密,多次覆盖重写文件存储区域防止数据恢复,等等。或者可以将多种方式结合以满足较高的安全要求。
示例代码unlink_before_close.c
编译执行:
$ gcc -o unlink_before_close unlink_before_close.c $ ./unlink_before_close
- 通过先unlink()后close()创建安全的临时文件
- 通过unlink创建安全的临时文件
- 创建临时文件 tmpnam tmpfile tempnam mkstemp unlink
- 创建临时文件 tmpnam tmpfile tempnam mkstemp unlink
- 创建临时文件 tmpnam tmpfile tempnam mkstemp unlink
- 如何在Linux创建安全的临时文件
- close与unlink的关系与区别
- close 与 unlink区别
- close和unlink
- Linux系统的临时文件安全
- 创建临时文件的简单方法
- 创建临时文件的简单方法 .
- 利用mkstemp创建程序退出后不会被删除的临时文件
- 创建临时文件
- 创建临时文件
- 创建临时文件
- 创建临时文件
- Linux中link,unlink,close,fclose详解
- POJ 2104 归并树 or 划分树
- 非奇异矩阵的LU分解C++程序
- Asp.net 后台调用js方法
- 点覆盖的次数
- create tooltips using CSS transitions and the pseudo-classes :before and :after
- 通过先unlink()后close()创建安全的临时文件
- open vswitch研究:datapath
- 最受欢迎的10个Linux发行版
- 离软件设计研发越来越远
- python简明教程学习总结1
- 黑马程序员_day10 面向对象(异常的处理,导包,jar包)。
- 空间分析之水文分析
- 黑马程序员_day11 多线程。
- MVC 3.0学习笔记(防止跨站点请求伪造 (CSRF) 攻击)