int SendBYE(char *num, char *tag1, char *tag2) { printf("\n\t=================================================================================\n\t"); printf("\n\t===== Enter Method of Send ACK To Camera =====\n\t"); printf("\n\t=================================================================================\n\t"); int sockbye = socket(AF_INET, SOCK_DGRAM, 0); if (sockbye < 0) { printf("socket built failt!"); return -1; } struct sockaddr_in camera_bye; camera_bye.sin_family = AF_INET;//地址族 camera_bye.sin_port = htons(5060);//端口 camera_bye.sin_addr.s_addr = inet_addr("192.168.1.250"); //unsigned int ack_len = sizeof(camera_ack); bind(sockbye, (sockaddr*)&camera_bye, sizeof(camera_bye)); char sendBuf[2500]; memset(sendBuf, 0, 2500); int zishu; zishu = snprintf(sendBuf, sizeof(sendBuf), "BYE sip:%s@192.168.1.250:5060 SIP/2.0\r\n" "Via: SIP/2.0/UDP 192.168.1.200:5080;branch=z9hG4bK776asdhds;rport\r\n" "Max-Forwards: 70\r\n" "From: <sip:170010000000000001@192.168.1.200:5080>;tag=1234567890\r\n" "To: <sip:%s@192.168.1.250:5060>;tag=12345678\r\n" "Call-ID: %s\r\n" "CSeq: 21 BYE\r\n" "Content-Length: 0\r\n" "Contact: <sip:170010000000000001@192.168.1.200:5080>\r\n" "\r\n", Host_ID, Host_ID, CALLID_NAME ); printf("zishu=%d\n", zishu); printf("sendBuf=%s\n", sendBuf); int bytes = sendto(sockbye, sendBuf, sizeof(sendBuf), 0, (sockaddr*)&camera_bye, sizeof(camera_bye)); printf("bytes=%d\n", bytes); // 关闭socket close(sockbye); return 0; }写了一个向网络摄像机发送BYE的函数,发送过去后,网络摄像机回复481 Call leg/Transaction does not exist,这是什么问题
时间: 2023-09-01 15:06:50 浏览: 144
这个问题可能是由于网络摄像机认为当前的会话不存在,因此无法处理BYE消息。可能的原因包括:
1. 在发送BYE消息之前,没有正确地完成之前的会话,或者没有正确地发送ACK消息。
2. 发送的BYE消息的Call-ID与之前的会话不匹配。
3. 网络摄像机在会话过程中出现了错误或异常,导致无法正确处理BYE消息。
你可以根据这些可能的原因进行排查和调试,以找出问题的具体原因。
相关问题
unsigned int getHeader(char *q, dns_header *header){ header->id = ntohs(*(uint16_t*) (q)); header->tag = ntohs(*(uint16_t*) (q+2)); header->queryNum = ntohs(*(uint16_t*) (q+4)); //printf("queryName: %d\n", header->id); header->answerNum = ntohs(*(uint16_t*) (q+6)); header->authorNum = ntohs(*(uint16_t*) (q+8)); header->addNum = ntohs(*(uint16_t*) (q+10)); return sizeof(dns_header); }帮我解释这段代码
这段代码的作用是从一个DNS查询消息中提取出消息头部分的字段,并将这些字段存入一个dns_header结构中。函数的参数是一个指向字符数组的指针q,指向要被解析的DNS消息的起始位置,以及一个指向dns_header结构的指针header,用于存储解析结果。函数的返回值是一个unsigned int类型的值,表示消息头部分的长度。
函数中首先使用ntohs()函数将消息中的16位字节序转换为主机字节序,然后使用指针偏移的方式,将转换后的结果存入dns_header结构中对应的字段中。其中,id字段存储消息的标识符,tag字段存储消息的标志,queryNum字段存储查询的数量,answerNum字段存储回答的数量,authorNum字段存储授权回答的数量,addNum字段存储附加回答的数量。
最后,函数返回dns_header结构的大小,以便后续进行解析。需要注意的是,函数中没有对指针q指向的内存进行边界检查,如果消息格式不正确或者消息长度不足可能会导致程序出错。
int DNS_root_parse_response(char *response, char *ip) { if (response == NULL) { printf("no root response"); return -1; } char *ptr = response + 2; struct DNS_Header header = {0}; header.id = ntohs(*(unsigned short *)ptr); ptr += 2; header.tag = ntohs(*(unsigned short *)ptr); ptr += 2; header.queryNum = ntohs(*(unsigned short *)ptr); ptr += 2; header.answerNum = ntohs(*(unsigned short *)ptr); ptr += 2; header.authorNum = ntohs(*(unsigned short *)ptr); ptr += 2; header.addNum = ntohs(*(unsigned short *)ptr); ptr += 2; struct DNS_Query *query = calloc(header.queryNum, sizeof(struct DNS_Query)); for (int i = 0; i < header.queryNum; i++) { int len_q = 0; dns_parse_name(response + 2, ptr, &query[i].name, &len_q); ptr += (len_q + 2); query[i].qtype = htons(*(unsigned short *)ptr); ptr += 2; query[i].qclass = htons(*(unsigned short *)ptr); ptr += 2; } char cname[NAME_LEN], aname[NAME_LEN], net_ip[NET_IP_LEN]; struct DNS_RR *answer = calloc(header.answerNum + header.addNum + header.authorNum, sizeof(struct DNS_RR)); int len_r = 0; for (int i = 0; i < header.answerNum + header.addNum + header.authorNum; i++) { len_r = 0; dns_parse_name(response + 2, ptr, &answer[i].name, &len_r); ptr += (len_r + 2); answer[i].type = htons(*(unsigned short *)ptr); ptr += 2; answer[i].rclass = htons(*(unsigned short *)ptr); ptr += 2; answer[i].ttl = htons(*(unsigned int *)ptr); ptr += 4; answer[i].data_len = htons(*(unsigned short *)ptr); ptr += 2; len_r = 0; memcpy(net_ip, ptr, 4); dns_parse_name(response + 2, ptr, &answer[i].rdata, &len_r); ptr += answer[i].data_len; inet_ntop(AF_INET, net_ip, ip, sizeof(struct sockaddr)); printf("%s has an address of %s\n", &answer[i].name, ip); } }
这是一个 C 语言函数,用于解析 DNS 查询的响应报文。它的参数包括指向响应报文和 IP 地址的指针。函数首先检查响应报文是否为 NULL,如果是,则返回 -1。接下来,函数从响应报文中解析出 DNS 报文头部,并存储在结构体 header 中。然后,函数使用循环解析出 DNS 查询结构体数组 query。在循环中,函数首先解析出查询名字,并更新偏移量。然后,函数解析出查询类型和查询类,并更新偏移量。接着,函数使用 calloc 分配空间,解析 DNS 响应记录,并存储在结构体 answer 中。在循环中,函数首先解析出记录名字,并更新偏移量。然后,函数解析出记录类型、记录类、TTL 和数据长度,并更新偏移量。接着,函数解析出记录数据,并更新偏移量。最后,函数将 IP 地址转换为字符串格式,并打印出来。注意,此函数没有返回值,最后一行应该加上 return 0;。
阅读全文