全志科技
直播中

纯纯纯牛奶

11年用户 523经验值
私信 关注
[问答]

wpa_supplicant是什么?启动wpa_supplicant应用

  • 该FAQ旨在记录wpa_supplicant和wpa_cli的一些基础知识,方便在tina系统上做网络联通性的排查。

回帖(1)

潘福乔

2021-12-29 13:46:26

  • wpa_supplicant是一个连接、配置WiFi的工具,它主要包含wpa_supplicant与wpa_cli两个程序。 可以通过wpa_cli来进行WiFi的配置与连接,前提要保证wpa_supplicant正常启动。
    相当于wpa_supplicant 是服务端,wpa_cli 是客户端。
    1.wpa_supplicant
    启动wpa_supplicant应用
    wpa_supplicant -i wlan0 -Dnl80211 -c/etc/wifi/wpa_supplicant.conf -O /etc/wifi/sockets -B
    wpa_supplicant -Dnl80211 -iwlan0 -c/etc/wifi/wpa_supplicant.conf -B
    wpa_supplicant -B -iwlan0 -c/etc/wifi/wpa_supplicant.conf -Dwext
    -D 驱动程序名称(可以是多个驱动程序:nl80211,wext)
    -i 接口名称
    -c 配置文件
    -B 在后台运行守护进程
    配置文件 /etc/wpa_supplicant.conf文件里,添加下面代码:
    ctrl_interface=/var/run/wpa_supplicant //
    update_config=1 // 强制更新覆盖配置 
    ctrl_interface指向的是一个目录,在这个目录中默认会生成一个文件/var/run/wpa_supplicant/wlan0,这是local socket address,相当于UNIX Domain Socket,程序和后台程序wpa_supplicant进行通信(其实是wpa_supplicant作为后台服务程序是通过本地socket和客户端进行通信的)
    update_config = 1时会在(客户端发送SAVE_CONFIG命令)更新这个配置文件。
    Tina上wpa_supplicant的启动是放在/etc/init.d/wpa_supplicant自启动脚本中的。
    2.wpa_cli
    wpa_cli 是客户端,用来进行WiFi的配置与连接。
    启动wpa_cli应用


  • wpa_cli 有命令和交互的方式进行操作
  • wpa_cli -i wlan0 scan   //搜索附件wifi热点
  • wpa_cli -i wlan0 scan_result   //显示搜索wifi热点
  • wpa_cli -i wlan0 status //当前WPA/EAPOL/EAP通讯状态
  • wpa_cli -i wlan0 ping //pings wpa_supplicant


  • 添加新的连接


  • wpa_cli -i wlan0 add_network //添加一个网络连接,会返回
  • wpa_cli set_network ssid ‘“name”’ //ssid名称
  • wpa_cli set_network psk ‘“psk”’  //密码
  • wpa_cli set_network scan_ssid 1
  • wpa_cli set_network priority 1 //优先级


  • 保存连接
    wpa_cli -i wlan0 save_config //信息保存到默认的配置文件中,前面提到的/etc/wpa_supplicant.conf
  • 断开连接



  • wpa_cli -i wlan0 list_network //列举保存过得连接
  • wpa_cli -i wlan0 select_network //连接指定的ssid
  • wpa_cli -i wlan0 enable_network //使能制定的ssid


  • 网络连接成功的配置文件示例



  • ctrl_interface=/var/run/wpa_supplicant/
  • ap_scan=1
  • network={
  • scan_ssid=1
  • ssid="xxxx"
  • psk="xxxx"
  • bssid=
  • priority=2
  • }
  • 例如:



  • wpa_cli -i wlan0 scan;
  • wpa_cli -i wlan0 scan_result;
  • wpa_cli -i wlan0 add_network;
  • wpa_cli -i wlan0 set_network 0  ssid '"AW-PDC-PD2-fly2.4g"';
  • wpa_cli -i wlan0 set_network 0  key_mgmt WPA-PSK;
  • wpa_cli -i wlan0 set_network 0  psk '"xxxxxxxx"';
  • wpa_cli -i wlan0 save_config;
  • wpa_cli -i wlan0 select_network 0;
  • wpa_cli -i wlan0 enable_network 0;
  • wpa_cli -i wlan0 list_network;
  • wpa_cli -i wlan0 status;



      • 问题记录

      • 错误1
        Successfully initialized wpa_supplicant
        ioctl[SIOCSIWENCODEEXT]: Invalid argument
        ioctl[SIOCSIWENCODEEXT]: Invalid argument




    原来在命令中sudo wpa_supplicant -B -D n180211,wext -i wlo1 -c /home/wpa_supplicant.cfg
    错把nl80211写成n180211,注意是数字1与字母l的区别。



    • 错误2
      wpa supplicant: No network configuration found for current AP
      说明配置文件写的不对,尤其从网上复制过来时常有看不见的tab字符等。
      解决办法:从Archlinux文档上复制了一份格式正确的配置,再改一改就OK了
    • 错误3
      ctrl_iface exists and seems to be in use - cannot override it
      Delete ‘/var/run/wpa_supplicant/wlo1’ manually if it is not used anymore
      Failed to initialize control interface ‘/var/run/wpa_supplicant’.
      You may have another wpa_supplicant process already running or the file was
      left by an unclean termination of wpa_supplicant in which case you will need
      to manually remove this file before starting wpa_supplicant again.
      系统已经存在打开的多个wpa_supplicant实例,执行一下sudo killall wpa_supplicant杀死所有wpa_supplicant即可。
    • 错误4
      Successfully initialized wpa_supplicant
      [ 2093.037373] ieee80211_do_open: vif_type=2, p2p=0, ch=3, addr=34:0f:51:ac:5f:97
      [ 2093.045662] [STA] !!!xradio_vif_setup: id=0, type=2, p2p=0, addr=34:0f:51:ac:5f:97
      [ 2093.055088] [AP_WRN] BSS_CHANGED_ASSOC but driver is unjoined.
      nl80211: deinit ifname=wlan0 disabled_11b_rates=0
      [ 2093.088882] [STA_WRN] !!! xradio_remove_interface: vif_id=0
      wlan0: Failed to initialize driver interface


举报

更多回帖

发帖
×
20
完善资料,
赚取积分