亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dns.c

?? 一個開源的sip源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
    if (rr->type == PJ_DNS_TYPE_A) {
	pj_memcpy(&rr->rdata.a.ip_addr, p, 4);
	p += 4;

    } else if (rr->type == PJ_DNS_TYPE_CNAME ||
	       rr->type == PJ_DNS_TYPE_NS ||
	       rr->type == PJ_DNS_TYPE_PTR) 
    {

	/* Get the length of the target name */
	status = get_name_len(0, pkt, p, max, &name_part_len, &name_len);
	if (status != PJ_SUCCESS)
	    return status;

	/* Allocate memory for the name */
	rr->rdata.cname.name.ptr = (char*) pj_pool_alloc(pool, name_len);
	rr->rdata.cname.name.slen = 0;

	/* Get the name */
	status = get_name(0, pkt, p, max, &rr->rdata.cname.name);
	if (status != PJ_SUCCESS)
	    return status;

	p += name_part_len;

    } else if (rr->type == PJ_DNS_TYPE_SRV) {

	/* Priority */
	pj_memcpy(&rr->rdata.srv.prio, p, 2);
	rr->rdata.srv.prio = pj_ntohs(rr->rdata.srv.prio);
	p += 2;

	/* Weight */
	pj_memcpy(&rr->rdata.srv.weight, p, 2);
	rr->rdata.srv.weight = pj_ntohs(rr->rdata.srv.weight);
	p += 2;

	/* Port */
	pj_memcpy(&rr->rdata.srv.port, p, 2);
	rr->rdata.srv.port = pj_ntohs(rr->rdata.srv.port);
	p += 2;
	
	/* Get the length of the target name */
	status = get_name_len(0, pkt, p, max, &name_part_len, &name_len);
	if (status != PJ_SUCCESS)
	    return status;

	/* Allocate memory for the name */
	rr->rdata.srv.target.ptr = (char*) pj_pool_alloc(pool, name_len);
	rr->rdata.srv.target.slen = 0;

	/* Get the name */
	status = get_name(0, pkt, p, max, &rr->rdata.srv.target);
	if (status != PJ_SUCCESS)
	    return status;
	p += name_part_len;

    } else {
	/* Copy the raw data */
	rr->data = pj_pool_alloc(pool, rr->rdlength);
	pj_memcpy(rr->data, p, rr->rdlength);

	p += rr->rdlength;
    }

    *parsed_len = (int)(p - start);
    return PJ_SUCCESS;
}


/*
 * Parse raw DNS packet into DNS packet structure.
 */
PJ_DEF(pj_status_t) pj_dns_parse_packet( pj_pool_t *pool,
				  	 const void *packet,
					 unsigned size,
					 pj_dns_parsed_packet **p_res)
{
    pj_dns_parsed_packet *res;
    const pj_uint8_t *start, *end;
    pj_status_t status;
    unsigned i;

    /* Sanity checks */
    PJ_ASSERT_RETURN(pool && packet && size && p_res, PJ_EINVAL);

    /* Packet size must be at least as big as the header */
    if (size < sizeof(pj_dns_hdr))
	return PJLIB_UTIL_EDNSINSIZE;

    /* Create the structure */
    res = PJ_POOL_ZALLOC_T(pool, pj_dns_parsed_packet);

    /* Copy the DNS header, and convert endianness to host byte order */
    pj_memcpy(&res->hdr, packet, sizeof(pj_dns_hdr));
    res->hdr.id	      = pj_ntohs(res->hdr.id);
    res->hdr.flags    = pj_ntohs(res->hdr.flags);
    res->hdr.qdcount  = pj_ntohs(res->hdr.qdcount);
    res->hdr.anscount = pj_ntohs(res->hdr.anscount);
    res->hdr.nscount  = pj_ntohs(res->hdr.nscount);
    res->hdr.arcount  = pj_ntohs(res->hdr.arcount);

    /* Mark start and end of payload */
    start = ((const pj_uint8_t*)packet) + sizeof(pj_dns_hdr);
    end = ((const pj_uint8_t*)packet) + size;

    /* Parse query records (if any).
     */
    if (res->hdr.qdcount) {
	res->q = (pj_dns_parsed_query*)
		 pj_pool_zalloc(pool, res->hdr.qdcount *
				      sizeof(pj_dns_parsed_query));
	for (i=0; i<res->hdr.qdcount; ++i) {
	    int parsed_len = 0;
	    
	    status = parse_query(&res->q[i], pool, (const pj_uint8_t*)packet, 
	    			 start, end, &parsed_len);
	    if (status != PJ_SUCCESS)
		return status;

	    start += parsed_len;
	}
    }

    /* Parse answer, if any */
    if (res->hdr.anscount) {
	res->ans = (pj_dns_parsed_rr*)
		   pj_pool_zalloc(pool, res->hdr.anscount * 
					sizeof(pj_dns_parsed_rr));

	for (i=0; i<res->hdr.anscount; ++i) {
	    int parsed_len;

	    status = parse_rr(&res->ans[i], pool, (const pj_uint8_t*)packet, 
	    		      start, end, &parsed_len);
	    if (status != PJ_SUCCESS)
		return status;

	    start += parsed_len;
	}
    }

    /* Parse authoritative NS records, if any */
    if (res->hdr.nscount) {
	res->ns = (pj_dns_parsed_rr*)
		  pj_pool_zalloc(pool, res->hdr.nscount *
				       sizeof(pj_dns_parsed_rr));

	for (i=0; i<res->hdr.nscount; ++i) {
	    int parsed_len;

	    status = parse_rr(&res->ns[i], pool, (const pj_uint8_t*)packet, 
	    		      start, end, &parsed_len);
	    if (status != PJ_SUCCESS)
		return status;

	    start += parsed_len;
	}
    }

    /* Parse additional RR answer, if any */
    if (res->hdr.arcount) {
	res->arr = (pj_dns_parsed_rr*)
		   pj_pool_zalloc(pool, res->hdr.arcount *
					sizeof(pj_dns_parsed_rr));

	for (i=0; i<res->hdr.arcount; ++i) {
	    int parsed_len;

	    status = parse_rr(&res->arr[i], pool, (const pj_uint8_t*)packet, 
	    		      start, end, &parsed_len);
	    if (status != PJ_SUCCESS)
		return status;

	    start += parsed_len;
	}
    }

    /* Looks like everything is okay */
    *p_res = res;

    return PJ_SUCCESS;
}


