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

  1. 启动hostapd

$ hostapd /etc/hostapd.conf -B

  1. 启动dhcpd

$dhcpd

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

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

相关推荐
o(╥﹏╥)20 分钟前
linux(ubuntu )卡死怎么强制重启
linux·数据库·ubuntu·系统安全
娶不到胡一菲的汪大东24 分钟前
Ubuntu概述
linux·运维·ubuntu
Yuan_o_36 分钟前
Linux 基本使用和程序部署
java·linux·运维·服务器·数据库·后端
东方隐侠安全团队-千里43 分钟前
网安瞭望台第17期:Rockstar 2FA 故障催生 FlowerStorm 钓鱼即服务扩张现象剖析
网络·chrome·web安全
那就举个栗子!1 小时前
Ubuntu 20.04下Kinect2驱动环境配置与测试【稳定无坑版】
linux·ubuntu
灯火不休➴1 小时前
[Xshell] Xshell的下载安装使用、连接linux、 上传文件到linux系统-详解(附下载链接)
linux·运维·服务器
Lukea111 小时前
【新教程】Ubuntu server 24.04配置无线网WiFi
linux·ubuntu·教程
小峰编程1 小时前
独一无二,万字详谈——Linux之文件管理
linux·运维·服务器·云原生·云计算·ai原生
卜及中1 小时前
【Linux】资源隔离机制 — 命名空间(Namespace)详解
linux·服务器·php
扛枪的书生1 小时前
Socat 命令总结
linux