CentOS7实现无线网卡配置及连接

安装配置

最近用到产品无线功能模块自动化无线连接测试,这次做一个环境部署配置总结,在centos7.7系统内核版本3.10,使用的是RTL8812AU无线芯片网卡,Realtek官方有提供Linux驱动没法编译,国外大佬做了一个可以用于3.1内核的改版驱动,需网上下载:rtl8812au.zip驱动包。

使用make、make install命令编译安装,安装完后最好reboot一下,如果在编译过程中出现问题,一般来说都是依赖没装好,尝试用以下命令解决:

yum update (更新yum软件仓库)

yum install gcc (安装gcc)

安装完后,查看内核是否有加载的8812au模块:

[root@Server ~]# lsmod | grep 8812

8812au               1011830  0

不支持iw命令,例如输入iw dev会显示“nl80211 not found.”,并不影响使用。

使用ip link命令查看网卡设备名,可见下图ens35u1就是无线网卡设备名。

启动无线网卡:ifconfig ens35u1 up

设置WIFI热点:
首先如果还没安装wpa_supplicant的话,请先运行yum install wpa_supplicant

然后修改配置文件:

# vim /etc//wpa_supplicant/wpa_supplicant.conf

ctrl_interface=/var/run/wpa_supplicant/
update_config=1
device_name=RTL8192CU
manufacturer=Realtek
model_name=RTW_STA
model_number=WLAN_CU
serial_number=12345
device_type=1-0050F204-1
os_version=01020300
config_methods=virtual_display virtual_push_button keypad

以上内容就是添加到配置文件里。

服务端wpa_supplicant

wpa_supplicant是一个较好的选择,但缺点是它不支持所有的驱动。请浏览wpa_supplicant网站获得它所支持的驱动列表。另外,wpa_supplicant目前只能连接到那些你已经配置好ESSID的无线网络。wireless-tools支持几乎所有的无线网卡和驱动,但它不能连接到那些只支持WPA的AP。

经过编译后的wpa_supplicant源程序可以看到两个主要的可执行工具:wpa_supplicant和wpa_cli。 wpa_supplicant是核心程序,它和wpa_cli的关系就是服务和客户端的关系:后台运行wpa_supplicant,使用wpa_cli 来搜索、设置、连接网络。

wpa_supplicant接受多个命令行参数,特别是:

    -B:在后台执行

    -c:文件名 -路径配置文件

    -i:接口 - 监听的接口

    -D:指定驱动

关于支持的驱动程序的列表,请参考wpa_supplicant -h的输出结果。

  • nl80211 是当前的标准,但不是所有的无线芯片的模块支持。
  • wext 目前已过时,但仍得到广泛支持。

使用 -D 开关来指定驱动:

# wpa_supplicant -B -i interface -c configuration_file -D driver

启动后台:

wpa_supplicant -D wext -i ens35u1 -c /etc/wpa_supplicant/wpa_supplicant.conf -B

开机启动:

/usr/lib/systemd/system/wpa_supplicant.service

/usr/sbin/wpa_supplicant -u -f /var/log/wpa_supplicant.log -D wext -i ens35u1 -c /etc/wpa_supplicant/wpa_supplicant.conf

systemctl  enable wpa_supplicant

wpa_cli交互模式的命令如下表:

Full command

Short command

Description

status

stat

displays the current connection status

disconnect

disc

prevents wpa_supplicant from connecting to any access point

quit

q

exits wpa_cli

terminate

term

kills wpa_supplicant

reconfigure

recon

reloads wpa_supplicant with the configuration file supplied (-c parameter)

scan

scan