/* Perform name compression scheme.
 * If a name is already in the nametable, when no need to duplicate
 * the string with the pool, but rather just use the pointer there.
 */
static void apply_name_table( unsigned *count,
			      pj_str_t nametable[],
		    	      const pj_str_t *src,
			      pj_pool_t *pool,
			      pj_str_t *dst)
{
    unsigned i;

    /* Scan strings in nametable */
    for (i=0; i<*count; ++i) {
	if (pj_stricmp(&nametable[i], src) == 0)
	    break;
    }

    /* If name is found in nametable, use the pointer in the nametable */
    if (i != *count) {
	dst->ptr = nametable[i].ptr;
	dst->slen = nametable[i].slen;
	return;
    }

    /* Otherwise duplicate the string, and insert new name in nametable */
    pj_strdup(pool, dst, src);

    if (*count < PJ_DNS_MAX_NAMES_IN_NAMETABLE) {
	nametable[*count].ptr = dst->ptr;
	nametable[*count].slen = dst->slen;

	++(*count);
    }
}

static void copy_query(pj_pool_t *pool, pj_dns_parsed_query *dst,
		       const pj_dns_parsed_query *src,
		       unsigned *nametable_count,
		       pj_str_t nametable[])
{
    pj_memcpy(dst, src, sizeof(*src));
    apply_name_table(nametable_count, nametable, &src->name, pool, &dst->name);
}


static void copy_rr(pj_pool_t *pool, pj_dns_parsed_rr *dst,
		    const pj_dns_parsed_rr *src,
		    unsigned *nametable_count,
		    pj_str_t nametable[])
{
    pj_memcpy(dst, src, sizeof(*src));
    apply_name_table(nametable_count, nametable, &src->name, pool, &dst->name);

    if (src->data) {
	dst->data = pj_pool_alloc(pool, src->rdlength);
	pj_memcpy(dst->data, src->data, src->rdlength);
    }

    if (src->type == PJ_DNS_TYPE_SRV) {
	apply_name_table(nametable_count, nametable, &src->rdata.srv.target, 
			 pool, &dst->rdata.srv.target);
    } else if (src->type == PJ_DNS_TYPE_A) {
	dst->rdata.a.ip_addr.s_addr =  src->rdata.a.ip_addr.s_addr;
    } else if (src->type == PJ_DNS_TYPE_CNAME) {
	pj_strdup(pool, &dst->rdata.cname.name, &src->rdata.cname.name);
    } else if (src->type == PJ_DNS_TYPE_NS) {
	pj_strdup(pool, &dst->rdata.ns.name, &src->rdata.ns.name);
    } else if (src->type == PJ_DNS_TYPE_PTR) {
	pj_strdup(pool, &dst->rdata.ptr.name, &src->rdata.ptr.name);
    }
}

/*
 * Duplicate DNS packet.
 */
