RaspAP 是一个可以将树莓派轻松部署成无线 AP(Access Point)的软件方案,具有一套响应式的 WebUI 来控制 WiFi,用起来和家用路由器一样方便。RaspAP 可以运行在 Raspbian 上,只需要先给树莓派安装好 Raspbian 系统,再通过快速安装脚本就可以轻松完成 RaspAP 的安装和配置。
下面我们介绍一下 RaspAP 的安装配置方法。
准备工作
全新安装 Raspbian,建议使用最新的版本。
https://shumeipai.nxez.com/2013/09/07/how-to-install-and-activate-raspberry-pi.html
建议更新 Raspbian,包括核心和固件,然后重启系统:
1
2
3
|
sudo
apt-get update
sudo
apt-get dist-upgrade
sudo
reboot
|
运行 sudo raspi-config 命令,在设置 Localisation Options 菜单中设置 WiFi 地区。
如果你使用的是没有集成无线网卡的老版本树莓派,则需要自行准备一个 USB 的无线网卡。
完成上面这些准备工作之后,就可以开始下面的步骤进行快速安装了。
快速安装
下面提供了一个安装脚本,只需要一行命令就可以完成 RaspAP 的快速安装:
1
|
wget -q https:
//git
.io
/voEUQ
-O
/tmp/raspap
&&
bash
/tmp/raspap
|
安装程序会帮你完成所有需要手动安装的步骤(见下文)。
安装完成之后重启树莓派,无线网卡默认会被配置为热点:
IP 地址: 10.3.141.1
登录用户名: admin
登录密码: secret
DHCP 范围: 10.3.141.50 至 10.3.141.255
SSID: raspi-webgui
WiFi 密码: ChangeMe
AP – WiFi 客户端模式
RaspAP 允许你将树莓派通过有线网卡接入网络的同时,利用无线网卡去开启 AP 模式,实现对网络的共享。在 Configure hotspot 的 Advanced 标签栏中启用 AP,然后保存设置来启动热点,无须重启树莓派。
手动安装
尽管上面已经提供了自动化的安装脚本,但是为了便于理解,下面将介绍手动安装 RaspAP 的方法。
这些步骤适用于最新的 Raspbian Buster 版本,如果你用更早的 Raspbian 版本,则需要先安装好 git、lighttpd、php7、hostapd 和 dnsmasq。
1
|
sudo
apt-get
install
git lighttpd php7.1-cgi hostapd dnsmasq vnstat
|
注意:在 Raspbian Stretch 中,需要用 php7.0-cgi 替换以上命令中的 php7.1-cgi;而对于 Raspbian Jessie 或更早的版本,需要用 php5-cgi 替换以上命令中的 php7.1-cgi。启用 lighttpd 的 PHP 并重启 lighttpd 使设置生效:
1
2
|
sudo
lighttpd-
enable
-mod fastcgi-php
sudo
service lighttpd restart
|
为 www-data 用户添加对 sudoers 文件的访问权限。使用 nano 编辑器将下面的内容添加到 /etc/sudoers 文件的末尾:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
www-data ALL=(ALL) NOPASSWD:/sbin/ifdown
www-data ALL=(ALL) NOPASSWD:/sbin/ifup
www-data ALL=(ALL) NOPASSWD:/bin/cat /etc/wpa_supplicant/wpa_supplicant.conf
www-data ALL=(ALL) NOPASSWD:/bin/cat /etc/wpa_supplicant/wpa_supplicant-wlan[0-9].conf
www-data ALL=(ALL) NOPASSWD:/bin/cp /tmp/wifidata /etc/wpa_supplicant/wpa_supplicant.conf
www-data ALL=(ALL) NOPASSWD:/bin/cp /tmp/wifidata /etc/wpa_supplicant/wpa_supplicant-wlan[0-9].conf
www-data ALL=(ALL) NOPASSWD:/sbin/wpa_cli -i wlan[0-9] scan_results
www-data ALL=(ALL) NOPASSWD:/sbin/wpa_cli -i wlan[0-9] scan
www-data ALL=(ALL) NOPASSWD:/sbin/wpa_cli -i wlan[0-9] reconfigure
www-data ALL=(ALL) NOPASSWD:/bin/cp /tmp/hostapddata /etc/hostapd/hostapd.conf
www-data ALL=(ALL) NOPASSWD:/etc/init.d/hostapd start
www-data ALL=(ALL) NOPASSWD:/etc/init.d/hostapd stop
www-data ALL=(ALL) NOPASSWD:/etc/init.d/dnsmasq start
www-data ALL=(ALL) NOPASSWD:/etc/init.d/dnsmasq stop
www-data ALL=(ALL) NOPASSWD:/bin/cp /tmp/dhcpddata /etc/dnsmasq.conf
www-data ALL=(ALL) NOPASSWD:/sbin/shutdown -h now
www-data ALL=(ALL) NOPASSWD:/sbin/reboot
www-data ALL=(ALL) NOPASSWD:/sbin/ip link set wlan[0-9] down
www-data ALL=(ALL) NOPASSWD:/sbin/ip link set wlan[0-9] up
www-data ALL=(ALL) NOPASSWD:/sbin/ip -s a f label wlan[0-9]
www-data ALL=(ALL) NOPASSWD:/bin/cp /etc/raspap/networking/dhcpcd.conf /etc/dhcpcd.conf
www-data ALL=(ALL) NOPASSWD:/etc/raspap/hostapd/enablelog.sh
www-data ALL=(ALL) NOPASSWD:/etc/raspap/hostapd/disablelog.sh
www-data ALL=(ALL) NOPASSWD:/etc/raspap/hostapd/servicestart.sh
|
修改完成之后,git clone Web 文件到 /var/www/html 路径下:
1
2
|
sudo
rm
-rf
/var/www/html
sudo
git clone https:
//github
.com
/billz/raspap-webgui
/var/www/html
|
将图标资源移动到 Web 根目录。
1
|
sudo
mv
/var/www/html/dist/icons/
*
/var/www/html
|
修改文件的所有者为 www-data 用户。
1
|
sudo
chown
-R www-data:www-data
/var/www/html
|
将 RaspAP 的配置文件移动到正确的位置。
1
2
3
|
sudo
mkdir
/etc/raspap
sudo
mv
/var/www/html/raspap
.php
/etc/raspap/
sudo
chown
-R www-data:www-data
/etc/raspap
|
将 HostAPD 日志和服务控制脚本移动到正确的位置。
1
2
3
|
sudo
mkdir
/etc/raspap/hostapd
sudo
mv
/var/www/html/installers/
*log.sh
/etc/raspap/hostapd
sudo
mv
/var/www/html/installers/service
*.sh
/etc/raspap/hostapd
|
修改日志和服务控制脚本的拥有者和读写执行权限。
1
2
|
sudo
chown
-c root:www-data
/etc/raspap/hostapd/
*.sh
sudo
chmod
750
/etc/raspap/hostapd/
*.sh
|
在 /etc/rc.local 的 exit 0 之前添加下面的内容:
1
2
3
|
echo
1 >
/proc/sys/net/ipv4/ip_forward
#RASPAP
iptables -t nat -A POSTROUTING -j MASQUERADE
#RASPAP
iptables -t nat -A POSTROUTING -s 192.168.50.0
/24
! -d 192.168.50.0
/24
-j MASQUERADE
#RASPAP
|
强制载入 /etc/rc.local 让配置生效。
1
2
|
sudo
systemctl restart rc-
local
.service
sudo
systemctl daemon-reload
|
取消对热点服务的屏蔽,并启用热点。
1
2
|
sudo
systemctl unmask hostapd.service
sudo
systemctl
enable
hostapd.service
|
将 raspap 服务移动到正确的位置并启用。
1
2
|
sudo
mv
/var/www/html/installers/raspap
.service
/lib/systemd/system
sudo
systemctl
enable
raspap.service
|
重启树莓派,RaspAP 将自动运行!
1
|
sudo
reboot
|
RaspAP 默认的登录用户名是 admin,默认密码是 secret。
可选服务
OpenVPN 和 TOR 作为两个附加服务,可以通过简单的设置开启。
修改 /var/www/html/includes/config.php 文件中下面的两行即可。
1
2
3
|
// Optional services, set to true to enable.
define('RASPI_OPENVPN_ENABLED', false );
define('RASPI_TORPROXY_ENABLED', false );
|
GitHub:https://github.com/billz/raspap-webgui/
FAQ:https://github.com/billz/raspap-webgui/wiki/FAQs