Linux下Wi-Fi的实现:wireless_tools和wpa_supplicant

简介: 平台为hi35XX,在Liunx下借助wireless_tools和wpa_supplicant(因为现在的无线WIFI网络大多是wpa加密。所以需要移植wpa_supplicant工具)等工具实现wifi的过程。

平台为hi35XX,在Liunx下借助wireless_tools和wpa_supplicant(因为现在的无线WIFI网络大多是wpa加密。所以需要移植wpa_supplicant工具)等工具实现wifi的过程。

 

一、移植wireless_tools

1. 下载并编译wireless_tools

    tar zxf  wireless_tools.29.tar.gz(网上下载)

    cd wireless_tools.29

    make

    成功后会在当前目录生成iwspy,iwpriv,iwlist以及iwconfig等文件。

2. 拷贝文件

    我们只需将这四个文件拷备到文件系统的sbin目录,然后将当前目录的libiw.so.29库文件拷到文件系统的lib目录,无线网络工具即安装完成。

 

 

二、加载无线网卡驱动模块

    网上有很多无线驱动模块,可移植性很好。呵呵,我的是利用XX无线网卡公司提供的网卡驱动源码,修改下Makefile(1.网卡选择 2.平台  3.内核路径和工具链)以及os/linux下的config.mk(一般不需要修改),make得到的。

    insmod rtutil5572sta.ko。
    insmod rt5572sta.ko
    insmod rtnet5572sta.ko



三、指令的使用

1.  扫描可用的无线网络

    iwlistwifi-name scanning 

    其中wifi-name为无线网卡的名字,比如网卡eth0就是系统默认的网卡名字, wifi-name可以用ifconfig查看,一般为ra0(无线网卡),不过,需要ifconfig ra0 up

2.  扫描网络信息

    iwlistra0 scan

===>rt_ioctl_giwscan.11(11) BSS returned, data->length = 1427 

ra0       Scan completed : 

          Cell 01 - Address:C4:CA:D9:1D:9E:A0 

                    Protocol:802.11b/g/n 

                    ESSID:"" 

                    Mode:Managed 

                    Frequency:2.412 GHz(Channel 1) 

                    Quality=7/100  Signal level=-87 dBm  Noise level=-82 dBm 

                    Encryption key:off 

                    Bit Rates:54 Mb/s 

    如上:ESSID项的值即为无线网络的名字,如上的“TXJ”等。如果值为空,说明在无线路由勾选了隐藏ESSID的选项。ESSID是很关键的,如果被隐藏了,也不是不能连接,而是需要破解,用到其他的工具,非常麻烦。

3. 设置要连接的网络类型

      iwprivra0 set NetworkType=Infra 

4. 设置要连接的无线网络的安全模式

      iwprivra0 set AuthMode=WPA2PSK 

5. 设置网络加密方式:(CCMP即为AES)

      iwprivra0 set EncrypType=TKIP  

6. 设置连接时的密码

      iwprivra0 set WPAPSK=*******  //********为加密网络的密码

7. 连接该网络:有两种方式:

<1> 用iwpriv命令

    iwpriv ra0 set SSID=TXJ

<2> 用iwconfig命令

    iwconfigra0 essid TXJ

    至此,如果密码正确,就可以连接上网络TXJ了。 

8. 查看状态

    iwpriv ra0 connStatus 

    当然,你也可以用iwconfig命令查看状态。

 

 

四、wpa_supplicant

   wpa_supplicant本是开源项目源码,被谷歌修改后加入android移动平台,它主要是用来支持WEP,WPA/WPA2和WAPI无线协议和加密认证的,而实际上的工作内容是通过socket(不管是wpa_supplicant与上层还是 wpa_supplicant与驱动都采用socket通讯)与驱动交互上报数据给用户,而用户可以通过socket发送命令给wpa_supplicant调动驱动来对WiFi芯片操作。 简单的说,wpa_supplicant就是WiFi驱动和用户的中转站外加对协议和加密认证的支持。

 

    wpa_supplicant由网卡公司提供,呵呵,同样,网上也有很多相关资料,如下:

1.生成wpa_supplicant(网上下载,本人未试)

1.1下载并解压wpa_supplicant需要的源码

    tarxvfz wpa_supplicant-0.7.2.tar.gz

    tarxvfz wpa_supplicant-0.5.8.tar.gz

    tarzxvf openssl-0.9.8e.tar.gz

1.2编译openssl库

将wpa_supplicant中的补丁拷贝到openssl中:

       cp wpa_supplicant-0.7.2/patches/openssl-0.9.8e-tls-extensions.patch  openssl-0.9.8e/

建立openssl编译目标路径:

      mkdir /usr/local/ssl

修改openssl-0.9.8e目录下的makefile文件,修改内容如下:

    CC=arm-none-linux-gnueabi-gcc

    AR=arm-none-linux-gnueabi-ar

    RANLIB=arm-none-linux-gnueabi-ranlib

    INSTALLTOP=/usr/local/ssl

    OPENSSLDIR=/usr/local/ssl

