2022.11.10---进程

本文档展示了如何使用C语言实现一个程序,通过opendir和readdir函数遍历指定目录并打印文件的详细信息,包括文件类型、权限、链接数、用户ID、组ID、大小和时间。同时,还介绍了创建孤儿和僵尸进程的基本概念和代码示例。
要求输入目录的路径后,能够打印出指定路径下所有文件的详细信息,类似ls -l
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <pwd.h>
#include <grp.h>
#include <string.h>
#include <dirent.h>
#include <errno.h>
#include <time.h>
char file_type(mode_t m);
char *file_permission(mode_t m,char *str);
char *file_uid(uid_t uid,char *str);
char *file_gid(gid_t gid,char *str);
void file_time(time_t time);
int main(int argc, const char *argv[])
{
	DIR *dp=opendir(argv[1]);
	if(dp==NULL)

	{
		perror("opendir");
		return -1;
	}
	char ch=0;
	char str[20]="";
	struct stat buf;
	char path_name[50]="";
	while(1)
	{
		struct dirent *pa=readdir(dp);
		if(pa==NULL)
		{
			if(errno==0)
			{
				printf("read over\n");
				break;
			}
			else
			{
				perror("readdir");
				return -1;
			}
		}
		if(*pa->d_name!='.')
		{
			//printf("%s\n",pa->d_name);
			strcpy(path_name,argv[1]);
			strcat(path_name,pa->d_name);
			if(stat(path_name,&buf)<0)
			{
				perror("stat");
				return -1;
			}
			//提取文件类型
			ch=file_type(buf.st_mode);
			putchar(ch);
			//提取文件权限
			file_permission(buf.st_mode,str);
			printf("%s ",str);
			//提取链接数
			printf("%2ld ",buf.st_nlink);
			//提取所属用户ID  uid_t st_uid
			file_uid(buf.st_uid,str);
			printf("%s ",str);
			//提取所属组用户ID gid_t st_gid
			file_gid(buf.st_gid,str);
			printf("%s ",str);
			//提取文件大小  off_t st_size
			printf("%7ld ",buf.st_size);
			//提取文件时间 st_atime
			file_time((time_t)buf.st_mtime);
			printf("%s\n",pa->d_name);
		}
	}
	closedir(dp);
	
	return 0;
}
char file_type(mode_t m)
{
	char ch;
	switch(m&S_IFMT)
	{
	case S_IFBLK:ch='b';break;
	case S_IFCHR:ch='c';break;
	case S_IFDIR:ch='d';break;
	case S_IFREG:ch='-';break;
	case S_IFLNK:ch='l';break;
	case S_IFSOCK:ch='s';break;
	case S_IFIFO:ch='p';break;
	}
	return ch;
}
char *file_permission(mode_t m,char *str)
{
	for(int i=0;i<9;i++)
	{
		if(m&(0400>>i))
		{
			switch(i%3)
			{
			case 0:str[i]='r';break;
			case 1:str[i]='w';break;
			default:str[i]='x';
			}
		}
		else
		{
			str[i]='-';
		}
	}
	return str;
}
char *file_uid(uid_t uid,char *str)
{
	struct passwd *pa=getpwuid(uid);
	if(pa==NULL)
	{
		perror("getpwuid");
		return NULL;
	}
	strcpy(str,pa->pw_name);
	return str;
}
char *file_gid(gid_t gid,char *str)
{
	struct group *pa=getgrgid(gid);
	if(pa==NULL)
	{
		perror("getgrgid");
		return NULL;
	}
	strcpy(str,pa->gr_name);
	return str;
}
void file_time(time_t time)
{
	struct tm *pa=localtime(&time);
	printf("%02d %02d %02d:%02d ",pa->tm_mon+1,pa->tm_mday,\
			pa->tm_hour,pa->tm_min);
}
创建一个孤儿进程,创建一个僵尸进程;
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <stdlib.h>
int main(int argc, const char *argv[])
{
	pid_t pid=fork();
	if(pid>0)
	{
		printf("father\n");
		printf("getppid=%d getpid=%d\n",getppid(),getpid());
		_exit(7);//孤儿进程
		while(1)
			sleep(1);
	}
	else if(pid==0)
	{
		printf("child\n");
		printf("getppid=%d getpid=%d\n",getppid(),getpid());
		//_exit(7);//僵尸进程
		while(1)
			sleep(1);
	}
	else
	{
		perror("fork");
		return -1;
	}
	return 0;
}

