python服务程序(调用摄像头查看视频和识别二维码)+ Android 客户端程序

本文主要是介绍python服务程序(调用摄像头查看视频和识别二维码)+ Android 客户端程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

运行效果图
这里写图片描述
这里写图片描述

服务器端程序

#!/usr/bin/python
'''
服务器端程序 do_GET() 方法调用webcam摄像头,查看监控视频,同时识别二维码,do_POST()方法连接Mysql数据库,获取数据,并以webservice的形式发布出去供移动客户端与Mysql数据交互。
'''
import cv2
import Image
import threading
from BaseHTTPServer import BaseHTTPRequestHandler,HTTPServer
from SocketServer import ThreadingMixIn
import StringIO
import time
import qrtools
import serial
import MySQLdb
import datetime
import cgi
import random
import stringcapture = None
qr = qrtools.QR()
sr = serial.Serial('/dev/ttyACM0', baudrate=9600, timeout=1)
db = MySQLdb.connect('localhost', 'root', 'root', 'homedb')
cursor = db.cursor()def passwd_generator():s = string.ascii_letters + string.digitsl = len(s)passwd_l = 10return ''.join([s[random.randrange(0, l-1)] for x in range(passwd_l)])class CamHandler(BaseHTTPRequestHandler):def do_GET(self):if self.path.endswith('.mjpg'):self.send_response(200)self.send_header('Content-type','multipart/x-mixed-replace; boundary=--jpgboundary')self.end_headers()while True:try:rc, img = capture.read()if not rc:continueimgRGB = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)jpg = Image.fromarray(imgRGB)tmpFile = StringIO.StringIO()jpg.save(tmpFile,'JPEG')if qr.decode(tmpFile):print(qr.data)''' Verify QR code '''username, passwd = qr.data.trim().split(',')cursor.execute('select * from user where username="' + qr.username + '"')data = cursor.fetchone()if not data:continued = datetime.datetime.now() - data[3]if d < datetime.delta(seconds=10):if passwd == data[2]:''' Open lock via arduino'''if sr.isOpen():sr.write(b'1')self.wfile.write("--jpgboundary")self.send_header('Content-type','image/jpeg')self.send_header('Content-length',str(tmpFile.len))self.end_headers()jpg.save(self.wfile,'JPEG')time.sleep(0.05)except KeyboardInterrupt:breakreturnif self.path.endswith('.html'):self.send_response(200)self.send_header('Content-type','text/html')self.end_headers()with open('front.html', 'r') as f:self.wfile.write(f.read());# self.wfile.write('<html><head></head><body>')self.wfile.write('<img class="img-responsive" src="http://192.168.1.201:8800/cam.mjpg"/>')# self.wfile.write('</body></html>')with open('end.html', 'r') as f:self.wfile.write(f.read())returndef do_POST(self):if self.path == '/authenticate':ctype, pdict = cgi.parse_header(self.headers.getheader('content-type'))if ctype == 'multipart/form-data':postvars = cgi.parse_multipart(self.rfile, pdict)elif ctype == 'application/x-www-form-urlencoded':length = int(self.headers.getheader('content-length'))postvars = cgi.parse_qs(self.rfile.read(length), keep_blank_values=1)else:postvars = {}if postvars:username = postvars['username'][0]print("username=" + username)cursor.execute('select * from user where username=%s', (username, ))d = cursor.fetchone()if d:new_passwd = passwd_generator()print("new passwd=" + new_passwd)# cursor.execute('select * from user')cursor.execute('update user set passwd=%s, last_update=%s where username=%s', (new_passwd, datetime.datetime.now(), username))db.commit()if cursor:self.send_response(200)self.end_headers()self.wfile.write(username + ',' + new_passwd)print("response OK!")returnelse:self.send_response(200)self.send_header('Content-type', 'text/html')self.end_headers()self.wfile.write('<htm><body>Hello world</body></html>')returnclass ThreadedHTTPServer(ThreadingMixIn, HTTPServer):"""Handle requests in a separate thread."""def main():global captureglobal qrglobal srglobal cursorcapture = cv2.VideoCapture(0)capture.set(cv2.CAP_PROP_FRAME_WIDTH, 960);capture.set(cv2.CAP_PROP_FRAME_HEIGHT, 544);capture.set(cv2.CAP_PROP_SATURATION,0.2);global imgtry:server = ThreadedHTTPServer(('192.168.1.201', 8800), CamHandler)print "server started"server.serve_forever()except KeyboardInterrupt:capture.release()server.socket.close()cursor.close()db.close()if __name__ == '__main__':main()

Android 手机客户端程序

Activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:paddingBottom="@dimen/activity_vertical_margin"android:paddingLeft="@dimen/activity_horizontal_margin"android:paddingRight="@dimen/activity_horizontal_margin"android:paddingTop="@dimen/activity_vertical_margin"tools:context="com.example.king.httppostdemo.MainActivity"android:orientation="vertical"><Button
        android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="Click"android:id="@+id/button"android:layout_alignTop="@+id/text1"android:layout_alignParentLeft="true"android:layout_alignParentStart="true" /><TextView
        android:id="@+id/text1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="Hello World!" />
</LinearLayout>

MainActivity.java

package com.example.king.httppostdemo;import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;import java.util.HashMap;public class MainActivity extends Activity {private TextView tv1;private Button bt;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);tv1=(TextView)findViewById(R.id.text1);bt=(Button)findViewById(R.id.button);bt.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {HashMap<String, String> data = new HashMap<String, String>();data.put("username", "hello");AsyncHttpPost asyncHttpPost = new AsyncHttpPost(data);asyncHttpPost.setListener(new AsyncHttpPost.Listener(){@Overridepublic void onResult(String result) {// do something, using return value from networktv1.setText(result);}});asyncHttpPost.execute("http://192.168.1.201:8800/authenticate");}});}}

asyncHttpPost.class

package com.example.king.httppostdemo;import android.os.AsyncTask;import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.StatusLine;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;import java.io.UnsupportedEncodingException;
import java.net.HttpURLConnection;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;/*** Created by king on 16-10-6.*/
class AsyncHttpPost extends AsyncTask<String, String, String> {interface Listener {void onResult(String result);}private Listener mListener;private HashMap<String, String> mData = null;// post data/*** constructor*/public AsyncHttpPost(HashMap<String, String> data) {mData = data;}public void setListener(Listener listener) {mListener = listener;}/*** background*/@Overrideprotected String doInBackground(String... params) {byte[] result = null;String str = "";HttpClient client = new DefaultHttpClient();HttpPost post = new HttpPost(params[0]);// in this case, params[0] is URLtry {// set up post dataArrayList<NameValuePair> nameValuePair = new ArrayList<NameValuePair>();Iterator<String> it = mData.keySet().iterator();while (it.hasNext()) {String key = it.next();nameValuePair.add(new BasicNameValuePair(key, mData.get(key)));}post.setEntity(new UrlEncodedFormEntity(nameValuePair, "UTF-8"));HttpResponse response = client.execute(post);StatusLine statusLine = response.getStatusLine();if(statusLine.getStatusCode() == HttpURLConnection.HTTP_OK){result = EntityUtils.toByteArray(response.getEntity());str = new String(result, "UTF-8");}}catch (UnsupportedEncodingException e) {e.printStackTrace();}catch (Exception e) {}return str;}/*** on getting result*/@Overrideprotected void onPostExecute(String result) {// something...if (mListener != null) {mListener.onResult(result);}}
}

源码(click here)

这篇关于python服务程序(调用摄像头查看视频和识别二维码)+ Android 客户端程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1039097

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为