当前位置:  技术问答>linux和unix

请教关于netfilter中UDP包的问题!!!

    来源: 互联网  发布时间:2016-08-29

    本文导语:  最近在做一项目,主要是在kernel中按照我们的设定的特征捕获一些UDP包,并且将其存储下来,当到一定数量之后, 对这些包的数据部分进行运算,再构建一个新的包,将运算的结果作为包的数据发送出去。   这个项...

最近在做一项目,主要是在kernel中按照我们的设定的特征捕获一些UDP包,并且将其存储下来,当到一定数量之后,
对这些包的数据部分进行运算,再构建一个新的包,将运算的结果作为包的数据发送出去。
  这个项目基于一个运行了linux kernel的路由器,所以接收了包还要按照路由表将其转发出去。

我的做法:
  在NF_IP_PRE_ROUTING 处定义了钩子抓包,如果遇到符合设定规则的UDP包,我会将其UDP数据部分存储到
     我指定的地方,对于原来的包,我return NF_DROP;另外对于我还会存储这些UDP包中一个包的 IP包头、UDP包头,
在构建新的包时,需要用到这两包头信息;

我能做到是:
   我构建新包使用了nc_alloc_skb,此报文的ip包头、UDP包头、UDP数据我都能利用以前存储数据的复制进去。

现在问题主要有:
   1、我想把新建立的包在NF_IP_PRE_ROUTING点建立好之后,使其能按照一般的包正常的流程走下去(就像对包进行return NF_ACCEPT
后包继续走的流程一样),包括经过路由转发等,要实现这样有什么样的方法? 
   2、如果是要使用dev_queue_xmit将新建立的包发送出去,是不是包就会直接被发送出去了而不会经过路由选择?此外还必须要填充新建立
的包的mac头,而mac头的目的IP需要查找路由表才能知道。
   
   请各位朋友指导一下,小弟不胜感激。

|
1. 既然还是走原流程,为什么不在NF_IP_PRE_ROUTING处截取,然后直接修改报文数据sk_buffer呢。
2. dev_queue_xmit将报文发给网络核心接口层,在这里完成mac层打包,然后就发给最终的网络驱动。

至于楼上说的sys_socket那是4层的事情,跟netfilter不搭边。

部分笔记可以看看这里
http://blog.sina.com.cn/s/blog_62bbc49c0100fs0n.html

    
 
 

您可能感兴趣的文章:

  • 请教前辈们关于netfilter/iptables的问题
  • 请教!netfilter内核模块编程问题
  • 请教:2.6编译netfilter后运行死机
  • 请教本地硬盘安装问题请教本地硬盘安装问题
  • 请教,请教,这个问题是为什么????
  • ■请教■请教redhat最基本的问题!
  • 请教一个 shell 问题,我用下面这个 shell 语句总是失败,请教
  • 高分请教,各位大侠,请教一个问题,理论高手请进??谢谢
  • 请教象我这样的硬盘应如何安装Linux,我昨天试装了,但有问题。(老问题了,也看了前面的帖子,但还是来请教,请多指教)
  • 请教一个函数入口处的汇编问题(压栈问题)
  • 请教!出现这个提示是什么原因..是模块版本问题,还是其他问题..http://220.114.102.28/xitong/ProductShow.asp?ArticleID=82
  • 请教两个小问题:一个cgywin下使用vi的问题,另一个socket的问题
  • 请教一个opengl的问题
  • 请教两个redhat9问题
  • 请教kdevelop的问题
  • 送上100分问题请教,同时学习一下进程通讯问题,望各位不吝赐教
  • 请教linux 下的adsl拨号问题.
  • 请教unix常用命令命令问题
  • 请教,帖子回复的显示问题
  • 请教关于sendto问题
  • 请教linux共享上网的问题!!!在线等,问题解决马上结贴
  • 有在用AXIS的朋友吗?请教一个问题
  • 高分请教,n简单的问题急急!!!
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请教Linux下pgadmin3-1.0.2的编译和安装!!高分请教!
  • 各位大虾,请教装了REDHAT9操作系统后,启动时无法引导到LINUX,请教该如何解决啊
  • 请教,请教,,,一定要看!!一定要看!!
  • 请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • :请教高手,小弟打印width=1500,height=600(A3纸)的Applet,在预览中是该区域是黑的,打印出来也是黑的,请教高手解决一下
  • 请教这种循环的执行过程
  • 请教如何在指定目录下查找包含指定文字的文件
  • 请教局域网中如何通过ip地址得到主机名
  • 请教,如何用虚拟订机安装liux
  • 【请教】LINUX 下SNMP的MIB开发
  • 请教两个shell
  • 请教高手:如何用gnome/gtk编写托盘程序
  • 菜鸟请教Linux
  • 请教semop()函数的用法、含义
  • 请教个,关于C编译器参数CFLAGS的问题(真诚请教,分不够了全部送出)
  • 请问如何在Redhat7.1下安装Ftp服务,如何开启Ftp帐号????请教!!!急急急急急急
  • Think in java 问题。(请教)
  • 请教下我的eth0为什么设置后重启会失败?
  • 请教:$PWD 这个东西是什么意思啊?谢谢!
  • 请教高手AIX中怎么删除行尾的字符^M


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3