- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试了解 HTTP 代理服务器程序。我写了一个简单的基于 C 的套接字,它在收到消息时发送响应。请在下面找到程序。
#include <stdio.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <string.h>
#include <sys/types.h>
int main(){
int recvSocketFd = 0;
struct sockaddr_in serv_input_addr;
char inputBuff[1024];
memset(&serv_input_addr,'0',sizeof(serv_input_addr));
memset(&inputBuff, '0', sizeof(inputBuff));
recvSocketFd = socket(AF_INET,SOCK_STREAM,0);
if(recvSocketFd <= 0){
printf("\nError occurred while creating a socket\n");
return -1;
}
serv_input_addr.sin_family = AF_INET;
serv_input_addr.sin_addr.s_addr = htonl(INADDR_ANY);
serv_input_addr.sin_port = htons(8080);
bind(recvSocketFd, (struct sockaddr*)&serv_input_addr, sizeof(serv_input_addr));
listen(recvSocketFd,5);
int connFd = 0;
int n = 0;
int client_length = sizeof(serv_input_addr);
while(1){
connFd = accept(recvSocketFd, (struct sockaddr*)&serv_input_addr, &client_length);
if(connFd <0){
printf("\nError in accepting messages from socket\n");
return -1;
}
n = read(connFd,inputBuff,1023);
if(n>0){
printf("\nMessage : %s\n",inputBuff);
}
write(connFd,"Message received",15);
close(connFd);
}
}
这个正在运行的程序正在正确响应以下请求 http://<localhost>:8080/test
.
我试图将其设置为代理。所以我尝试将其设置为 Firefox 中的手动代理 http://<localhost>
端口为 8080。
但是请求没有命中这个套接字。
如果有人能帮助我理解这一点,那将非常有帮助。
注意:这不是作业程序,我也不是学生。我只是想学习东西。此声明适用于我们可耻的可耻受访者。
最佳答案
重新编辑:
请注意检查 bind() 是否成功的重要性。有多种情况;其中一个可能是套接字处于 TIME_WAIT 状态。如果没有实际验证 bind() 并在失败时中止,则程序可能看似 正常运行。 listen() 可以顺利通过。尽管在客户端,Firefox 很可能会报告拒绝连接,但这不是给定的。
在您的问题中,您声明您使用了 http://<localhost>
用于代理设置。如果这是文字,它将失败:您不能在代理设置中包含方案名称。
请注意,Firefox 不会验证主机名。例如。 a4a6®←@ł´ªĸµª5d4a"#¤&%=)(=/)=
毫无警告地飞过。
如果包含方案,http://
,Firefox 将无法连接,并且会出现未找到服务器。
原始答案:-)
即使对删除的部分进行评论,我也会将其保留在这里,因为其他人可能会发现它很有用。 (而且我花了一些时间来写它。)
这里有一些问题。我会一一带走。
首先解决这个问题,然后根据需要报告。
read() , write()和 close()在
client_length
未签名 int。您可以使用 unsigned int,但最好使用手册中定义的 socklen_t。
read() 返回 ssize_t,而不是 int。也改变这个。
没有错误检查它应该在的地方。规则 #1:始终检查错误!遇到麻烦而不验证请求是……一个很大的禁忌。
bind() , listen()和 close()返回整数。 0 是成功,-1 是错误。设置错误 errno。
手册对此非常清晰易读。阅读您使用的每个功能。
包含
以最简单的方式。中止并且没有尝试营救我们得到:
int res;
...
res = bind(recvSocketFd, (struct sockaddr*)&serv_input_addr, sizeof(serv_input_addr));
if (res != 0) {
perror("bind");
return errno;
}
res = listen(recvSocketFd, 5);
if (res != 0) {
perror("listen");
return errno;
}
...
res = close(connFd);
if (res != 0) {
perror("close");
return errno;
}
write()返回 ssize_t,成功时返回写入的字节数,否则返回 -1 并适当设置 errno。
res_wr = write(connFd, ...);
if (res == -1) {
perror("write");
return errno;
}
/* Else check if entire buffer was written, if not, act accordingly. */
错误的写语句:
write(connFd, "Message received", 15);
首先:“收到的消息” 是 17 个字节,包括终止 null。如果你想把它写到连接上,使用类似的东西:
const char msg_received[] = "Message received";
...
write(connFd, msg_received, sizeof(msg_received));
第二:这是您传递给客户端的内容,在您的例子中是 Firefox。换句话说,Firefox 会获取字符:
{ 'M', 'e', 's', 's', 'a', 'g', 'e', ' ', 'r', 'e', 'c', 'e', 'i', 'v', 'e' }
第三:当您在第一次读/写后立即执行 close() 时。 Firefox 很可能会回复连接已重置。通常你会写你的inputBuff,而不是像这样的一些状态消息。
stderr
另一方面:虽然写信给 stdout
是足够公平在本示例中,将错误和调试数据写入stderr
是一个好习惯。 .保持它作为一种习惯。示例:
sz_buf = read(connFd, inputBuff, BUF_SIZE - 1)
inputBuff[sz_buf] = 0x00;
fprintf(stderr,
"\n====================== Message (%4d) ================\n"
"%s\n"
"--------------------------------------------------------\n"
,
sz_buf, inputBuff
);
关于C http代理服务器套接字 - 没有命中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22284033/
关于 APC 操作码缓存,什么是“命中与未命中”?我已经安装了 APC 并且它运行良好,但我有“一些”失误,我想知道这是否“不好”。此外,我正在运行 Openx,因此,我很快就会填满“缓存完整计数”。
我试过这个: def test_send_confirm_hit(monkeypatch): hit = False def called(): global hit
是否可以将找到的单词插入到替换中? $(function() { content = 'hallo mein name ist peter und ich komme aus berlin.
我有一个允许用户将文件上传到文件夹的网站。首先,我检查文件是否存在,如果存在,然后检查复选框的值以确定用户是否要覆盖现有文件。如果点击上传并且未选中该框,我会执行一个带有消息和后退按钮的 die()
我有多个不同的进程通过 IPC 进行通信,当使用 gdb 调试单个进程时,每当遇到断点时,我都会尝试向其他进程发送消息。有没有一种方法可以自动在遇到断点时自动调用一个函数/一段代码(NotifyAll
目前,通过管道传输到 jq 的 cat 命令帮助我解析工作目录中的多个 JSON 文件,并根据正则表达式模式匹配文件中所有可用的电子邮件 ID。但是,我很想识别正则表达式模式被命中/匹配的文件名 ca
我们希望将 podname 解析为 IP,以在 akka 集群中配置种子节点。这是通过在 Kubernetes 中使用 headless (headless)服务和有状态集的概念来实现的。但是,如何在
Maven 项目具有以下文件夹结构: src/main/java src/main/resources src/test/java src/test/resources 如果我们导航到 Maven 项
我只使用 c 几个星期,所以很可能会出现我忽略的明显错误。我看过其他线程,但我不明白我正在读的很多内容。该程序假设有一个无限大的牌组。 已知问题: clearBuffer 当前未使用,我正在尝试不同的
我已将我的 AdMob 代码实现到我的 XML 文件中,如下所示: 在我的 Activity 的 onCreate 方法中: // load ads
我的作业是通过示例程序确定给定跟踪文件的缓存读/写/未命中/命中次数。 举例来说,这是示例跟踪输出的前 10 行。 0x37c852: W 0xbfd4b18c 0x37cfe0: W 0xbfd
https://plnkr.co/edit/2h6fV5yTjeUqLP3SvbvO?p=preview 预期 登录后应用程序重定向到 $state container,其中包含 dashboard
ElasticSearch 独立于 from 和 size 参数,基于查询的所有命中构建聚合结果。在大多数情况下,这是我们想要的,但我有一个特殊情况,我需要将聚合限制为前 N 个命中。 limits
我使用 Intel PCM 进行细粒度的 CPU 测量。在我的代码中,我试图测量缓存效率。 基本上,我首先将一个小数组放入 L1 缓存(通过多次遍历),然后启动计时器,再遍历数组一次(希望使用缓存),
我在为 javascript 滑动元素定义点击区域时遇到问题。 参见示例: http://www.warface.co.uk/clients/warface.co.uk/ 请滑过右侧的灰色框以显示按钮
我正在尝试在 foldersystem 中使用 os.walk() 找到几个 'my_file.bat',如果文件名匹配它应该用 subprocess.call() 或 .run() 调用。问题是 o
我有一个端点,我可以在其中请求我使用 Siesta 查询的多条数据(例如 https://example.com/things?ids=1,2,3) .如果我只缓存了一些 things ,我试图弄清楚
这是我的代码: public static function test(){ try{ $apiContext = ApiContext::create(
我使用 PHP 在需要时传递登录表单,代码如下: $htmlForm = ''.''; switch(LOGIN_METHOD) { case 'both': $htmlFor
我正在使用 nginx-lua带有 redis 的模块提供 ember-app 的静态文件. index文件内容存储在redis作为 value由 nginx 正确提供服务当(根)domain/IP被
我是一名优秀的程序员,十分优秀!