亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1709 | 回復: 8
打印 上一主題 下一主題

[內(nèi)核模塊] Trunk模式的數(shù)據(jù)包iph->version異常 [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2015-03-13 09:51 |只看該作者 |倒序瀏覽
最近基于網(wǎng)橋 + NatFilter分析Trunk模式發(fā)來的數(shù)據(jù)包.  發(fā)現(xiàn)其中 iph->version為0, 正常應(yīng)為iph->version:4

對于Trunk模式的數(shù)據(jù), 在代碼中是先移位4的, 請問各位有沒有遇到同類問題:

論壇徽章:
0
2 [報告]
發(fā)表于 2015-03-13 09:52 |只看該作者
                     這是移位代碼:
                          if(skb->protocol==htons(ETH_P_8021Q))
                {
                        iph=(struct iphdr *)((u8*)iph+4);                       
                }

論壇徽章:
20
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-08-17 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-16 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-18 06:20:00每日論壇發(fā)貼之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16賽季CBA聯(lián)賽之江蘇
日期:2017-06-26 11:05:5615-16賽季CBA聯(lián)賽之上海
日期:2017-07-21 18:12:5015-16賽季CBA聯(lián)賽之青島
日期:2017-09-04 17:32:0515-16賽季CBA聯(lián)賽之吉林
日期:2018-03-26 10:02:16程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-15 06:20:0015-16賽季CBA聯(lián)賽之江蘇
日期:2016-07-07 18:37:512015亞冠之薩濟拖拉機
日期:2015-08-17 12:21:08
3 [報告]
發(fā)表于 2015-03-13 11:36 |只看該作者
bridge在調(diào)inet_netfilter之前,應(yīng)該已經(jīng)把nh+4(指向iphdr)[@net/bridge/br_netfiler.c],所以在hook里面是不需要再次偏移的。

論壇徽章:
0
4 [報告]
發(fā)表于 2015-03-13 14:14 |只看該作者
在Trunk模式下, 實際收到的iph->version為0, 說明這個數(shù)據(jù)包還是有問題, 請問應(yīng)如何解析來自Trunk模式下的數(shù)據(jù)包?

論壇徽章:
20
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-08-17 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-16 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-18 06:20:00每日論壇發(fā)貼之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16賽季CBA聯(lián)賽之江蘇
日期:2017-06-26 11:05:5615-16賽季CBA聯(lián)賽之上海
日期:2017-07-21 18:12:5015-16賽季CBA聯(lián)賽之青島
日期:2017-09-04 17:32:0515-16賽季CBA聯(lián)賽之吉林
日期:2018-03-26 10:02:16程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-15 06:20:0015-16賽季CBA聯(lián)賽之江蘇
日期:2016-07-07 18:37:512015亞冠之薩濟拖拉機
日期:2015-08-17 12:21:08
5 [報告]
發(fā)表于 2015-03-13 15:08 |只看該作者
回復 4# tough_lion

建議先假設(shè)數(shù)據(jù)包是沒有問題的(正常的帶tag的ip報文),在你的抓包點里把從skb->head到skb->data+32這個區(qū)間的數(shù)據(jù)打印出來,
人為判斷mac頭在什么地方,vlan頭在什么地方,ip頭在什么地方,然后跟skb_network_header、skb->data比較,
這樣就能知道在你的抓包點,skb的各個字段是否需要偏移了。


   

論壇徽章:
0
6 [報告]
發(fā)表于 2015-03-13 18:14 |只看該作者
可以去看我帖子里的源碼

http://72891.cn/thread-4171778-1-1.html

論壇徽章:
0
7 [報告]
發(fā)表于 2015-03-13 20:53 |只看該作者
回復 6# jasonew


    你帖子里并沒有源碼, 方便再給我個鏈接嗎?

論壇徽章:
0
8 [報告]
發(fā)表于 2015-03-13 20:54 |只看該作者
回復 5# nswcfd


   感謝, 我先試試, 另外Trunk模式下, 應(yīng)該是公共標準, 即移動4位吧?

論壇徽章:
0
9 [報告]
發(fā)表于 2015-03-20 21:37 |只看該作者
本帖最后由 jasonew 于 2015-03-20 21:37 編輯

回復 7# tough_lion



二層數(shù)據(jù)包 如果帶VLAN TAG的話,那就是數(shù)據(jù)頭指針P + 18 得到IP頭指針的位置 struct iphdr *iph = (struct iphdr*)(pData + 1;,然后可以根據(jù)協(xié)議,比如IPPROTO_TCP == iph->protocol,那么 struct tcphdr *tcph = (struct tcphdr*)(iph + 1),UDP 一樣,換個結(jié)構(gòu)體就好

如果是正常的二層數(shù)據(jù)包,那么數(shù)據(jù)頭指針P + 14 得到IP頭指針的位置struct iphdr *iph = (struct iphdr*)(pData + 14);,其他都一樣
   
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP