最最最简单的网页控制wifi程序[1]
受Liuviking启发,我也开始研究乔帮主的网页控制程序,其版面布局功能非常强大,不过也因此需要安装lighttpd,lighttpd-mod-cgi,lighttpd-mod-fastcgi,php5-cgi,php5-fastcgi,libsqlite3等很多程序,造成自行安装比较复杂,配置文件多,一旦出现问题也较难排查,而且需要占比较多的rom,理论上会消耗更多的CPU资源,而且diy玩家也比较难对其进行修改。能不能有一种更简单的网页控制程序呢?Liuviking的ser2net组件虽好,可不能用在web服务器上。我目光转向了luci,openWRT的标准网页管理程序是luci,它是一个web application,既然是web app,那自然本来就有http server和application server了,能不能利用它呢?经过一番研究,发现luci的http server是uhttpd,application是一个比较精简的语言Lua写的,传说中这个Lua语言还比较强大,那应该是没有问题了。不过这个Lua在中国知名度还是比较小,国内的参考资料还是比较少,幸好它是几乎所有东西开源的,Lua, Luci, CGILua等待,很多时候可以上去官网看源代码。
首先要正确安装和启动mjpg-streamer,这个就不多说了。 http://192.168.1.1:8080/?action=stream
压缩包里有3个文件: web2ser,用winSCP上传到路由/www/cgi-bin/目录,并设文件权限“0777”令其可被执行。 wificar,用winSCP上传到路由/etc/init.d/目录,并设权限“0777”令其可被执行,然后还要在putty执行命令/etc/init.d/wificar enable去启用它。 car.htm,这个可以在本地运行,也可以放到/www/目录,通过下面的网址来访问: http://192.168.1.1/car.htm
我们还需要设置串口的速度为9600,stty是Linux的一个核心工具,但openWRT为了精简而默认没有安装,我们需要安装它。 opkg update opkg install coreutils-stty
按键定义和Liuviking的一样,都是发送0-6的字符,应该可以通用。
网页控制篇[2]
由于苦寻乔帮主的wifirobot_car_for26.ipk未果,但是却找到一个wifirobot_1.0_brcm-2.4.ipk的文件,这个是不能在2.6的系统上安装的。虽然已经决定用Liuviking的ser2net方案,但始终还是觉得web版的控制程序有必要,ser2net必须用特定的应用程序来控制,web版只需要一个浏览器即可,还是挺方便的。于是我决定研究wifirobot_1.0_brcm-2.4.ipk这个文件,打算把它移植到2.6的系统。
通过分析,发现乔帮主的程序里安装了下面几个程序,我们首先安装它们。
opkg install lighttpd opkg install lighttpd-mod-cgi opkg install lighttpd-mod-fastcgi opkg install php5-cgi opkg install php5-fastcgi opkg install libsqlite3 opkg install coreutils-stty
用winRAR打开wifirobot_1.0_brcm-2.4.ipk,一直看到有一个data的文件夹,全部解压出来。先修改一下文件/etc/init.d/wifirobot, 串口“tts/0”要改为“ttyS0”,波特率57600要改为9600。
还有app_car.php, app_ir.php,串口“tts/0”要改为“ttyS0”
然后把下面的文件通过WinSCP拷贝上去:
/etc/全部
/web/全部
还要设置权限和启动项,在putty里输入:
chmod 777 /etc/init.d/wifirobot
/etc/init.d/wifirobot enable
首先启动mjpg-streamer,测试一下是否运转:
http://192.168.1.1:8080/?action=stream
然后启动web服务器:
/usr/sbin/lighttpd -f /etc/lighttpd/lighttpd.conf > /dev/tty 2>&1
测试页面:
http://192.168.1.1:81/car.php
如无意外应该就可以看到控制页面了。
再探网页控制篇[3]
之前研究了乔帮主的网页控制程序,其版面布局功能非常强大,不过也因此需要安装lighttpd,lighttpd-mod-cgi,lighttpd-mod-fastcgi,php5-cgi,php5-fastcgi,libsqlite3等很多程序,造成自行安装比较复杂,一旦出现问题也较难排查,而且需要占比较多的rom,理论上会消耗更多的CPU资源,而且diy玩家也比较难对其进行修改。
能不能有一种更简单的网页控制程序呢?Liuviking的ser2net组件虽好,可不能用在web服务器上。我目光转向了luci,openWRT的标准网页管理程序是luci,它是一个web application,既然是web app,那自然本来就有http server和application server了,能不能利用它呢?经过一番研究,发现luci的http server是uhttpd,application是一个比较精简的语言Lua写的,传说中这个Lua语言还比较强大,那应该是没有问题了。
不过这个Lua在中国知名度还是比较小,国内的参考资料还是比较少,幸好它是几乎所有东西开源的,Lua, Luci, CGILua等待,很多时候可以上去官网看源代码。
下面我们来研究怎么实现我们的要求。
首先是Lua的入门,用记事本新建一个test.lua的文件,里面的内容是:
print("hello,lua")
用winSCP上传到路由,上传后修改其属性为"0777",令其可以被执行,然后我们用putty登录,执行命令:
lua test.lua
我们应该可以在屏幕上看到hello,lua这几个字。
然后是测试串口,这个其实非常简单,新建2ser.lua,里面的内容是:
io.output("/dev/ttyS0")
io.write(" test1 ")
上传,改属性,TTL线连接电脑,打开超级终端,putty执行:
lua2ser.lua
就可以在超级终端看到test1这几个字了。
再来就是看看web和Lua是怎么连接的,新建test文件(没有后缀名),内容如下:
#!/usr/bin/lua
print("hello,lua")
保存为UNIX格式(这个可能要UltraEdit或Notepad++等强力编辑工具)
上传到/www/cgi-bin/目录下,改属性,在浏览器查看
http://192.168.1.1/cgi-bin/test
浏览器里应该就可以看到hello,lua这几个字。
web怎么向串口发送数据呢?新2ser文件,内容如下:
#!/usr/bin/lua
io.output("/dev/ttyS0")
io.write(" test1 ")
保存为UNIX格式,上传到/www/cgi-bin/目录下,改属性,TTL线连接电脑,打开超级终端,在浏览器查看
http://192.168.1.1/cgi-bin/2ser
就可以在超级终端看到test1这几个字了。
web怎么接收传递过来的参数呢?
新建webtest文件(没有后缀名),内容如下:
#!/usr/bin/lua
print(os.getenv("QUERY_STRING"))
保存为UNIX格式(这个可能要UltraEdit或Notepad++等强力编辑工具)
上传到/www/cgi-bin/目录下,改属性,在浏览器查看
http://192.168.1.1/cgi-bin/webtest?abc
浏览器里应该就可以看到abc这几个字。
最后就把这些命令组合起来,新web2ser文件,内容如下:
#!/usr/bin/lua
io.output("/dev/ttyS0")
io.write(os.getenv("QUERY_STRING"))
保存为UNIX格式,上传到/www/cgi-bin/目录下,改属性,TTL线连接电脑,打开超级终端,在浏览器查看
http://192.168.1.1/cgi-bin/web2ser?abc
就可以在超级终端看到abc这几个字
我们还需要设置串口的速度为9600,stty是Linux的一个核心工具,但openWRT为了精简而默认没有安装,我们需要安装它。
opkg update
opkg install coreutils-stty
然后加到启动项/etc/init.d/wificar里
/usr/bin/stty -F /dev/ttyS0 raw speed 9600
这是我的wificar文件,如果你没有这个文件,可以新建一个,内容如下
#!/bin/sh /etc/rc.common START=80 start() { /usr/bin/stty -F /dev/ttyS0 raw speed 9600 ser2net -c /etc/ser2net.conf } stop(){ killall mjpg_streamer }
注意保存为UNIX格式,用winSCP上传到路由并设权限“0777”令其可被执行,然后还要执行命令/etc/init.d/wificar enable去启用它。
我们还要写一个网页去整合视频和控制按键。新建一个car.htm文件,内容如下:
<div style="float:left"> <script> function sendSer(value){ document.getElementById("ser").src="http://192.168.1.1/cgi-bin/web2ser?"+value; } </script> <table> <tr><td/><img id="ser" width="1" height="1"> <td><input type="button" onmousedown="sendSer('1')" onmouseup="sendSer('0')" value="前进" /></td><td/></tr> <tr><td><input type="button" onmousedown="sendSer('2')" onmouseup="sendSer('0')" value="左转" /></td><td/> <td><input type="button" onmousedown="sendSer('4')" onmouseup="sendSer('0')" value="右转" /></td></tr> <tr><td/><td><input type="button" onmousedown="sendSer('3')" onmouseup="sendSer('0')" value="后退" /></td><td/></tr> <tr><td colspan="3" align="middle"> <input type="button" onclick="sendSer('5')" value="舵机向上" /></td></tr> <tr><td colspan="3" align="middle"> <input type="button" onclick="sendSer('6')" value="舵机向下" /></td></tr> </table> </div> <div style="float:left"> <iframe width="640" height="480" src="http://192.168.1.1:8080/?action=stream"/> </div>
这个文件可以直接本地运行,也可以放到服务器/www下面,那样就可以通过下面的网址来访问:
http://192.168.1.1/car.htm
由于我的上位机改了,发送的不再限于可见字符,ser2net就没问题,但这个网页版控制程序也需要修改了。 lua真的很强大,只需要几行就搞定了。 在web2ser同一个文件夹下面,新建一个byte2ser文件,设置一样的权限,内容如下:
#!/usr/bin/lua a=os.getenv("QUERY_STRING") io.output("/dev/ttyATH0") for w in string.gmatch(a,"%d+") do io.write(string.char(tonumber(w))) end
a是url的参数,用gmatch提取所有的数字,分别将数字转换为char,发送到ttyATH0,就可以了。 网页控制例子:http://192.168.1.1/cgi-bin/byte2ser?65,66,67 byte2ser接收到参数“65,66,67”,提取出数字65,66,67,并转换为char,"A", "B" 和 “C”,发送到串口。
其实参数里面,所有非数字的字符都可以用来做分隔符,例子用的是逗号“,”,你可以用加号“+”,空格“ ”,或者英文字符都可以,比如下面的参数都可以被识别:
65+66+67 65 66 67 65a66b67
本文章由作者:佐须之男 整理编辑,原文地址: 网页控制Openwrt串口
本站的文章和资源来自互联网或者站长的原创,按照 CC BY -NC -SA 3.0 CN协议发布和共享,转载或引用本站文章应遵循相同协议。如果有侵犯版权的资 源请尽快联系站长,我们会在24h内删除有争议的资源。欢迎大家多多交流,期待共同学习进步。