hostapd 移植和使用[通俗易懂]

hostapd 移植和使用[通俗易懂]

发布于 2022-08-31 15:45:07

1.8K0

举报

大家好,又见面了,我是你们的朋友全栈君。

一、hostapd简介

hostapd 是一个用户态用于AP和认证服务器的守护进程。

它实现了IEEE 802.11相关的接入管理,IEEE 802.1X/WPA/WPA2/EAP 认证, RADIUS客户端,EAP服务器和RADIUS 认证服务器。

二、hostapd移植

1.打开hostap官网,下载hostapd-2.7.tar.gz源码包;

2.解压源码包:

$ tar xvzf hostapd-2.7.tar.gz

$ cd hostapd-2.7/hostapd

3.配置工程

(1)拷贝默认配置:

$ cp defconfig .config

(2) 打开.config,需要修改的配置如下:

CONFIG_DRIVER_WEXT=y //使用WEXT通过ioctl和驱动通信,典型工具ifconfig等

CONFIG_DRIVER_NL80211=y //使用NL80211通过一个特殊的socket和驱动打通信,典型工具包 括 iwconfig等,使能该选项时应指定libnl库,移植libnl参考libnl3.2 移植

CFLAGS += -I../../libnl-3.2.25/install/include/ // CONFIG_DRIVER_NL80211=y时。需指定libnl头文件

LIBS += -L../../libnl-3.2.25/install/include/ // CONFIG_DRIVER_NL80211=y时,需指定libnl库

CONFIG_LIBNL32=y // CONFIG_DRIVER_NL80211=y时,需指定libnl库版本

CC = arm-linux-gcc // 配置编译器

CONFIG_TLS = internal // 配置TLS实现,可选有openssl、internal,选择penssl时需指定openssl库,移植步 骤请参考Openssl 移植,由于开发板flash空间较小,出于节省空间的考虑,选择 internal

CONFIG_INTERNAL_LIBTOMMATH = y //CONFIG_TLS = internal时,需使能

CFLAGS += -I../../openssl-1.1.1/install/include/ // CONFIG_TLS = openssl时。需指定openssl头文件

LIBS += -L../../lopenssl-1.1.1/install/include/ // CONFIG_TLS = openssl时,需指定openssl库

可以根据自己的需求选择配置 CONFIG_DRIVER_WEXT 、CONFIG_DRIVER_NL80211 、CONFIG_TLS。

(3)执行 make -j8 编译hostapd。

(4)将可执行程序hostapd、hostapd_cli拷贝到开发板文件系统/usr/bin/目录下,使用chmod命令修改可执行权限:

$ chmod 777 hostapd、hostapd_cli

将hostapd.conf文件拷贝到开发板文件系统/etc/目录下。

如果使能配置选项CONFIG_DRIVER_NL80211=y,需将libnl-3.so.200.20.0和libnl-genl-3.so.200.20.0拷贝到开发 板文件系统/usr/lib/目录下,并在/usr/lib/执行以下命令创建软连接:

$ ln -s libnl-3.so.200.20.0 libnl-3.so.200

$ ln -s libnl-genl-3.so.200.20.0 libnl-genl-3.so.200

如果配置选项CONFIG_TLS = openssl,需将libcrypto.so.1.1和libssl.so.1.1拷贝到开发板文件系统/usr/lib/目录下。

三、配置hostapd

打开/etc/hostapd.conf文件,修改如下选项:

interface=wlan0 //设置网卡

#bridge=br0 //如果需要桥接到其他网卡,使能该项

ssid=testap //设置热点

channel=6 //设置wifi通道

wpa=2

wpa_passphrase=12345678 //设置热点密码

eap_server=1 //使能eap server

ieee80211n=1 //使能ieee80211n

ht_capab=[SHORT-GI-20][SHORT-GI-40][HT40+]

wpa_key_mgmt=WPA-PSK WPA-EAP

wpa_pairwise=CCMP TKIP

max_num_sta=8 //最大连接数

wpa_group_rekey=86400

四、hostapd使用

1.打开wlan0

$ ifconfig wlan0 up

2.设置wlan0 IP地址

$ ifconfig wlan0 192.168.0.1

3. 启动hostapd

$ hostapd /etc/hostapd.conf -B

4. 启动dhcpd

$dhcpd

到此,hostapd设置成功,可以使用手机连接开发板了。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/143220.html原文链接:https://javaforall.cn

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
您可以按照以下步骤在Linux系统上使用hostapd搭建和使用WiFi: 1. 安装hostapd:可以使用以下命令在终端中安装hostapd: ``` sudo apt-get update sudo apt-get install hostapd ``` 2. 配置hostapd:可以使用以下命令来编辑hostapd的配置文件: ``` sudo nano /etc/hostapd/hostapd.conf ``` 在编辑器中,您需要设置一些参数,例如SSID(WiFi名称),密码,通道等等。以下是一个示例: ``` interface=wlan0 driver=nl80211 ssid=my_network hw_mode=g channel=6 macaddr_acl=0 auth_algs=1 ignore_broadcast_ssid=0 wpa=2 wpa_passphrase=my_password wpa_key_mgmt=WPA-PSK wpa_pairwise=TKIP rsn_pairwise=CCMP ``` 请注意,这只是一个示例配置文件。您需要根据自己的需要进行调整。 3. 启动hostapd:可以使用以下命令来启动hostapd: ``` sudo systemctl start hostapd ``` 4. 配置网络接口:您需要配置网络接口,以便能够将WiFi网络连接到互联网。可以使用以下命令来配置网络接口: ``` sudo nano /etc/network/interfaces ``` 您需要添加以下内容: ``` auto wlan0 iface wlan0 inet static address 192.168.1.1 netmask 255.255.255.0 ``` 这将为wlan0接口配置静态IP地址。 5. 配置DHCP服务器:您需要配置DHCP服务器,以便为连接到WiFi网络的设备分配IP地址。可以使用以下命令来安装和配置DHCP服务器: ``` sudo apt-get install isc-dhcp-server ``` 然后,您需要编辑DHCP服务器的配置文件: ``` sudo nano /etc/dhcp/dhcpd.conf ``` 在文件末尾添加以下内容: ``` subnet 192.168.1.0 netmask 255.255.255.0 { range 192.168.1.10 192.168.1.50; option broadcast-address 192.168.1.255; option routers 192.168.1.1; default-lease-time 600; max-lease-time 7200; option domain-name "my_network"; option domain-name-servers 8.8.8.8, 8.8.4.4; } ``` 请注意,这只是一个示例配置文件。您需要根据自己的需要进行调整。 6. 启动DHCP服务器:可以使用以下命令来启动DHCP服务器: ``` sudo systemctl start isc-dhcp-server ``` 现在,您的hostapd WiFi网络已经搭建好了,您可以使用其他设备连接到该网络并访问互联网。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_20312079

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值