PJ_DEF(void) pj_dns_packet_dup(pj_pool_t *pool,
			       const pj_dns_parsed_packet*p,
			       unsigned options,
			       pj_dns_parsed_packet **p_dst)
{
    pj_dns_parsed_packet *dst;
    unsigned nametable_count = 0;
#if PJ_DNS_MAX_NAMES_IN_NAMETABLE
    pj_str_t nametable[PJ_DNS_MAX_NAMES_IN_NAMETABLE];
#else
    pj_str_t *nametable = NULL;
#endif
    unsigned i;

    PJ_ASSERT_ON_FAIL(pool && p && p_dst, return);

    /* Create packet and copy header */
    *p_dst = dst = PJ_POOL_ZALLOC_T(pool, pj_dns_parsed_packet);
    pj_memcpy(&dst->hdr, &p->hdr, sizeof(p->hdr));

    /* Initialize section counts in the target packet to zero.
     * If memory allocation fails during copying process, the target packet
     * should have a correct section counts.
     */
    dst->hdr.qdcount = 0;
    dst->hdr.anscount = 0;
    dst->hdr.nscount = 0;
    dst->hdr.arcount = 0;
	

    /* Copy query section */
    if (p->hdr.qdcount && (options & PJ_DNS_NO_QD)==0) {
	dst->q = (pj_dns_parsed_query*)
		 pj_pool_alloc(pool, p->hdr.qdcount * 
				     sizeof(pj_dns_parsed_query));
	for (i=0; i<p->hdr.qdcount; ++i) {
	    copy_query(pool, &dst->q[i], &p->q[i], 
		       &nametable_count, nametable);
	    ++dst->hdr.qdcount;
	}
    }

    /* Copy answer section */
    if (p->hdr.anscount && (options & PJ_DNS_NO_ANS)==0) {
	dst->ans = (pj_dns_parsed_rr*)
		   pj_pool_alloc(pool, p->hdr.anscount * 
				       sizeof(pj_dns_parsed_rr));
	for (i=0; i<p->hdr.anscount; ++i) {
	    copy_rr(pool, &dst->ans[i], &p->ans[i],
		    &nametable_count, nametable);
	    ++dst->hdr.anscount;
	}
    }

    /* Copy NS section */
    if (p->hdr.nscount && (options & PJ_DNS_NO_NS)==0) {
	dst->ns = (pj_dns_parsed_rr*)
		  pj_pool_alloc(pool, p->hdr.nscount * 
				      sizeof(pj_dns_parsed_rr));
	for (i=0; i<p->hdr.nscount; ++i) {
	    copy_rr(pool, &dst->ns[i], &p->ns[i],
		    &nametable_count, nametable);
	    ++dst->hdr.nscount;
	}
    }

    /* Copy additional info section */
    if (p->hdr.arcount && (options & PJ_DNS_NO_AR)==0) {
	dst->arr = (pj_dns_parsed_rr*)
		   pj_pool_alloc(pool, p->hdr.arcount * 
				       sizeof(pj_dns_parsed_rr));
	for (i=0; i<p->hdr.arcount; ++i) {
	    copy_rr(pool, &dst->arr[i], &p->arr[i],
		    &nametable_count, nametable);
	    ++dst->hdr.arcount;
	}
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美视频在线观看| 天使萌一区二区三区免费观看| 国产欧美精品一区二区三区四区| 亚洲美女免费视频| 久久99国产精品久久99果冻传媒| 99久精品国产| 久久九九全国免费| 视频一区中文字幕| 欧美亚洲综合另类| 国产精品久久久久永久免费观看| 蜜臀精品久久久久久蜜臀| 97成人超碰视| 欧美国产日本视频| 久久超级碰视频| 制服丝袜亚洲网站| 亚洲一区二区精品久久av| av在线综合网| 国产欧美一区二区精品性色超碰| 日韩一区欧美二区| 欧美日韩精品专区| 亚洲一区二区三区免费视频| 成人av动漫在线| 国产精品五月天| 国产传媒欧美日韩成人| 日韩精品中文字幕一区| 五月天中文字幕一区二区| 91农村精品一区二区在线| 国产清纯白嫩初高生在线观看91| 另类小说综合欧美亚洲| 日韩精品在线一区二区| 免费观看日韩电影| 91精品国产综合久久精品麻豆| 亚洲啪啪综合av一区二区三区| 丰满少妇在线播放bd日韩电影| 久久婷婷综合激情| 国产99精品在线观看| 久久久久国色av免费看影院| 久草在线在线精品观看| 欧美精品一区二区久久久| 理论片日本一区| 精品少妇一区二区三区在线播放| 久久成人免费网| 精品噜噜噜噜久久久久久久久试看| 毛片一区二区三区| 久久这里只有精品6| 国产精品123| 国产精品网站导航| 一本大道久久a久久综合| 亚洲三级久久久| 欧美日韩国产另类不卡| 日日夜夜免费精品视频| 日韩欧美色电影| 国产成人在线免费观看| 国产精品美女久久久久av爽李琼| 99久久久免费精品国产一区二区| 亚洲人成网站影音先锋播放| 欧美亚洲愉拍一区二区| 蜜桃视频一区二区三区在线观看| 精品欧美一区二区在线观看| 国产原创一区二区三区| 中文字幕一区二区三区蜜月| 色域天天综合网| 免费观看在线综合| 国产精品久久久久久久蜜臀 | 91小视频免费看| 一区二区三区四区五区视频在线观看| 欧美色手机在线观看| 久久精品国内一区二区三区| 国产免费成人在线视频| 日本韩国欧美一区二区三区| 日本欧美在线观看| 中文字幕制服丝袜成人av| 91黄色小视频| 国产激情一区二区三区| 亚洲小少妇裸体bbw| 久久综合资源网| 欧美四级电影网| 国产精品白丝jk白祙喷水网站| 亚洲精选免费视频| 久久婷婷久久一区二区三区| 91传媒视频在线播放| 国产露脸91国语对白| 亚洲成人tv网| 最新日韩在线视频| 精品理论电影在线观看| 欧美视频在线一区| 成人精品视频一区二区三区| 午夜精品aaa| 亚洲色图.com| 久久久久久久久久久久电影 | 26uuu另类欧美| 精品视频在线免费看| 成人激情视频网站| 国产一区二区三区高清播放| 亚洲在线视频免费观看| 国产精品久久久久久久久动漫 | 国产九色精品成人porny| 亚洲成av人片在www色猫咪| 国产精品卡一卡二卡三| 久久久国产精品麻豆| 欧美成人video| 欧美精品777| 欧美在线观看一区| 91免费观看视频| av不卡在线播放| 成人av网站在线| 国产福利一区在线观看| 精品在线免费视频| 麻豆精品久久久| 美女视频黄 久久| 日韩精品电影一区亚洲| 亚洲sss视频在线视频| 亚洲综合丁香婷婷六月香| 最好看的中文字幕久久| 国产精品久久久久久一区二区三区| 久久久久久久av麻豆果冻| 久久精品亚洲乱码伦伦中文| 欧美一卡二卡在线| 日韩亚洲欧美高清| 日韩三区在线观看| www国产精品av| 久久精品欧美一区二区三区不卡| 欧美精品一区二区三区很污很色的 | 国产精品进线69影院| 久久精品一区四区| 欧美国产禁国产网站cc| 日本一区二区三级电影在线观看 | 国产一区二区三区综合| 国内精品免费**视频| 国产精品一级在线| 成人精品视频一区| 91看片淫黄大片一级在线观看| 色婷婷亚洲精品| 欧美精品vⅰdeose4hd| 精品国产乱码久久| 国产精品全国免费观看高清 | 激情文学综合插| 成人免费黄色在线| 欧美系列一区二区| 日韩亚洲欧美一区二区三区| 久久精品视频网| 国产精品毛片高清在线完整版 | 亚洲国产高清在线观看视频| 综合久久给合久久狠狠狠97色 | 91电影在线观看| 精品久久久久久久久久久久久久久久久 | 自拍偷拍欧美精品| 香港成人在线视频| 国产一区二区三区美女| 成年人国产精品| 欧美福利电影网| 国产人成亚洲第一网站在线播放| 亚洲蜜臀av乱码久久精品| 日韩在线一区二区三区| 国产91精品露脸国语对白| 色94色欧美sute亚洲线路一久 | 精品系列免费在线观看| av一区二区三区黑人| 欧美日本在线一区| 国产欧美精品日韩区二区麻豆天美| 国产精品国产精品国产专区不蜜 | 一区二区视频在线看| 日本最新不卡在线| 91丨porny丨首页| 欧美大尺度电影在线| 国产精品久久久久久久第一福利| 日韩成人免费电影| 91美女视频网站| 久久网这里都是精品| 日韩成人免费在线| 色狠狠一区二区| 欧美国产1区2区| 久久99精品国产.久久久久久| 色一情一乱一乱一91av| 国产视频一区二区在线观看| 偷拍日韩校园综合在线| 99re热视频这里只精品| 国产欧美日韩精品a在线观看| 日韩高清不卡一区二区三区| 96av麻豆蜜桃一区二区| 国产亚洲精品bt天堂精选| 亚洲成人av资源| 91黄色免费观看| 国产精品日产欧美久久久久| 国产麻豆一精品一av一免费| 欧美二区三区91| 亚洲午夜激情网页| 欧美亚洲精品一区| 一区二区三区在线视频观看 | 久久精品99国产精品| 欧美最新大片在线看| 一区精品在线播放| 粉嫩av一区二区三区粉嫩| 精品国产一区二区三区久久久蜜月| 亚洲成人你懂的| 欧美狂野另类xxxxoooo| 亚洲精品久久嫩草网站秘色| 成人精品在线视频观看| 中日韩免费视频中文字幕| 成人手机电影网|