netfilter demo
功能:指定IP报文DROP
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/netfilter_ipv4.h>
#include <linux/skbuff.h>
#include <linux/udp.h>
#include <linux/ip.h>
#include <net/ip.h>
#include <linux/inet.h> /*in_aton()*/ /* This function to be called by hook. */
MODULE_LICENSE("Dual BSD/GPL"); static char* n_ip = "192.168.1.102"; //ip=192.168.1.61
module_param(n_ip, charp, S_IRUGO); static unsigned int hook_func (unsigned int hooknum,
struct sk_buff *skb,
const struct net_device *in,
const struct net_device *out, int (*okfn) (struct sk_buff *))
{
struct tcphdr *tcph = tcp_hdr (skb);
struct iphdr *iph = ip_hdr (skb);
struct tcphdr *modtcph;
unsigned char *tail;
unsigned char *user_data;
unsigned char *it;
struct sk_buff *modskb;
char *tempPay;
char *payload; //Char array to store original payload before modifications
int lenOrig;
int lenNew;
u16 sport, dport;
u32 saddr, daddr;
int i1,i2,i3,i4; if (!skb)
return NF_ACCEPT; saddr = ntohl (iph->saddr);
daddr = ntohl (iph->daddr);
sport = ntohs (tcph->source);
dport = ntohs (tcph->dest);
tail = skb_tail_pointer (skb);
user_data = (unsigned char *) ((unsigned char *) tcph + (tcph->doff * )); if (iph->daddr == in_aton(n_ip) ) //判断ip地址
{
i1 = daddr>>;
i2 = (daddr>>) & 0x000000ff;
i3 = (daddr>>) & 0x000000ff;
i4 = daddr & 0x000000ff;
printk ("daddr == %d.%d.%d.%d\n ",i1,i2,i3,i4); ip_send_check (iph);
for (it=user_data;it!=tail;it++)
{
*it++;
printk("%x",*it);
}
printk ("\n");
return NF_DROP;
} return NF_ACCEPT;
} static struct nf_hook_ops nfho = {
.hook = hook_func,
.hooknum = , /* NF_IP_LOCAL_IN */
.pf = PF_INET,
.priority = NF_IP_PRI_FIRST,
}; static int __init
init_nf (void)
{
printk (KERN_INFO "Register netfilter module.\n");
nf_register_hook(&nfho);
printk ("n_ip: %s\n", n_ip);
return ;
} static void __exit
exit_nf (void)
{
printk (KERN_INFO "Unregister netfilter module.\n");
nf_unregister_hook (&nfho);
} module_init (init_nf);
module_exit (exit_nf);
MODULE_LICENSE ("GPL");
Makefile
obj-m := demo.o
modules-objs:= demo.o
KDIR := /lib/modules/`uname -r`/build
PWD := $(shell pwd) default:
make -C $(KDIR) M=$(PWD) modules clean:
rm -rf *.o .* .cmd *.ko *.mod.c .tmp_versions
netfilter demo的更多相关文章
- 通过一个demo了解Redux
TodoList小demo 效果展示 项目地址 (单向)数据流 数据流是我们的行为与响应的抽象:使用数据流能帮我们明确了行为对应的响应,这和react的状态可预测的思想是不谋而合的. 常见的数据流框架 ...
- 很多人很想知道怎么扫一扫二维码就能打开网站,就能添加联系人,就能链接wifi,今天说下这些格式,明天做个demo
有些功能部分手机不能使用,网站,通讯录,wifi基本上每个手机都可以使用. 在看之前你可以扫一扫下面几个二维码先看看效果: 1.二维码生成 网址 (URL) 包含网址的 二维码生成 是大家平时最常接触 ...
- 在线浏览PDF之PDF.JS (附demo)
平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html#skill 下载地址:http://mozilla.gith ...
- 【微框架】Maven +SpringBoot 集成 阿里大鱼 短信接口详解与Demo
Maven+springboot+阿里大于短信验证服务 纠结点:Maven库没有sdk,需要解决 Maven打包找不到相关类,需要解决 ps:最近好久没有写点东西了,项目太紧,今天来一篇 一.本文简介 ...
- vue双向数据绑定原理探究(附demo)
昨天被导师叫去研究了一下vue的双向数据绑定原理...本来以为原理的东西都非常高深,没想到vue的双向绑定真的很好理解啊...自己动手写了一个. 传送门 双向绑定的思想 双向数据绑定的思想就是数据层与 ...
- Android Studio-—使用OpenCV的配置方法和demo以及开发过程中遇到的问题解决
前提: 1.安装Android Studio(过程略) 2.官网下载OpenCV for Android 网址:http:opencv.org/downloads.html 我下载的是下图的版本 3. ...
- iOS之ProtocolBuffer搭建和示例demo
这次搭建iOS的ProtocolBuffer编译器和把*.proto源文件编译成*.pbobjc.h 和 *.pbobjc.m文件时,碰到不少问题! 搭建pb编译器到时没有什么问题,只是在把*.pro ...
- 钉钉开放平台demo调试异常问题解决:hostname in certificate didn't match
今天研究钉钉的开放平台,结果一个demo整了半天,这帮助系统写的也很难懂.遇到两个问题: 1.首先是执行demo时报unable to find valid certification path to ...
- 无限分级和tree结构数据增删改【提供Demo下载】
无限分级 很多时候我们不确定等级关系的层级,这个时候就需要用到无限分级了. 说到无限分级,又要扯到递归调用了.(据说频繁递归是很耗性能的),在此我们需要先设计好表机构,用来存储无限分级的数据.当然,以 ...
随机推荐
- 02_HTML03
学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"软件测试"获取视频和教程资料! b站在线视频 HTML ...
- MacOS英语学习
总结于B站Mac云课堂:https://www.bilibili.com/video/BV1vf4y1U7SZ 各个软件的链接: Edge:https://www.microsoft.com/zh-c ...
- zabbix 监控nginx状态
1. 安装nginx,参考其它 [root@iZ2zeapnvuohe8p14289u6Z /]# vim /etc/nginx/nginx.conf # 加上下面 location /nginx_s ...
- Python os.remove() 方法
概述 os.remove() 方法用于删除指定路径的文件.如果指定的路径是一个目录,将抛出OSError.高佣联盟 www.cgewang.com 在Unix, Windows中有效 语法 remov ...
- PHP scandir() 函数
------------恢复内容开始------------ 实例 列出 images 目录中的文件和目录: <?php$dir = "/images/"; // Sort ...
- HDU Typewriter 6583 dp SAM 卡常
LINK:Typewriter 好久没写SAM了 什么都给忘了. 写了大概2h.感觉被卡常还看了题解. 考虑dp 然后容易想到维护前面的一个j决策 尽可能小. 然后每次考虑向后加一个字符 不过不行就跳 ...
- luogu P4095 [HEOI2013]Eden 的新背包问题 多重背包 背包的合并
LINK:Eden 的新背包问题 就是一个多重背包 每次去掉一个物品 询问钱数为w所能买到的最大值. 可以对于每次Q暴力dp 利用单调队列优化多重背包 这样复杂度是Qnm的. 发现过不了n==10的点 ...
- 通过缓存Cache记录命中率
import org.apache.juli.logging.Log; /** * 通过此Cache记录命中率 * @author Administrator * */ public class Lo ...
- adb如何连接Mac版腾讯手游助手
Mac版腾讯手游助手,的端口是6555: 所以使用adb connect 127.0.0.1:6555 进行连接
- [NLP]LSTM理解
简介 LSTM(Long short-term memory,长短期记忆)是一种特殊的RNN,主要是为了解决长序列训练过程中的梯度消失问题.以下先从RNN介绍. 简说RNN RNN(Recurrent ...