1.静态文件路径访问
返回URL_name,(a标签,src 静态路由访问)
2.流传输,前端渲染
二进制流返回前端,前端根据二进制流编码类型显示
3.前端js生成
后台获取到微信支付的code_url,前端js将code_url生成二维码,并渲染
使用python_web 框架--》tornado
manager.py
import os import asyncio import tornado.ioloop import tornado.httpserver import tornado.web import tornado.options from tornado.options import define, options, parse_command_line from apps import UrlHandler, Url2Handler, Url3Handler define("port", default=8000, type=int) def create_app(): settings = { "template_path": os.path.join(os.path.dirname(__file__), "templates"), "static_path": os.path.join(os.path.dirname(__file__), "static"), } application = tornado.web.Application( handlers=[ (r"/url", UrlHandler), (r"/url2", Url2Handler), (r"/url3", Url3Handler), ], debug=True, **settings, ) return application if __name__ == '__main__': parse_command_line() app = create_app() server = tornado.httpserver.HTTPServer(app) server.listen(options.port) asyncio.get_event_loop().run_forever()
apps.py
import tornado.web from manager_handler import gen_qrcode, gen_qrcode_obj,gen_qrcode_buf class BaseHandler(tornado.web.RequestHandler): pass class UrlHandler(BaseHandler): def get(self): # 获取链接 self.render('qrcode.html', title="url", data='URL-提交', img_stream='') async def post(self): # 生成二维码 url = self.get_argument('url_str') # URL转换二维码 img_stream = gen_qrcode(url) await self.render('qrcode.html', title="qrcode", data='扫码支付', img_stream=img_stream) class Url2Handler(BaseHandler): def get(self): # 获取链接 self.render('qrcode.html', title="url", data='URL-提交', img_stream='') async def post(self): # 生成二维码 url = self.get_argument('url_str') # URL转换二维码 img_stream = gen_qrcode_obj(url=url) # await self.render('qrcode.html', title="qrcode", data='扫码支付', img_stream=img_stream) self.set_header('Content_Type', 'image/jpg') self.set_header('Content_length', len(img_stream)) self.write(img_stream) class Url3Handler(BaseHandelr): def get(self): self.render('qrcode.html', title="url", data='URL-提交', img_stream='') def post(self): url = self.get_argument('url') img_stream = gen_qrcode_buf(url) self.set_header('Content-Type', 'image/png') self.write(img_stream)
manager_handler.py
import qrcode import io import base64 import time def gen_qrcode(url): """ 方式1: URL转换二维码 :param url: 转换二维码的URL :return: base64编码后的 二进制流 二维码数据 """ qr = qrcode.make(url) buf = io.BytesIO() qr.save(buf) img_buf = buf.getvalue() img_stream = base64.b64encode(img_buf) return img_stream def gen_qrcode_obj(version=1, box_size=10, border=4, url=None): """ 方式2: URL转换二维码(图片流传输, template需要指明 data:base64编码) :param version: :param box_size: :param border: :return: """ qr = qrcode.QRCode( version=version, error_correction=qrcode.constants.ERROR_CORRECT_L, box_size=box_size, border=border, ) url = "https://www.12dms.com" if url is None else url save_name = "./" + "qrcode" + str(time.time()) + ".png" qr.add_data(url) qr.make() img = qr.make_image() img.save(save_name.encode()) with open(save_name, 'rb') as img_f: img_stream = img_f.read() img_stream = base64.b64encode(img_stream) print(img_stream) return img_stream def gen_qrcode_buf(words): qr = qrcode.make(words) buf = io.BytesIO() qr.save(buf, 'png') qr_buf = buf.getvalue() # img_stream = base64.b64encode(qr_buf) return qr_buf
base.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>{% block title %}{% end %}</title> {% block head %}{% end %} </head> <body> <h1 style="text-align: center"> {% block h1 %}{{ data }}{% end %} </h1> {% block content %}{% end %} </body> </html>
qrcode.html
{% extends "base.html" %} {% block title %} {{ title }} {% end %} {% block h1 %} {{ data }} {% end %} {% block content %} <form method="post" action="" > <p> 输入待转换的URL:<input name="url_str"/> <br> {# {{ img_stream }}#} {% if img_stream %} <img style="width:180px" src="data:;base64,{{ img_stream }}" alt=""> {% end %} </p> <br> <input id="submit" type="submit" value="生成二维码"> </form> {% end %}
以上就是python-图片流传输的思路及示例(url转换二维码)的详细内容,更多关于python 图片流传输的资料请关注小牛知识库其它相关文章!
本文向大家介绍python 将dicom图片转换成jpg图片的实例,包括了python 将dicom图片转换成jpg图片的实例的使用技巧和注意事项,需要的朋友参考一下 主要原理:调整dicom的窗宽,使之各个像素点上的灰度值缩放至[0,255]范围内。 使用到的python库:SimpleITK 下面是一个将dicom(.dcm)图片转换成jpg图片的demo: 以上这篇python 将dicom
本文向大家介绍用PHP代替JS玩转DOM的思路及示例代码,包括了用PHP代替JS玩转DOM的思路及示例代码的使用技巧和注意事项,需要的朋友参考一下 事情的起源比较简单,我需要把一个导航页的数据整理好写入数据库。一个比较直观的方法是对html文件进行分析,通用的方法是用php的正则表达式来匹配。但是这样做开发和维护都很困难,代码可读性非常差。 导航页的数据都是规则的排列在DOM树当中的,用JS可以用
本文向大家介绍史上最简洁C# 生成条形码图片思路及示例分享,包括了史上最简洁C# 生成条形码图片思路及示例分享的使用技巧和注意事项,需要的朋友参考一下 在网上看到一些人写关于条形码的代码都很长,有的甚至拿来卖,所以查了下资料,希望能对大家有帮助。 我的实现原理是: 其实Windows本身就有一个字体是用来显示条形码的。 只要将数字改为这种字体就变成了条形码。 windows字体库下
本文向大家介绍java 导入Excel思路及代码示例,包括了java 导入Excel思路及代码示例的使用技巧和注意事项,需要的朋友参考一下 导出就是将List转化为Excel(listToExcel) 导入就是将Excel转化为List(excelToList) 一、思路分析 1、我们要做导入,实际上也就是先文件上传,然后读取文件的数据。 2、我们要有一个导入的模板,因为我们导入的Exce
本文向大家介绍SpringBoot上传图片的示例,包括了SpringBoot上传图片的示例的使用技巧和注意事项,需要的朋友参考一下 说明:通常项目中,如果图片比较多的话,都会把图片放在专门的服务器上,而不会直接把图片放在业务代码所在的服务器上。下面的例子只是为了学习基本流程,所以放在了本地。 1、单张图片上传 1.1、前端用表单提交 前端代码: 后端代码; 1.2、前端用ajax提交 前端代码与上
本文向大家介绍Python实现图片转字符画的示例,包括了Python实现图片转字符画的示例的使用技巧和注意事项,需要的朋友参考一下 字符画真的很有意思,将图片中的像素用字符代替,就生成了字符画。 但是像素是有颜色深浅的,我们如何将带有不同颜色的像素编码为对应的字符呢? 转化方法: 将彩色图片转化为灰度图 根据颜色深浅的RGB值(值域从0到255,其中0为黑色,255为白色) 涉及自己喜欢的字符集合