然后编译openssl:

    make & make install

正常编译后,在/usr/local/ssl中将会出现ssl库。

1.3编译wpa_supplicant

    cd  wpa_supplicant-0.5.8

    cp  defconfig .config

在.config中添加如下代码

    CC=arm-none-linux-gnueabi-gcc-L /usr/local/ssl/lib/

    CFLAGS+= -I/usr/local/ssl/include/

    LIBS+= -L/usr/local/ssl/lib/

然后编译:

    make

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

 

2.把RT2870STA.dat文件复制到/etc/Wireless/RT2870STA 目录下

    1.1 mkdir -p /etc/Wireless/RT2870STA //创建多层目录。

    1.2 cp /mnt/rt5370/RT2870STA.dat  /etc/Wireless/RT2870STA

 

3.首先关闭本地网卡,再启动wifi网卡

    #ifconfig eth0 down (如果非同一ip段,不需要关闭)

    ifconfig ra0 up

    启动网卡后,会不断出现错误:BIRIdx(1): RXDMALen not multiple of 4.[43507], BulkInBufLen = 416)
    修改./MODULE/include/iface/rtmp_usb.h问题就能够解决掉。
    #define RXBULKAGGRE_SIZE  12 该为8 

 

4.设置网卡参数

    ifconfig ra0  192.168.2.188

    #ifconfig ra0  broadcast 192.168.2.255 (广播地址,默认)

    #ifconfig ra0  netmask 255.255.255.0(子网掩码,默认)

 

5.编写wpa_supplicant.conf配置文件

    ctrl_interface=/var/run/wpa_supplicant

    network={

             ssid="TXJ"  //路由器名称

             scan_ssid=1

             key_mgmt=WPA-EAP WPA-PSK IEEE8021XNONE

             pairwise=TKIP CCMP

             group=CCMP TKIP WEP104 WEP40

             psk="xxxxx" //密码

            }

 

6.启动命令

    mkdir -p /var/run/wpa_supplicant

    /mnt/rt5370/wpa_supplicant -Dwext-ira0 -c /etc/wpa_supplicant.conf

7.命令查看状态

  /mnt/rt5370/iwpriv ra0 connStatus   //iwpriv文件放在/mnt/rt5370/目录下,所以,需要这样运行指令。

  成功 ra0  connStatus:Connected(AP:TXJ[E0:05:C5:CF:F0:56])

  然后,就可以ping通192.168.2.1,说明连接上路由器了。那么,工作就完成了。

附:

    -i<ifname>: 网络接口名称 

    -c<conf>:配置文件名称

    -C<ctrl_intf>:控制接口名称

    -D<driver>:驱动类型

    -p<driver_param>:驱动参数

    -b<br_ifname>:桥接口名称

 

 

rt5370支持WPS,rt3070不支持。

 

目录
相关文章
|
Linux 网络安全 开发工具
Linux:expect实现自动拉取git代码
Linux:expect实现自动拉取git代码
392 0
Daz
|
Unix Linux Shell
GNU/Linux下实现一个简易shell,支持多重管道
简易shell,支持多重管道
Daz
407 0
|
监控 Shell Linux
【Linux】进程控制 —— 进程创建 | 进程退出 | 进程等待 | 进程程序替换 | 实现简易shell
本文将介绍进程控制;最后自己实现简陋的shell,对于bash会有更深的理解。 前置文章:进程虚拟地址空间;环境变量。
295 0
【Linux】进程控制 —— 进程创建 | 进程退出 | 进程等待 | 进程程序替换 | 实现简易shell
Daz
|
IDE Unix Linux
|
Java Linux
想要在Linux中只显示隐藏文件,用对ls就可以实现
在使用Linux的过程中,如何只显示隐藏文件呢? 其实非常简单,只需要用到`ls`就可以实现。
254 0
想要在Linux中只显示隐藏文件,用对ls就可以实现
Daz
|
IDE Unix Linux
GNU/Linux下实现一个简易echo服务器
本文将详细讲解一个简易echo服务器的实现
Daz
224 0
GNU/Linux下实现一个简易echo服务器
|
关系型数据库 MySQL Linux
Linux下C语言实现MySQL操作——连接、查询、插入与客户端打造
Linux下C语言实现MySQL操作——连接、查询、插入与客户端打造
314 0
Linux下C语言实现MySQL操作——连接、查询、插入与客户端打造
|
Linux
基于XShell实现Win与Linux文件传输(替换XFtp等)
基于XShell实现Win与Linux文件传输(替换XFtp等)
254 0
基于XShell实现Win与Linux文件传输(替换XFtp等)
|
安全 Oracle 关系型数据库
Linux——了解目录结构( / )、实现远程操作(Xshell、Xftp)
Linux——了解目录结构( / )、实现远程操作(Xshell、Xftp)
Linux——了解目录结构( / )、实现远程操作(Xshell、Xftp)
|
Linux
Linux C 实现屏幕截图
Linux C 实现屏幕截图
280 0