树莓派3B+ 网页控制GPIO(WebIOPi)

树莓派3B+ 网页控制GPIO(WebIOPi)


对于没接触编程的小白来说,让他们编程控制树莓派的GPIO口输出输入,那简直就是折磨人,WebOPi就是一个开源、方便、实用的网页端控制树莓派GPIO的程序,它不仅自带控制的网页,还可以通过浏览器请求(按照restful标准)直接响应指令,实现远程对树莓派GPIO的控制。

1.什么是WebIOPi?

WebIOPi是一个完美将树莓派的GPIO口控制端和WEB连接的东西,在网页通过对图形按钮的点击,即可在树莓派GPIO口得到响应!
WebIOPi是用python编写,具有加载和执行自定义脚本的功能,使用具有设置和循环功能的全面结构。它具有统一的串行/ SPI / I2C支持和一个完整且一致的功能集控制,支持30多种设备,包括大多数使用的模拟转换器,IOO扩展器和传感器。在网页端支持Javascript / HTML客户端库Web UI,也可在Python / java客户端,苹果或Android应用程序下调用。在COAP支持下带来了最好的物联网协议的PI,PI将是未来发展的重心!

官网:http://webiopi.trouch.com/
本次安装需要的文件打包:
rpi3-webiopi

并提供一个docker:https://hub.docker.com/r/wirthual/rpi-webiopi/

2.安装前准备

对于未更新软件源导致下载失败的,可参考:
修改 国内软件源:http://blog.csdn.net/kxwinxp/article/details/78370980

// 安装python2(安装过的请跳到下一步)
sudo apt-get install -y python-dev
// 安装gpio模块(如果是python3,请修改python-rpi.gpio为python3-rpi.gpio)
sudo apt-get install python-rpi.gpio

如果安装GPIO模块失败,可尝试这方法:

sudo apt-get install python-pip
sudo pip install rpi.gpio

3.安装WebIOPi

// 回到pi用户程序目录
cd ~/application
// 下载WebIOPi
// 或者到这里选择最新版本:https://github.com/thortex/rpi3-webiopi
git clone https://github.com/thortex/rpi3-webiopi.git
cd rpi3-webiopi/webiopi_0.7.1
// 安装
sudo ./setup.sh

可选安装方案二:

// 下载官方webIOPI
cd /home/pi
sudo wget http://sourceforge.net/projects/webiopi/files/WebIOPi-0.7.1.tar.gz
// 解压
tar xvzf WebIOPi-0.7.1.tar.gz
cd WebIOPi-0.7.1
// 下载插件(适配新树莓派)
wget https://raw.githubusercontent.com/doublebind/raspi/master/webiopi-pi2bplus.patch
// 注入脚本
patch -p1 -i webiopi-pi2bplus.patch
// 安装
sudo ./setup.sh

4.运行WebIOPi

//查看帮助
sudo webiopi -h
// 启动到8000端口:
sudo webiopi 8000
// 后台启动:
sudo /etc/init.d/webiopi start
// 开机自启:
sudo update-rc.d webiopi defaults

访问地址(请改成相应的树莓派IP):

http://192.168.1.112:8000

树莓派3B+ 网页控制GPIO(WebIOPi)_第1张图片

5.添加访问认证(可选)

cd /home/pi
sudo wget https://github.com/weaved/installer/raw/master/binaries/weaved-nixinstaller_1.2.13.bin
sudo chmod +x weaved-nixinstaller_1.2.13.bin
sudo ./weaved-nixinstaller_1.2.13.bin

设置完成后,再次访问网页则需要认证

登录账户的用户名: webiopi 密码: raspberry

你可能感兴趣的:(树莓派3B+(⊙o⊙)开源硬件,树莓派3,gpio,WebOPi,远程控制,智能家居)