scans for available access points (only scans it, doesn't display anything)

scan_result

scan_r

displays the results of the last scan

list_networks

list_n

displays a list of configured networks and their status (active or not, enabled or disabled)

select_network

select_n

select a network among those defined to initiate a connection (ie select_network 0)

enable_network

enable_n

makes a configured network available for selection (ie enable_network 0)

disable_network

disable_n

makes a configured network unavailable for selection (ie disable_network 0)

remove_network

remove_n

removes a network and its configuration from the list (ie remove_network 0)

add_network

add_n

adds a new network to the list. Its id will be created automatically

set_network

set_n

shows a very short list of available options to configure a network when supplied with no parameters.

See next section for a list of extremely useful parameters to be used with set_network and get_network.

get_network

get_n

displays the required parameter for the specified network. See next section for a list of parameters

save_config

save_c

saves the configuration

 

设置网络的基本格式:set_network <network id> <key> <parameter> [<parameter>]

显示网络信息的基本格式:get_network <network id> <key>

相应的参数如下表:

Key

Description

Parameters

ssid

Access point name

string

id_str

String identifying the network

string

priority

Connection priority over other APs

number (0 being the default low priority)

bssid

Mac address of the access point

mac address

scan_ssid

Enable/disbale ssid scan

0, 1, 2

key_mgmt

Type of key management

WPA-PSK, WPA_EAP, None

pairwise

Pairwise ciphers for WPA

CCMP, TKIP

group=TKIP

Group ciphers for WPA

CCMP, TKIP, WEP104, WEP40

psk

Pre-Shared Key (clear or encrypted)

string

wep_key0

WEP key (up to 4: wep_key[0123])

string

eap

Extensible Authentication Protocol

MD5, MSCHAPV2, OTP, GTC, TLS, PEAP, TTLS

identity

EAP identity string

string

password

EAP password

string

ca_cert

Pathname to CA certificate file

/full/path/to/certificate

client_cert

Pathname to client certificate

/full/path/to/certificate (PEM/DER)

private_key

Pathname to a client private key file

/full/path/to/private_key (PEM/DER/PFX)

常见例子:

1、连接无加密的AP

>add_network  (It will display a network id for you, assume it returns 0)

>set_network 0 ssid ‘"test"’

>set_network 0 key_mgmt NONE

>enable_network 0

>quit

2、连接WEP加密AP

>add_network   (assume return 1)

>set_network 1 ssid ‘"test"’

>set_network 1 key_mgmt NONE

>set_network 1 wep_key0 "'your ap password"'

>enable_network 1

3、连接WPA-PSK/WPA2-PSK加密的AP

>add_network   (assume return 2)

>set_network 2 ssid ‘"test"’

>set_network 2 psk '"your pre-shared key"'

>enable_network 2

到此,wifi模块就能连接上AP了。

3、以上是通过命令行工具wpa_cli来实现wifi网络的连接。当然,也可以通过wpa_supplicant的配置文件来实现连接。

再回顾下运行wpa_supplicant时执行的命令:

/system/bin/wpa_supplicant -d -Dwext -iens35u1 -c/etc/wpa_supplicant/wpa_supplicant.conf

我们在执行时加上了-c/etc/wpa_supplicant/wpa_supplicant.conf,可以将我们要连接的AP的设置以一定的格式写入wpa_supplicant.conf配置文件中即可。

例如:

ctrl_interface=/var/run/wpa_supplicant/

network={

ssid="my access point"

proto=WPA

key_mgmt=WPA-PSK

psk='"you pass words"'

}

配置hostap软路由

  1. 官网下个特别版Hostap,这个程序可以在官方驱动包里找到,位置是:\Linux\wpa_supplicant_hostapd\wpa_supplicant_hostapd-0.8_rtw_r7475.20130812.tar.gz
  2. 找到后把它复制到当前目录,如果之前安装过hostapd,可以使用yum remove hostapd命令,把原版的先卸载掉。
解压:
# tar -xzvf wpa_supplicant_hostapd-0.8_rtw_r7475.20130812.tar.gz
# cd wpa_supplicant_hostapd-0.8_rtw_r7475.20130812/hostapd
# make & make install
修改配置文件:
# vim rtl_hostapd.conf

interface=ens35u1
ctrl_interface=/var/run/hostapd
ssid=CentOS_Test
channel=6
wpa=2
wpa_passphrase=12345678
#bridge=br0
eap_server=1
wps_state=2
uuid=12345678-abc5-def0-1234-56789abcdef0
device_name=RTL8192CU
manufacturer=Realtek
model_name=RTW_SOFTAP
model_number=WLAN_CU
serial_number=12345
device_type=6-0050F204-1
os_version=01020300
config_methods=label display push_button keypad
driver=rtl871xdrv
beacon_int=100
hw_mode=g
ieee80211n=1
wme_enabled=1
ht_capab=[SHORT-GI-20][SHORT-GI-40][HT40+]
wpa_key_mgmt=WPA-PSK
wpa_pairwise=CCMP
max_num_sta=8
wpa_group_rekey=86400

上面这个配置文件中,红色部分是需要修改的:

1. interface=无线网卡设备名
2. ssid=自定义热点名
3. wpa_passphrase=密码
4. bridge=网桥名 (如以网桥方式连接的话,要填上网桥名,否则必须注释掉)
5. uuid=通用识别码

详细版本在官方驱动程序包的如下位置:
配置文件:\Linux\wpa_supplicant_hostapd\rtl_hostapd_2G.conf
PDF说明:\Linux\document\Quick_Start_Guide_for_SoftAP.pdf

# chmod +x rtl_hostapd.conf
# ./hostapd rtl_hostapd.conf -B (以后台方式启动hostap)

最后,用手机扫描WIFI,会发现有一个名为CentOS_Test的热点,恭喜成功!

综合实践

  • WiFi开启

先配置好无线路由器SSID、加密方式等。

# ifconfig  ens35u1 up ( 启动无线网卡)

# wpa_supplicant -D wext -i ens35u1 -c /etc/wpa_supplicant/wpa_supplicant.conf -B  (启动服务端)

根据配置文件/etc/wpa_supplicant.conf来初始化ens35u1接口

如果wpa_supplicant.conf文件为空,则不会自动连接,需要连接一次网络才行

  • 扫描热点

命令如下:

wpa_cli -i ens35u1 scan              //扫描附近热点

wpa_cli -i ens35u1 scan_result   //打印热点信息

 

  • 连接热点
# wpa_cli -i ens35u1 add_network  // 添加一个网络连接,并返回网络ID号,如果wpa_supplicant.conf文件为空,则返回0,表示第一个热点
作用:用来区分用户连接过的每个热点

3.1以连接yj-hello_5G为例

wpa_cli -i ens35u1 set_network 1 ssid '"yj-hello_5G"'    //设置ID为0的热点SSID

wpa_cli -i ens35u1 set_network 1 psk '"yj-hello_5G"'    //设置ID为0的热点的密码

wpa_cli -i ens35u1 key_mgmt WPA-PSK

PS:如果是没有加密的公共网络,则为NONE:

wpa_cli -i ens35u1 set_network 0 key_mgmt NONE

继续输入:

wpa_cli -i ens35u1 set_network 0 priority 2     //设置当前网络优先级,默认为2

wpa_cli -i ens35u1 set_network 0 scan_ssid 1    //设置ssid默认为1即可

wpa_cli -i ens35u1 enable_network 1            //启动连接ID为0的网络

wpa_cli -i ens35u1 select_network 1             //选择网络0(这样做的好处在于,可以取消先前的其它网络连接)

udhcpc -b -i ens35u1 -q  或 dhclient ens35u1 或 配置静态IP  (ifconfig ens35u1 192.168.0.19 netmask 255.255.255.0)

ping路由器网关:

  • 保存连接配置
wpa_cli -i ens35u1 save_config    //保存当前连接的网络配置到wpa_supplicant.conf文件中,使得下次自动连接

保存后的wpa_supplicant.conf文件如下所示:

 

查看无线网卡当前连接状态:

# wpa_cli -i ens35u1 status

查看当前连接的是哪个网络:

# wpa_cli -i wlan0 list_network 

打印如下,可以看到当前连接的ID号为1:

查看当前速率:

[root@Server ~]# iwlist ens35u1 rate

ens35u1   4 available bit-rates :

      1 Mb/s

      2 Mb/s

      5.5 Mb/s

      11 Mb/s

      Current Bit Rate:867 Mb/s

查看当前信道:

[root@Server ~]# iwlist ens35u1 channe | grep Current

          Current Frequency:5.745 GHz (Channel 149)

查看更详细信息:

以上的信息数据,自动化测试,用例会到获取速率值或信道值或MAC地址,需要脚本处理字符数据截取出来值。

  • 断开热点
wpa_cli -i wlan0 disable_network 0    //与id0的网络进行断开
wpa_cli -i wlan0 remove_network 0     //将id0的网络移除掉,必须先断开才行
wpa_cli -i wlan0 save_config          //并更新wpa_supplicant.conf文件

配置后的wpa_supplicant.conf文件如下所示:

ctrl_interface=/var/run/wpa_supplicant/
update_config=1
device_name=RTL8192CU
manufacturer=Realtek
model_name=RTW_STA
model_number=WLAN_CU
serial_number=12345
device_type=1-0050F204-1
os_version=01020300
config_methods=virtual_display virtual_push_button keypad

移除后,只缺少了当前SSID热点数据,以上内容还是默认会保留的。

  • 关闭WIFI

# killall udhcpc (如果ens35u1接口配置静态IP,此命令不使用)

# killall wpa_supplicant

# ifconfig ens35u1 down

备注:扫描过程中偶尔会出现如下信息:

Successfully initialized wpa_supplicant
rfkill: Cannot get wiphy information
ioctl[SIOCSIWAP]: Operation not permitted
似乎有一点报错,但实际上对使用并没什么影响。
还可以tail -f /var/log/wap_supplicant.log动态监控查看无线扫描、连接过程打印出来的日志数据。

 

posted on 2020-08-22 22:59  Jasongo  阅读(16812)  评论(0编辑  收藏  举报