欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python Tornado批量上傳圖片并顯示功能

 更新時間:2020年03月26日 10:42:37   作者:XerCis  
Tornado龍卷風是一個開源的網(wǎng)絡(luò)服務(wù)器框架,它是基于社交聚合網(wǎng)站FriendFeed的實時信息服務(wù)開發(fā)而來的。這篇文章主要介紹了Python Tornado批量上傳圖片并顯示,需要的朋友可以參考下

簡介

Tornado龍卷風是一個開源的網(wǎng)絡(luò)服務(wù)器框架,它是基于社交聚合網(wǎng)站FriendFeed的實時信息服務(wù)開發(fā)而來的。2007年由4名Google前軟件工程師一起創(chuàng)辦了FriendFeed,旨在使用戶能夠方便地跟蹤好友在Facebook和Twitter等多個社交網(wǎng)站上的活動。結(jié)果兩年后,F(xiàn)acebook宣布收購FriendFeed,交易價格約為5000萬美元。而此時FriendFeed只有12名員工。據(jù)說這幫人后來又到了Google,搞出了現(xiàn)在的Google App Engine...

我們開發(fā)這個Web服務(wù)器的主要目的就是為了處理FriendFeed的實時功能 -- 在FriendFeed的應(yīng)用里每個活動用戶都會保持著一個服務(wù)器連接。

Tornado使FriendFeed使用的可擴展的非阻塞Web服務(wù)器及其相關(guān)工具的開源版本,這個Web框架看起來有些像web.py或 Google的webapp,不過為了更加有效地利用非阻塞服務(wù)器環(huán)境,Tornado這個Web框架還包含了一些相關(guān)的有用工具和優(yōu)化。

區(qū)別

Tornado與現(xiàn)代主流的Web服務(wù)器框架有著明顯的區(qū)別:它使非阻塞式的服務(wù)器,速度相當快。這得益于其非阻塞的方式和對epoll的運用。Tornado每秒可以處理數(shù)以千計的連接,對于實時Web服務(wù)來說Tornado確實是一個理想的Web框架。

與Node.js相同的是,Tornado也采用的是單進程單線程異步IO的網(wǎng)絡(luò)模型,它們都可以編寫異步非阻塞的程序。但由于Node.js是Google Chrome V8引擎的JS運行環(huán)境或工具包,它屬于偏底層的抽象,擴展了JS編寫服務(wù)器程序的能力,所以基于Node.js會由不同的Web框架。從這個角度來看Node.js和Tornado其實并不在一個層次上。

Tornado是使用Python編寫的Web服務(wù)器兼Web應(yīng)用框架,與主流Web服務(wù)器框架不同的是,Tornado是異步非阻塞式服務(wù)器,得益于非阻塞式和對epoll模型的運用,Tornado是實時Web服務(wù)的一個理想框架,它非常適合開發(fā)長輪詢、WebSocket和需要與每個用戶建立持久連接的應(yīng)用。

特點

  • 輕量級Web框架
  • 異步非阻塞IO處理方式
  • Tornado采用的單進程單線程異步IO的網(wǎng)絡(luò)模式,其高性能源于Tornado基于Linux的Epoll(UNIX為kqueue)的異步網(wǎng)絡(luò)IO。
  • 出色的抗負載能力
  • 不依賴多進程或多線程
  • WSGI全棧替代產(chǎn)品
  • WSGI把應(yīng)用(Application)和服務(wù)器(Server)結(jié)合起來,Tornado既可以是WSGI應(yīng)用也可以是WSGI服務(wù)。
  • 既是WebServer也是WebFramework

Tornado是基于Bret Taylor和其他人員為FrientFeed所開發(fā)的網(wǎng)絡(luò)服務(wù)框架,當FriendFeed被Facebook收購后得以開源。不同于那些最多只能達到1w并發(fā)連接的傳統(tǒng)網(wǎng)絡(luò)服務(wù)器。Tornado在設(shè)計之初就考慮到了性能因素,旨在解決C10K問題,這樣的設(shè)計使其成為一個擁有高性能的框架。

正文開始

問題描述

Python Tornado批量上傳圖片并顯示,前后端都要顯示

思路

1.文件上傳

前端FormData上傳,后端BytesIO解析

2.顯示圖片

前端FileReader讀取顯示,后端matplotlib顯示

代碼

index.html

<!DOCTYPE html>
<head>
 <title>批量上傳圖片并顯示</title>
 <meta charset='utf-8'>
 <script src='https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js'></script>
</head>

<body>
<input id='send' type='file' accept="image/png, image/jpeg" multiple><br>
</body>
<script>
 $('#send').change(function () {
  var files = $('#send')[0].files;
  var form = new FormData();
  for (var i = 0; i < files.length; i++) {
   //插入form
   var file = files[i];
   console.log(file);
   form.append('files', file);
   //顯示圖片
   var fileReader = new FileReader();
   fileReader.readAsDataURL(file);
   fileReader.onloadend = function (event) {
    var src = event.target.result;
    $('body').append('<img src=' + src + ' width=200px>');
   }
  }

  //上傳
  $.ajax({
   type: 'POST',
   url: '/upload',
   data: form,
   processData: false,
   contentType: false,
   success: function (response) {
    console.log(response)
   }
  });
 })