没传完wget --debug --no-check-certificate https://192.168.0.240/rtsp_thread.2022.11.1765247248.core Setting --check-certificate (checkcertificate) to 0 DEBUG output created by Wget 1.15 on linux-gnu. URI encoding = ‘UTF-8’ --2025-12-09 10:32:18-- https://192.168.0.240/rtsp_thread.2022.11.1765247248.core Connecting to 192.168.0.240:443... connected. Created socket 3. Releasing 0x0000000001435b40 (new refcount 0). Deleting unused 0x0000000001435b40. Initiating SSL handshake. Handshake successful; connected socket 3 to SSL handle 0x0000000001436330 certificate: subject: /C=US/ST=CA/O=TPRI/CN=192.168.0.240 issuer: /C=US/ST=CA/O=TPRI/CN=TPRI-intermediate-RSA-f53a44c8 WARNING: cannot verify 192.168.0.240's certificate, issued by ‘/C=US/ST=CA/O=TPRI/CN=TPRI-intermediate-RSA-f53a44c8’: Self-signed certificate encountered. ---request begin--- GET /rtsp_thread.2022.11.1765247248.core HTTP/1.1 User-Agent: Wget/1.15 (linux-gnu) Accept: */* Host: 192.168.0.240 Connection: Keep-Alive ---request end--- HTTP request sent, awaiting response... ---response begin--- HTTP/1.1 200 OK Connection: close Content-Type: application/json Cache-Control: no-cache Expires: 0 X-Frame-Options: SAMEORIGIN Transfer-Encoding: chunked ---response end--- 200 OK Registered socket 3 for persistent reuse. Length: unspecified [application/json] Saving to: ‘rtsp_thread.2022.11.1765247248.core’ [ <=> ] 803 --.-K/s in 0s 2025-12-09 10:32:18 (25.3 MB/s) - ‘rtsp_thread.2022.11.1765247248.core’ saved [803]
12-10
根据您的调试输出,文件下载已成功完成,但存在以下关键现象和潜在问题: --- ### **核心问题分析** 1. **文件大小异常**: - 目标文件 `rtsp_thread.2022.11.1765247248.core` 仅下载了 **803字节**(实际应为更大文件)。 - 服务器返回的 `Content-Type` 是 `application/json`,但文件名后缀为 `.core`(通常为二进制崩溃转储文件),表明服务端可能返回了错误内容。 2. **响应头可疑字段**: ```http HTTP/1.1 200 OK Content-Type: application/json # 与预期文件类型不符 Transfer-Encoding: chunked # 未明确返回文件总大小 ``` --- ### **解决方案** #### 步骤1:验证服务端实际文件 在 **A机器(192.168.0.240)** 检查文件是否存在且内容正确: ```bash ls -lh /path/to/rtsp_thread.2022.11.1765247248.core # 确认文件大小 file /path/to/rtsp_thread.2022.11.1765247248.core # 检查真实文件类型 ``` #### 步骤2:排除服务端配置问题 - **Web服务重定向规则**: 检查A机器的Web服务器(如Nginx/Apache)是否对 `.core` 文件做了特殊处理(如强制返回JSON错误页)。 ```nginx # Nginx示例:检查是否存在以下规则 location ~ \.core$ { return 403; # 或其他非文件下载逻辑 } ``` - **临时禁用HTTPS重定向**: 若使用Python HTTP服务,改用纯HTTP避免干扰: ```bash python3 -m http.server 8000 --bind 0.0.0.0 ``` #### 步骤3:强制下载原始文件(绕过服务端处理) 通过 `wget` 添加标头伪装浏览器请求: ```bash wget --no-check-certificate \ --header="Accept: application/octet-stream" \ https://192.168.0.240/rtsp_thread.2022.11.1765247248.core ``` #### 步骤4:使用替代工具(如curl) ```bash curl -k -o rtsp_thread.2022.11.1765247248.core \ https://192.168.0.240/rtsp_thread.2022.11.1765247248.core ``` --- ### **关键检查点** 1. **服务端日志**: 查看A机器的Web服务日志,确认请求是否被拦截或修改: ```bash tail -f /var/log/nginx/access.log ``` 2. **文件权限**: 确保A机器的文件可被Web服务器进程读取: ```bash chmod a+r /path/to/rtsp_thread.2022.11.1765247248.core ``` --- ### **若问题仍未解决** - **直接传输文件**(跳过Web服务): 在A机器启动临时TCP监听,B机器用 `nc` 直接下载: ```bash # A机器(192.168.0.240): nc -l -p 8000 < rtsp_thread.2022.11.1765247248.core # B机器(192.168.0.9): nc 192.168.0.240 8000 > rtsp_thread.2022.11.1765247248.core ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值