歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux綜合 >> Linux資訊 >> 更多Linux >> Linux下的網絡HOOK實現以及使用方法

Linux下的網絡HOOK實現以及使用方法

日期:2017/2/27 9:45:24   编辑:更多Linux

最近瘋狂的研究Linux的種種功能,也頗有心得,這裡講述一下Linux下的Net的Hook,使用net的Hook可以實現很多很多非常底層的功能,比如過濾報文,做防火牆,做代理等等。

Now,Let's Go!

使用的是Linux 2.6.19.1的內核代碼。

首先是 在./Source/net/netfilter/core.c文件中的函數 nf_register_hook:

static DEFINE_SPINLOCK(nf_hook_lock);

int nf_register_hook(strUCt nf_hook_ops *reg)

{

struct list_head *i;

spin_lock_bh(&nf_hook_lock);

list_for_each(i, &nf_hooks[reg->pf][reg->hooknum]) {

if (reg->priority < ((struct nf_hook_ops *)i)->priority)

break;

}

list_add_rcu(®->list, i->prev);

spin_unlock_bh(&nf_hook_lock);

synchronize_net();

return 0;

}

EXPORT_SYMBOL(nf_register_hook);

void nf_unregister_hook(struct nf_hook_ops *reg)

{

spin_lock_bh(&nf_hook_lock);

list_del_rcu(®->list);

spin_unlock_bh(&nf_hook_lock);

synchronize_net();

}

EXPORT_SYMBOL(nf_unregister_hook);

int nf_register_hooks(struct nf_hook_ops *reg, unsigned int n)

{

unsigned int i;

int err = 0;

for (i = 0; i < n; i++) {

err = nf_register_hook(®[i]);

if (err)

goto err;

}

return err;

err:

if (i > 0)

nf_unregister_hooks(reg, i);

return err;

}

EXPORT_SYMBOL(nf_register_hooks);

void nf_unregister_hooks(struct nf_hook_ops *reg, unsigned int n)

{

unsigned int i;

for (i = 0; i < n; i++)

nf_unregister_hook(®[i]);

}

EXPORT_SYMBOL(nf_unregister_hooks);

更多內容請看Linux安全應用寶典 Linux防火牆 Linux服務器專題,或




Copyright © Linux教程網 All Rights Reserved