USB Wi-FiアダプタがAP(CLI)に接続されていない

USB Wi-FiアダプタがAP(CLI)に接続されていない

最近armhfベースのボードを設定しましたが、ネットワーク構成でこの問題が発生しました。 TP-Link USB WiFiアダプタが接続されているので、WiFiに接続できるようですが、イーサネットケーブルを抜くと、設定したIPアドレスを使用してボードに接続できません/etc/network/interfaces。アクセスポイントも確認しましたが、それによると、私のデバイスはWi-Fi経由で接続されていませんでした。

統計によると、かなりうまく機能しているようで、ちょっと恥ずかしいです。これが私が今まで持っているものです:

$ tail -n [changes] /var/log/syslog

Mar 30 23:09:24 localhost kernel: [  830.968410] sun7i-dwmac 1c50000.ethernet eth0: Link is Down
Mar 30 23:09:50 localhost kernel: [  856.968094] sun7i-dwmac 1c50000.ethernet eth0: Link is Up - 100Mbps/Full - flow control rx/tx

接続が実行されているようです。

$ iw wlan0 link
      Connected to xx:67:5x:e1:9f:af (on wlan0)
      SSID: UPCA887FD1
      freq: 2452
      RX: 187653 bytes (1131 packets)
      TX: 500 bytes (6 packets)
      signal: -48 dBm
      tx bitrate: 57.8 MBit/s MCS 5 short GI

      bss flags:    short-slot-time
      dtim period:  1
      beacon int:   100


$ iwconfig
      eth0      no wireless extensions.



      wlan0     IEEE 802.11  ESSID:"nietwurk"
      Mode:Managed  Frequency:2.452 GHz  Access Point: xx:67:5x:e1:9f:af
      Bit Rate=72.2 Mb/s   Tx-Power=20 dBm
      Retry short limit:7   RTS thr:off   Fragment thr:off
      Encryption key:off
      Power Management:off
      Link Quality=66/70  Signal level=-44 dBm
      Rx invalid nwid:0  Rx invalid crypt:0  Rx invalid frag:0
      Tx excessive retries:0  Invalid misc:0   Missed beacon:0

      lo        no wireless extensions.


$ ifconfig 

      ...
      wlan0   Link encap:Ethernet  HWaddr 64:70:02:0e:10:99
              inet addr:192.168.0.35  Bcast:192.168.0.255  Mask:255.255.255.0
              UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
              RX packets:4494 errors:0 dropped:2 overruns:0 frame:0
              TX packets:11 errors:0 dropped:0 overruns:0 carrier:0
              collisions:0 txqueuelen:1000
              RX bytes:498743 (487.0 KiB)  TX bytes:1338 (1.3 KiB)



$ ifup -vvv wlan0
    Configuring interface wlan0=wlan0 (inet)
    run-parts --exit-on-error --verbose /etc/network/if-pre-up.d
    run-parts: executing /etc/network/if-pre-up.d/bridge
    run-parts: executing /etc/network/if-pre-up.d/ethtool
    run-parts: executing /etc/network/if-pre-up.d/hostapd
    run-parts: executing /etc/network/if-pre-up.d/ifenslave
    + [ inet = meta ]
    + IF_BOND_SLAVES=
    + [  ]
    + [  ]
    + [ -z  ]
    + exit
    run-parts: executing /etc/network/if-pre-up.d/vlan
    run-parts: executing /etc/network/if-pre-up.d/wireless-tools
    run-parts: executing /etc/network/if-pre-up.d/wpasupplicant
    wpa_supplicant: wpa-driver nl80211,wext (default)
    wpa_supplicant: /sbin/wpa_supplicant -s -B -P /run/wpa_supplicant.wlan0.pid -i wlan0 -D nl80211,wext -C /run/wpa_supplicant
    Starting /sbin/wpa_supplicant...
    wpa_supplicant: creating sendsigs omission pidfile: /run/sendsigs.omit.d/wpasupplicant.wpa_supplicant.wlan0.pid
    wpa_supplicant: ctrl_interface socket located at /run/wpa_supplicant/wlan0
    wpa_supplicant: configuring network block -- 0
    wpa_supplicant: wpa-ssid "nietwurk" -- OK
    wpa_supplicant: wpa-psk ***** -- OK
    wpa_supplicant: enabling network block 0 -- OK
    ip addr add 192.168.0.35/255.255.255.0 broadcast 192.168.0.255    dev wlan0 label wlan0
    ip link set dev wlan0   up

    run-parts --exit-on-error --verbose /etc/network/if-up.d
    run-parts: executing /etc/network/if-up.d/ethtool
    run-parts: executing /etc/network/if-up.d/ifenslave
    + [ inet = meta ]
    + [  ]
    run-parts: executing /etc/network/if-up.d/ip
    run-parts: executing /etc/network/if-up.d/mountnfs
    run-parts: executing /etc/network/if-up.d/openssh-server
    run-parts: executing /etc/network/if-up.d/upstart
    run-parts: executing /etc/network/if-up.d/wpasupplicant

/etc/network/interfaces

allow-hotplug wlan0
iface wlan0 inet static
        address 192.168.0.35
        netmask 255.255.255.0
        wpa-ssid nietwurk
        wpa-psk <the psk, not in quotes>
        wireless-mode Managed

どんなアイデアがありますか?

答え1

  1. 事前共有キー(PSK)の漏洩を防ぐために、/etc/network/interfacesの権限を制限します(または/etc/network/interfaces.d/wlan0などの最新のDebianバージョンでは別々の設定ファイルを使用します):

    chmod 0600 /etc/network/interfaces

  2. 次の例を変更して、WPAパスワードを使用してSSIDの正しいWPA PSKハッシュを計算します。

    wpa_passphrase myssid my_very_secret_passphrase

コマンドラインにパスワードを入力しないと、パスワードの入力を求められます。上記のコマンドは、次の出力を提供します。

network={
    ssid="myssid"
    #psk="my_very_secret_passphrase"
    psk=ccb290fd4fe6b22935cbae31449e050edd02ad44627b16ce0151668f5f53c01b
}

/etc/network/interfaces ファイルに入れるには、「psk=」から行末までコピーする必要があります。

  1. テキストエディタで/etc/network/interfacesを開きます。

    nano /etc/network/interfaces

  2. ワイヤレスインターフェイスとSSIDとPSK HASHに適したスタンザを定義します。たとえば、

auto wlan0 iface wlan0 inet dhcp wpa-ssid myssid wpa-psk ccb290fd4fe6b22935cbae31449e050edd02ad44627b16ce0151668f5f53c01b

「auto」セクションはシステム起動時にインターフェースを開きます。必要でない場合は、この行を削除またはコメントアウトしてください。

  1. ファイルを保存してエディタを終了します。
  2. インターフェイスを開きます。これにより、wpa_supplicantがバックグラウンドプロセスから始まります。

    # ifup wlan0

関連情報