UNIX操作系统tar命令之隐患及解决方法( 二 )


第二种方法笔者进行了有效的尝试,并用c编写了一个修补程序mtar.c,经编译成mtar运行程序,本程序具有以下功能:
Amtar -v tarfi1e 修补任何原因造成的tar档案包中文件的chksum错误(包括本程序的-c功能) 。
Bmtar -t tarfi1e 查考tar档案包中文件信息 。
C mtar -c tarfi1e 加密tar档案包,使tar命令不能打开该包 。
D mtar -p tarfi1e 将包中的所有文件置压缩状态标志 。
E mtar -u tarfi1e 将包中所有文件置非压缩状态标志 。四、 实际应用
本程序使用5个选项 -t -c -v -p -u,每次只能用一个参数,每个参数对应一个功能 。
例如:mtar -v abc 既可修复上面提到的abc包打不开问题 。
mtar -v /dev/fd0135ds18可修复tar格式3″软盘 。
mtar -c /dev/fd0135ds18可加密tar格式3″软盘 。
mtar -v /dev/fd0135ds18可解密tar格式3″软盘 。
mtar -t abc可详细列出abc包中文件信息,sum_v=0表示文件属性头校验正常,compress=[1]表示文件抽取时自动解压缩 。
本程序从编写至今笔者进行了十四次改版,使该程序适合含任何文件类型的tar档案包 。并在SCO UNIX 3242和SCO OPENSERVER 50下多次进行编译和全面功能测试 。现将该程序整理出来,敬请同行多加指教 。源程序附后 。
Mtar.c内容如下:
#include″stdio.h″
#include″string.h″
#include″unistd.h″
#include″sys/types.h″
#include″sys/stat.h″
#include″fcntl.h″

#define TBLOCK 512
#define NBLOCK 20
#define NAMSIZ 100
union hblock {
char dummy[TBLOCK];
struct header {
char name[NAMSIZ];
char mode[8];
char uid[8];
char gid[8];
char size[12];
char mtime[12];
char chksum[8];
char linkflag;
char linkname[NAMSIZ];
char extno[4];
char extotal[4];
char efsize[12];
char compid;
} dbuf,
} dblock;
main(argc,argv)
int argc;
char *argv[];
{
char compress;
int i,seekip=0,ip,compc;
long sum,sum_v,filesize=0,mvblock=0,total;
FILE*fp;
ip=0;
if(strncmp(argv[1],″-c″,2)==0) ip=1;
if(strncmp(argv[1],″-v″,2)==0) ip=1;
if(strncmp(argv[1],″-t″,2)==0) ip=1;
if(strncmp(argv[1],″-p″,2)==0) ip=1;
if(strncmp(argv[1],″-u″,2)==0) ip=1;

if(argc !=3||ip !=1)
{
printf(″Usage:mtar-[c,v,t,p,u]tarfilen″);
exit(1);
}
if((fp=fopen(argv[2],″r+″))==NULL)
{
printf(″Can not open the %sn″,argv[2]);
exit(1);
}
while(seekip==0)
{
if(fread((dblock.dummy),TBLOCK,1,fp)!=1)
{
printf(″Can not read the%s !n″,argv[2]);
break;
}
sum=0;
compc=0;
for(i=0;i< TBLOCK;i++) sum=sum+dblock.dumm
y[i];
for(i=0;i< 8,i++)sum=sum-dblock.dbuf.chksum[i];
if(sum==0)break;

ip=0;
if(strncmp(argv[1],″-c″,2)==0)
compress=dblock.dbuf.compid;
sum_v=270*0xff+0400; ip=1;
}
if(strncmp(argv[1],″-v″,2)==0)
compress=dblock.dbuf.compid;
sum_v=sum+0400; ip=1
}
if(strncmp(argv[1],″-p″,2)==0)
compc=dblock.dbuf.compid;
compc=0x31-compc;
sum_v=sum+0400+compc;
compress=0x31; ip=1;
}
if(strncmp(argv[1],″-u″,2)==0)
compc=dblock.dbuf.compid;
compc=0x00-compc;
sum_v=sum+0400+compc;
compress=0x00; ip=1;
}
if(ip==1)
{
if(sum-v >=0)sprintf (dblock.dbuf.
chksum,″%60″,sum_v);
else
{
dblock.dbuf.chksum[0]=′-′;
dblock.dbuf.chksum[6]=0x00;
dblock.dbuf.chksum[7]=0x00;
sum_v=sum_v-dblock.dbuf.linkflag;
sum=sum-dblock.dbuf.linkflag;
dblock.dbuf.linkflag=0x00;
for(i=0;isum_v=sum_v-dblock.dbuf.linkname[i];
sum=sum-dblock.dbuf.linkname[i];
dblock.dbuf.linkname[i]=0x00;
}
sprintf(dblock.dbuf.chksum+1,″%-50″,-sum_v);
}
sprintf(&dblock.dbuf.compid,″%c″,compress);

推荐阅读