Wpa_supplicant.conf用法小结

本文详细介绍了如何在Wpa_supplicant中配置WPA2和AES,澄清了常见的误解,提供了实际的配置示例,并解释了关键参数的作用,如ssid、scan_ssid、psk、proto、key_mgmt、pairwise等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Wpa_supplicant是linux系统下一个非常强大的无线网卡管理程序。google搜索到的它似乎不支持WPA2和AES,其实不然,参考它的文档可以发现,WPA2只是RSN的别名,而AES也是CCMP的一部分,所以它们的支持完全是没有问题的。

它的文档看起来非常复杂,其实配置非常简单,下面先给出我的wpa_supplication.conf

ctrl_interface=/var/run/wpa_supplicant
ctrl_interface_group=wheel
update_config=1
 
network={
	ssid="xxxx"
	scan_ssid=1
	psk=xxxxxxxxx37bca5cf24a345f514d319211822f568bba28f8f0b74c894e7644
	proto=RSN
	key_mgmt=WPA-PSK
	pairwise=CCMP
	auth_alg=OPEN
}

解释一下上面的比较容易困惑的地方:
签名三句应该是个模板,没仔细研究过。

network=开始是无线接入点的具体配置,一般的无线接入点可以用wpa_passphrase来自动生成,语法是

继续解释最开始的例子,network=后面的内容

ssid :接入点名称,这个没什么好说的

scan_ssid=1 :这个很容易错过,如果你的无线接入点是隐藏的,那么这个就是必须的,亲身经历,折腾了好久才搞定,记之备忘。

psk=xx :是加密后的密码,用wpa_passphrase自动生成的

proto=RSN WPA2就选这个,抄一下官方配置文件例子里面的:

# proto: list of accepted protocols ---支持的协议列表
# WPA = WPA/IEEE 802.11i/D3.0  
# RSN = WPA2/IEEE 802.11i (also WPA2 can be used as an alias for RSN) ---也能使用WPA2,它只是RSN的一个别名而已
# If not set, this defaults to: WPA RSN   ---如果不设置,默认就是WPA RSN,即全部支持

key_mgmt= 认证密钥管理协议,还是抄:

# key_mgmt: list of accepted authenticated key management protocols  ---支持的协议列表
# WPA-PSK = WPA pre-shared key (this requires 'psk' field)     ---一般都是这个,这就包括了WPA、WPA2开始的那些方式
# WPA-EAP = WPA using EAP authentication    ---这个就是WEP开头的,猜的,求验证
# IEEE8021X = IEEE 802.1X using EAP authentication and (optionally) dynamically
#	generated WEP keys
# NONE = WPA is not used; plaintext or static WEP could be used  ---这个是开放的,没密码,联通、电信之类的就这个
# WPA-PSK-SHA256 = Like WPA-PSK but using stronger SHA256-based algorithms
# WPA-EAP-SHA256 = Like WPA-EAP but using stronger SHA256-based algorithms
# If not set, this defaults to: WPA-PSK WPA-EAP ---如果未设置,默认支持WAP、WEP开头那些

pairwise= 这个就是加密方式,继续抄

# pairwise: list of accepted pairwise (unicast) ciphers for WPA   ---WPA可用的加密方式列表
# CCMP = AES in Counter mode with CBC-MAC [RFC 3610, IEEE 802.11i/D7.0]  ---看到没,这个就是AES,换了马甲而已
# TKIP = Temporal Key Integrity Protocol [IEEE 802.11i/D7.0] ---TKIP 这个倒是没变
# NONE = Use only Group Keys (deprecated, should not be included if APs support
#	pairwise keys)   ---这个估计很少用
# If not set, this defaults to: CCMP TKIP  ---不设置的话是CCMP TKIP,看似正确,其实有些路由器无法自动识别,只能二选一,很坑爹。

好了,其他的不多说了,有兴趣看英文原文吧:

wpa_supplicant官方配置文件(英文)

### 如何配置 `/etc/wpa_supplicant/wpa_supplicant.conf` 文件 在 Linux 或类 Unix 系统中,`/etc/wpa_supplicant/wpa_supplicant.conf` 是用于管理无线网络连接的核心配置文件之一。以下是关于该文件的关键配置项及其说明: #### 基本结构 `wpa_supplicant.conf` 的基本结构由多个部分组成,主要包括全局设置和网络特定的配置。 #### 全局设置 全局设置通常位于文件顶部,定义了一些通用的行为参数。例如: ```plaintext ctrl_interface=/var/run/wpa_supplicant update_config=1 eapol_version=1 ap_scan=1 fast_reauth=1 ``` - `ctrl_interface`: 定义控制接口路径,允许其他程序(如图形界面工具)与 wpa_supplicant 进行通信[^1]。 - `update_config=1`: 启动后允许动态更新此配置文件的内容[^1]。 - `eapol_version`: 设置 EAPOL 协议版本,默认为 1。 - `ap_scan`: 扫描模式的选择,0 表示不扫描,依赖驱动提供 BSS 列表;1 表示主动扫描;2 表示被动扫描[^3]。 - `fast_reauth`: 是否启用快速重新认证机制。 #### 网络配置 每个网络条目以 `network={}` 开始并结束,内部包含一系列键值对来描述具体的网络属性。以下是一个典型的 Wi-Fi 配置示例: ```plaintext network={ ssid="YourNetworkName" psk="YourPassword" key_mgmt=WPA-PSK } ``` - **ssid**: 指定要连接的无线网络名称。 - **psk**: 如果使用 WPA/WPA2 加密,则指定预共享密钥(密码)。也可以通过哈希形式表示复杂密码[^3]。 - **key_mgmt**: 密钥管理方式,常见的有 `NONE`, `WPA-PSK`, 和 `IEEE8021X` 等选项。 对于更复杂的场景可能还需要额外字段比如身份验证方法或者企业级证书等信息。 #### 自动生成过程中的注意事项 实际应用过程中可能会遇到模板生成的情况,在某些 Android 设备上观察到最终生效的实际位置可能是 `/data/misc/wifi/wpa_supplicant.conf` 而非预期的位置 `/etc/wpa_supplicant/wpa_supplicant.conf` 。这是因为系统会基于初始模板 (`wpa_supplicant_template.conf`) 结合运行时状态自动生成目标文件[^2]。 因此如果手动调整了原始模板却未看到效果变化的话,请确认当前操作系统是否采用了类似的自动化流程覆盖默认设定。 #### 示例代码展示 下面给出一段完整的简单例子供参考: ```plaintext # Global configuration options ctrl_interface=/var/run/wpa_supplicant update_config=1 country=CN # Network definitions network={ ssid="HomeWiFi" psk="password1234" proto=RSN key_mgmt=WPA-PSK pairwise=CCMP auth_alg=OPEN } network={ ssid="GuestNet" scan_ssid=1 key_mgmt=NONE } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值