|
本帖最后由 qtsharp 于 2012-10-27 10:49 编辑
原文:http://www.cnblogs.com/qtsharp/archive/2012/10/26/2740924.html
使用的工具:
树莓派+python+django+pyserial+STC89C52单片机。
树莓派通过usb转串口与单片机,linux上自带usb转串口芯片的驱动,真爽!
网页与后台使用django,通过django调用pyserial库向单片机发送命令。
基于这种原型,可以很方便的利用手机浏览器控制家里的电器,好好利用django的账户安全功能,又可以做到远程控制需要的安全保密性!
树莓派+python+django+pyserial这个方案,是我认为在学习成本、搭建速度、开发速度、安全性、易用度、客户端无关性方面比较完美的集合。
视频里使用的手机QQ浏览器,由于手机网络不给力,并且又通过qq服务器压缩转发,所以能看出延迟,如果用电脑操作效果更好。
1、这个方案其实完全可以拿掉单片机,直接将python+django+rpi.gpio结合可以做同样的事,一个树莓派结合继电器就可以做远程网页控制了。
2、但是直接通过单片机利用蓝牙芯片进行串口连接,可以降低无线控制系统的成本。
3、由于网页使用python语言编写,所以可以十分方便的进行本地操作,更有超多的现成库,可实现的功能远远比网页脚本语言强大得多。
4、估计没几个能有比django的admin模块更简单的健全的账户安全系统了。
5、其实整个系统的核心就在django上,所以这个系统运行在任何一个linux终端上上均可以,不单单是树莓派。
6、但是树莓派最大的优势就是低功耗,高度优化的系统和rpi.gpio,作为一个日常低负载的服务器没有人会不喜欢——如果CPU能再给力点的话。
相关资料:
1、django教程:http://djangobook.py3k.cn/2.0/ 如果碰到无法理解的问题,别急,去https://docs.djangoproject.com/en/1.4/找找答案。
2、51单片机的串口例程:http://www.elecfans.com/emb/danpianji/20110509197678.html
3、PySerial方面完全可以用这里的代码:http://www.shumeipai.net/read.php?tid=1118&ds=1#11689
4、下面贴一下django里的部分app代码:
[pre lang="ython" line="1"]control.py:
#!/usr/bin/env python
import serial
class Control():
def __init__(self,device='/dev/ttyUSB0',BAUD=4800):
self.client = serial.Serial(device,BAUD,timeout=1)
def command(self,CMD):
try:
self.client.write(CMD)
self.client.close()
except:
pass
views.py:
from django.shortcuts import render_to_response
from django.template import RequestContext
from django.http import HttpResponse,HttpResponseRedirect, Http404
from control import Control
def control(request):
DEMO=None
if request.method == 'POST':
if 'CMD' in request.POST:
CON = Control()
CMD = request.POST['CMD']
CON.command(CMD)
if 'demo' in request.POST:
DEMO=request.POST['demo']
if 'not_demo' in request.POST:
DEMO=None
return render_to_response('controller.html', {'demo'EMO}, context_instance=RequestContext(request))[/code]
再贴上有点偏离主题的视频里示范网页的html模板代码:
[pre lang="html" line="1"]{% extends "basepage.html" %}
{% block title %}远程控制{% endblock %}
{% block content %}
{% if not demo %}
<form action="" method="post">{% csrf_token %}
<p><input type="submit" name='demo' title='视频演示' accesskey="y" value="视频演示"></button></p>
</form>
<form action="" method="post">{% csrf_token %}
<p><input type="submit" name='CMD' title='开' accesskey="k" value="01">开</button></p>
<p><input type="submit" name='CMD' title='关' accesskey="g" value="00">关</button></p>
<p><input type="submit" name='CMD' title='闪' accesskey="s" value="88">闪</button></p>
</form>
{% endif %}
{% if demo %}
<form action="" method="post">{% csrf_token %}
<p><input type="submit" name='not_demo' title='返回控制' accesskey="f" value="返回控制"></button></p>
</form>
<br>
<embed src="http://player.youku.com/player.php/sid/XNDY2Nzg2NjI0/v.swf" allowFullScreen="true" quality="high" width="480" height="400" align="middle" allowScriptAccess="always" type="application/x-shockwave-flash"></embed>
{% endif %}
{% endblock%}[/code]
|
|