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

Linux 钩子模块的编写

    来源: 互联网  发布时间:2015-10-28

    本文导语:  公司有个项目,要求写个钩子模块,要求只允许VLAN1的请求通过,过滤掉其他的(公司内部的交换机采用VLAN),请问如何入手呀,有那些资料可以参考的呀 | 在netfilter中注册钩子函数即可,一...

公司有个项目,要求写个钩子模块,要求只允许VLAN1的请求通过,过滤掉其他的(公司内部的交换机采用VLAN),请问如何入手呀,有那些资料可以参考的呀

|
在netfilter中注册钩子函数即可,一个参考实现

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 

//define interface packet coming from
static char *in_dev="eth0";
MODULE_PARM(in_dev,"s");

//capture packet and analyse it
static unsigned int packet_cap(unsigned int hooknum,struct sk_buff **pskb,const struct net_device *in,const struct net_device *out,int (*okfn)(struct sk_buff *))
{
unsigned int ret=NF_ACCEPT;
if(in&&(strcmp(in_dev,in->name)!=0)) goto no_interest;
struct iphdr *iph=(*pskb)->nh.iph;
unsigned int data_len=(*pskb)->len;



void *protoh=(u_int32_t *)iph+iph->ihl;
data_len-=iph->ihl*4;
switch(iph->protocol) {
case IPPROTO_TCP: {
struct tcphdr *tcph=protoh;
/*if((iph->frag_off)&IP_OFFSET)
break;
if(data_lensource);
if(sport%2==0) ret=NF_DROP;
printk("packet sport=%dn",sport);

break; 
}
case IPPROTO_UDP: {
struct udphdr *udph=protoh;
/*if((iph->frag_off)&IP_OFFSET)
break;
if(data_lensource);
if(sport%2==0) ret=NF_DROP;
break; 

default:
break;

no_interest:
return ret;
}

//define one hook function
static struct nf_hook_ops hook_pcap={{NULL,NULL},packet_cap,PF_INET,NF_IP_LOCAL_IN,NF_IP_PRI_FILTER+1};

static int __init init(void)
{
return nf_register_hook(&hook_pcap);
}

static void __exit fini(void)
{
nf_unregister_hook(&hook_pcap);
}

module_init(init);
module_exit(fini);

MODULE_LICENSE("GPL"); 

|
你需要在钩子函数里面来判断该数据包是否是指定的vlan所发出的包,进而可以控制是丢弃还是接收,这个是不难的,只要你知道如何判断是否是vlan发出的包就ok了
好运,好好理解一下吧。netfilter是很好用的一个框架

|


vlanid = (*(skb->data) & 0x0f) * 256 + *(skb->data + 1);



|
参照Netfilter,iptables ,你只用下钩子了。

    
 
 

您可能感兴趣的文章:

  • linux内核注册钩子是个什么东西?
  • linux下怎样给socket挂钩子
  • Linux中一个模块中的函数如何被另一个模块调用?
  • 同机装有Windows和Linux两套系统(先装Win后装Linux),如何使计算机使用Windows的启动模块而不是Linux的启动模块?
  • *******是不是对内核模块编程然后再重新编译内核就可以把此模块整合到linux系统中
  • 关于LINUX内核模块的按需卸载及安装
  • linux内核中网络模块的学习
  • linux怎样将网卡接收到的数据包交给不同模块处理
  • linux内核模块间调用函数
  • linux下使用无线模块wifi发现不了网卡
  • 怎样测出linux启动每个模块的时间
  • Linux 内核模块编程问题!!!!
  • linux2.6内核 如何自动加载当前所需要的模块
  • 关于Linux模块
  • linux 内核模块????
  • 数据库 iis7站长之家
  • linux 内核哪个模块是负责管理笔记本touchpad触摸板的?
  • 我向linux内核里加载模块时出现段错误
  • 在linux操作系统中,如何实现可加载的模块是否被卸载的检测
  • 关于Linux下模块编程的问题请教,急急急急急急
  • 编译和使用自己编写的linux内核模块的问题
  • Linux 内核模块工具 kmod
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 编写 linux shell 有什么好的编写工具呢?
  • 我是一个linux新手,不知道如何在linux进行C语言的编写和使用?
  • Linux下如何编写脚本文件
  • Linux有没有类似bat文件,如何编写。
  • linux下用java编写邮箱客户端程序与在windows下有什么不同??
  • LINUX下面的WEB Service如果编写?是用.NET写吗?WINDOW下面的web service能在LINUX下面用吗?
  • 在windows下可以用Code::Blocks编写linux程序吗?
  • 请教在linux下用什么编写web程序比较方便?
  • linux 编写内核函数errno
  • 如何在LINUX下用一个普通文件调用一个自己编写的调用系统的文件
  • 如何在linux下自动启动一个用Java编写的服务程序?
  • 连接到Linux的终端可以进行程序编写吗
  • 如何在linux下用c语言编写文本界面,不是在x-window下
  • 请教各位大大 怎样编写LINUX触摸屏的驱动程序?
  • linux下用C或C++编写图形附加码程序
  • linux 里面编写c语言用什么软件好用啊?
  • 怎么在LINUX下打开QT编写的文件。。。。
  • 想在LINUX平台上编写一个播放器,需要什么软件呢?
  • 如何编写MOTO E6 linux系统的PKG软件
  • Linux下如何用C语言编写命令行下的菜单
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载


  • 站内导航:


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

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

    浙ICP备11055608号-3