</script>
</html>

app.py

import tornado.web
import tornado.ioloop
from PIL import Image
from io import BytesIO
import matplotlib.pyplot as plt
from tornado.options import define, options

define("port", default=8888, help="運行端口", type=int)

class MainHandler(tornado.web.RequestHandler):
 def get(self):
  self.render("index.html")
class UploadHandler(tornado.web.RequestHandler):
 def post(self):
  files = self.request.files['files']
  for file in files:
   img = file['body']
   img = Image.open(BytesIO(img)).convert('RGB')
   plt.imshow(img)
   plt.show()

if __name__ == "__main__":
 app = tornado.web.Application(
  [
   (r"/", MainHandler),
   (r"/upload", UploadHandler),
  ],
 )
 app.listen(options.port)
 print("http://localhost:{}/".format(options.port))
 tornado.ioloop.IOLoop.current().start()

效果

前端

在這里插入圖片描述

后端

在這里插入圖片描述

總結(jié)

到此這篇關(guān)于Python Tornado批量上傳圖片并顯示功能的文章就介紹到這了,更多相關(guān)python tornado批量上傳內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python爬蟲_城市公交、地鐵站點和線路數(shù)據(jù)采集實例

    Python爬蟲_城市公交、地鐵站點和線路數(shù)據(jù)采集實例

    下面小編就為大家分享一篇Python爬蟲_城市公交、地鐵站點和線路數(shù)據(jù)采集實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • 探究Python中isalnum()方法的使用

    探究Python中isalnum()方法的使用

    這篇文章主要介紹了探究Python中isalnum()方法的使用,是Python入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-05-05
  • Pytorch maxpool的ceil_mode用法

    Pytorch maxpool的ceil_mode用法

    今天小編就為大家分享一篇Pytorch maxpool的ceil_mode用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • Python Web日志管理與監(jiān)控實踐指南

    Python Web日志管理與監(jiān)控實踐指南

    這篇文章主要介紹了Python Web日志管理與監(jiān)控實踐指南,文中通過代碼示例講解的非常詳細,對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-09-09
  • Python利用matplotlib實現(xiàn)制作動態(tài)條形圖

    Python利用matplotlib實現(xiàn)制作動態(tài)條形圖

    說到用 Python 制作動態(tài)圖,首先想到的肯定是一些直接拿來就用的庫,雖然我沒做過,但是我相信一定有且不止一個,搜了一圈后發(fā)現(xiàn)有個bar chart race庫看起來不錯,感興趣的可以跟隨小編一起學(xué)習(xí)一下
    2022-10-10
  • Python桌面應(yīng)用開發(fā)實戰(zhàn)之PyQt的安裝使用

    Python桌面應(yīng)用開發(fā)實戰(zhàn)之PyQt的安裝使用

    這篇文章主要給大家介紹了關(guān)于Python桌面應(yīng)用開發(fā)實戰(zhàn)之PyQt的安裝使用,PyQt是一個功能強大的Python庫,用于創(chuàng)建圖形用戶界面(GUI)應(yīng)用程序,需要的朋友可以參考下
    2023-08-08
  • Python實現(xiàn)字典(dict)的迭代操作示例

    Python實現(xiàn)字典(dict)的迭代操作示例

    這篇文章主要介紹了Python實現(xiàn)字典(dict)的迭代操作,結(jié)合實例形式分析了Python針對字典鍵、值以及鍵值對等迭代操作實現(xiàn)技巧,需要的朋友可以參考下
    2018-06-06
  • python使用正則表達式的search()函數(shù)實現(xiàn)指定位置搜索功能

    python使用正則表達式的search()函數(shù)實現(xiàn)指定位置搜索功能

    SEARCH函數(shù),函數(shù)名。主要用來返回指定的字符串在原始字符串中首次出現(xiàn)的位置 ,從左到右查找,忽略英文字母的大小寫。接下來通過本文給大家介紹python使用正則表達式的search()函數(shù)實現(xiàn)指定位置搜索功能,需要的朋友一起看看吧
    2017-11-11
  • python爬取某網(wǎng)站原圖作為壁紙

    python爬取某網(wǎng)站原圖作為壁紙

    之前已經(jīng)爬取過網(wǎng)站上的圖片,貌似很簡單可是他喵的都像馬賽克一樣,怎么能用做壁紙呢通過多重審查發(fā)現(xiàn),原圖地址藏在更深的地方 所以,來爬一下原圖吧,需要的朋友可以參考下
    2021-06-06
  • Django中url與path及re_path的區(qū)別說明

    Django中url與path及re_path的區(qū)別說明

    這篇文章主要介紹了Django中url與path及re_path的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03

最新評論