最近瘋狂的研究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服務器專題,或