使用临时文件要考虑几个问题:
保证临时文件间的文件名不互助冲突。
保证临时文件中内容不被其他用户或者黑客偷看、删除和修改。
Linux中提供了mkstemp和tmpfile函数来处理临时文件。
mkstemp函数
intmkstemp(char*template);
mkstemp函数在系统中以唯一的文件名创建一个文件并打开,而且只有当前用户才能访问这个临时文件,并进行读、写操作。mkstemp函数只有一个参数,这个参数是个以XXXXXX结尾的非空字符串。mkstemp函数会用随机产生的字符串替换XXXXXX,保证了文件名的唯一性。函数返回一个文件描述符,如果执行失败返回-1。在glibc2.0.6以及更早的glibc库中这个文件的访问权限是0666,glibc2.0.7以后的库这个文件的访问权限是0600。
临时文件使用完成后应及时删除,否则临时文件目录会塞满垃圾。由于mkstemp函数创建的临时文件不能自动删除,所以执行完mkstemp函数后要调用unlink函数,unlink函数删除文件的目录入口,但临时文件还可以通过文件描述符进行访问,直到最后一个打开的进程关闭文件操作符,或者程序退出后临时文件被自动彻底地删除。
[cpp]viewplaincopy在CODE上查看代码片派生到我的代码片<spanstyle="font-size:18px;">#include<stdio.h>#include<string.h>#include<unistd.h>#include<stdlib.h>intwrite_temp_file(char*buffer,size_tlength){intlen=length;charfilename_template[]="/tmp/temp_file.XXXXXX";intfd=mkstemp(filename_template);unlink(filename_template);//Unlinkthefile,soit'llberemovedwhencloseprintf("Templatefilename:%s\n",filename_template);write(fd,&len,sizeof(len));write(fd,buffer,len);returnfd;}char*read_temp_file(intfd,size_t*length){char*buffer;lseek(fd,0,SEEK_SET);read(fd,length,sizeof(size_t));buffer=(char*)malloc(*length);read(fd,buffer,*length);close(fd);//Tempfilewillbedeletedreturnbuffer;}intmain(intargc,char**argv){charbuffer[]="Testtemplatefiles";intfd=write_temp_file(buffer,strlen(buffer));intlen=0;char*result=read_temp_file(fd,&len);printf("Len:%d\nContent:%s\n",len,result);free(result);return0;}</span>