我正处于为c类编写代理服务器的早期阶段,在调试时,我的程序给了我一个简单的输出,简单的两行
直接://
直接://
这是什么意思?我以前从来没有这样过。当我不提供执行该程序所需的3个参数时,程序甚至输出这个。#include <pthread.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <time.h>
#include <string.h>
int main (int argc, char *argv[]){
if(argc!=3){
printf("Usage: proxy <IP address> <port no.>");
exit(1);
}
int csock, ssock, clen, slen;
int csocka, ssocka;
int rc, fd, ttl;
char method[40];
char uri[80];
char prot[40];
char cbuf[100];
time_t logtime;
char * pch;
struct sockaddr_in caddr;
struct sockaddr_in caddr2;
struct sockaddr_in saddr;
struct sockaddr_in saddr2;
csock = socket(AF_INET, SOCK_STREAM, 0);
caddr.sin_family = AF_INET;
caddr.sin_addr.s_addr = inet_addr(argv[1]);
caddr.sin_port = htons(atoi(argv[2]));
clen = sizeof(caddr);
rc = bind(csock, (struct sockaddr *) &caddr, clen);
if(rc < 0){
printf("bind failed");
exit(1);
}
rc = listen(csock, 5);
if(rc < 0){
printf("listen failed");
exit(1);
}
printf("hey");
csocka = accept(csock, (struct sockaddr *) &caddr2, &clen);
if(csocka < 0){
printf("accept failed");
exit(1);
}
while(1){
read(csocka,&cbuf,sizeof(cbuf));
time(&logtime); //time of req.
if(cbuf==NULL){
cerror("400 Bad Request: empty request");
write(csocka, &errbuf, sizeof(errbuf));
continue;
}
ttl = strlen(cbuf);
while(cbuf[ttl-1] == '\n' || cbuf[ttl-1] == '\r'){
cbuf[ttl--] = '\0';
}
if(sscanf(cbuf,"%[^ ] %[^ ] %[^ ]", method, uri, prot) != 3){
cerror("400 Bad Request: Unexpected number of arguments");
write(csocka, &errbuf, sizeof(errbuf));
continue;
}
if(method!="GET" || method !="HEAD"){
cerror("405 Method Not Allowed: GET/HEAD only");
write(csocka, &errbuf, sizeof(errbuf));
continue;
}
if(uri == (char*) 0){
cerror("400 Bad Request: empty url");
write(csocka, &errbuf, sizeof(errbuf));
continue;
}
printf("%s \n", cbuf);
}
close(csocka);
}
答案 0 :(得分:1)
最可能的原因是你没有运行你的程序,而是一些系统程序。
如果您使用的是Linux计算机,请键入:
which <program name>
找出您实际运行的可执行文件。
输入:
./<program name>
运行您的程序(假设您与可执行文件位于同一目录中)。
答案 1 :(得分:0)
为什么忽略read
的返回值?是什么让您认为read
为空终止cbuf
?如果read
不是空终止cbuf
,那么是什么让您认为将buf传递给strlen
是安全的?您通过将不是字符串的内容传递给strlen来调用未定义的行为......后面的行为可能看起来很奇怪或不一致,但这是未定义行为的本质。
int len = read(csocka,&cbuf,sizeof(cbuf));
if (len <= 0) {
/* something went wrong in read().
* report an error and stop here... */
break;
}
/* Once error checking is performed, len is the number of bytes recieved by read. */
考虑上面的代码。如果您正确检查错误,是否需要行ttl=strlen(cbuf);
?
printf("%s \n", cbuf);
错误,因为cbuf不是字符串。考虑fwrite(cbuf, len, stdout); putchar('\n');
或printf("%.*s\n", len, stdout);
。
write(csocka, &errbuf, sizeof(errbuf));
看起来也错了,但我会把它留在你手中。如果您需要我们为您解决这些类型的错误,那么您的学习方法效果不佳。你正在读哪本书?