亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python Flask框架開(kāi)發(fā)之運(yùn)用SocketIO實(shí)現(xiàn)WebSSH方法詳解

 更新時(shí)間:2022年10月08日 16:27:35   作者:LyShark 孤風(fēng)洗劍  
Socket.IO本是一個(gè)面向?qū)崟r(shí)web應(yīng)用的JavaScript庫(kù),現(xiàn)在已成為擁有眾多語(yǔ)言支持的Web即時(shí)通訊應(yīng)用的框架。這篇文章主要介紹了Python 運(yùn)用SocketIO實(shí)現(xiàn)WebSSH方法

Flask 框架中如果想要實(shí)現(xiàn)WebSocket功能有許多種方式,運(yùn)用SocketIO庫(kù)來(lái)實(shí)現(xiàn)無(wú)疑是最簡(jiǎn)單的一種方式,F(xiàn)lask中封裝了一個(gè)flask_socketio庫(kù)該庫(kù)可以直接通過(guò)pip倉(cāng)庫(kù)安裝,如下內(nèi)容將重點(diǎn)簡(jiǎn)述SocketIO庫(kù)在Flask框架中是如何被應(yīng)用的,最終實(shí)現(xiàn)WebSSH命令行終端功能,其可用于在Web瀏覽器內(nèi)實(shí)現(xiàn)SSH命令行執(zhí)行。

首先我們先來(lái)看一下SocketIO庫(kù)是如何進(jìn)行通信的,對(duì)于前端部分需要引入socket.io這個(gè)框架,然后就是利用該框架內(nèi)提供的各類函數(shù)實(shí)現(xiàn)創(chuàng)建WS通道,如下代碼:

代碼中通過(guò)調(diào)用io.connect來(lái)連接后端,socket.emit則是用于向后端推送一條消息,而socket.on則是一個(gè)回調(diào)函數(shù),一旦有數(shù)據(jù)被傳出則第一時(shí)間執(zhí)行回調(diào)函數(shù)內(nèi)的代碼。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <script type="text/javascript" src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
    <script type="text/javascript" src="https://cdn.lyshark.com/javascript/socket.io/socket.io.min.js"></script>
</head>
<body>
<script type="text/javascript" charset="UTF-8">
    $(document).ready(function() {
        namespace = '/Socket';
        var socket = io.connect("http://" + document.domain + ":" + location.port + namespace);
        // 初始化完成后,發(fā)送一條消息
        socket.emit("message",{"data":"hello lyshark"});
        // 收到數(shù)據(jù)后,執(zhí)行輸出
        socket.on('response', function(recv) {
            console.log('hello lyshark ' + recv.Data)
        });
    });
</script>
</body>
</html>

接著就是后端,后端部分代碼如下所示,代碼中app.config['SECRET_KEY']是配置一個(gè)安全密鑰這里可以隨意填寫,通過(guò)socketio = SocketIO(app)初始化一個(gè)SOCKET對(duì)象,當(dāng)有消息出現(xiàn)時(shí)SocketIO會(huì)自動(dòng)執(zhí)行相應(yīng)的處理函數(shù),常見(jiàn)的處理方法也就如下這三種。

  • message 出現(xiàn)消息后,率先執(zhí)行此處
  • connect 當(dāng)websocket連接成功時(shí),自動(dòng)觸發(fā)connect默認(rèn)方法
  • disconnect 當(dāng)websocket連接失敗時(shí),自動(dòng)觸發(fā)disconnect默認(rèn)方法
from flask import Flask,render_template,request
from flask_socketio import SocketIO
async_mode = None
app = Flask(import_name=__name__,
            static_url_path='/python',   # 配置靜態(tài)文件的訪問(wèn)url前綴
            static_folder='static',      # 配置靜態(tài)文件的文件夾
            template_folder='templates') # 配置模板文件的文件夾
app.config['SECRET_KEY'] = "lyshark"
socketio = SocketIO(app)
@app.route("/")
def index():
    return render_template("index.html")
# 出現(xiàn)消息后,率先執(zhí)行此處
@socketio.on("message",namespace="/Socket")
def socket(message):
    print("接收到消息:",message['data'])
    for i in range(1,100):
        socketio.sleep(1)
        socketio.emit("response",           # 綁定通信
                      {"Data":i},           # 返回socket數(shù)據(jù)
                      namespace="/Socket")
# 當(dāng)websocket連接成功時(shí),自動(dòng)觸發(fā)connect默認(rèn)方法
@socketio.on("connect",namespace="/Socket")
def connect():
    print("鏈接建立成功..")
# 當(dāng)websocket連接失敗時(shí),自動(dòng)觸發(fā)disconnect默認(rèn)方法
@socketio.on("disconnect",namespace="/Socket")
def disconnect():
    print("鏈接建立失敗..")
if __name__ == '__main__':
    socketio.run(app,debug=True,host="0.0.0.0")

如上就是前后端所有的代碼,當(dāng)我們運(yùn)行Flask后端時(shí),打開(kāi)前端頁(yè)面并查看控制臺(tái),可以看到效果,后臺(tái)會(huì)每隔一段時(shí)間自動(dòng)向前端推送一個(gè)消息此時(shí)這個(gè)通道也算是建立成功了。

原理明白了以后,再去實(shí)現(xiàn)一個(gè)WebSSH終端就會(huì)變得很容易,WebSSH終端我們需要xterm這個(gè)前端庫(kù)來(lái)實(shí)現(xiàn),其原理就是當(dāng)后臺(tái)有數(shù)據(jù)輸出或前臺(tái)有輸入時(shí)第一時(shí)間傳遞給SSH模塊執(zhí)行然后返回結(jié)果,我們先來(lái)看前端部分是如何實(shí)現(xiàn)這段功能的。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <script type="text/javascript" src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
    <script type="text/javascript" src="https://cdn.lyshark.com/javascript/socket.io/socket.io.min.js"></script>
    <link rel="stylesheet"  rel="external nofollow"  />
    <link rel="stylesheet"  rel="external nofollow"  />
    <script type="text/javascript" src="https://cdn.lyshark.com/javascript/xterm/xterm.js"></script>
</head>
<body>
    <div id="terminal"></div>
    <script>
      var window_width = $(window).width();
      var window_height = $(window).height();
      var term = new Terminal(
            {
                cols: Math.floor(window_width/9),
                rows: Math.floor(window_height/20),
                useStyle:false,
                convertEol: true,
                cursorBlink:true,
                cursorStyle:null,
            });
        console.log("高度" + window_height + "寬度" + window_width);
        $(document).ready(function() {
            namespace = '/Socket';
            var socket = io.connect("http://" + document.domain + ":" + location.port + namespace);
            socket.on("connect",function(){
                term.open(document.getElementById('terminal'));
            });
            // 接受后端數(shù)據(jù),并寫到控制臺(tái)
            socket.on("response",function(recv){
                term.write(recv.Data);
            });
            // 發(fā)送消息到對(duì)端
            term.on("data",function(data){
               socket.send(data);
               //socket.emit("message",{"data":data});
            });
        });
</script>
</body>
</html>

上方代碼中當(dāng)鏈接SOCKET成功后,則socket.on("response",function(recv)用于接收后臺(tái)的輸出,一旦后臺(tái)有輸出數(shù)據(jù)則直接調(diào)用term.write(recv.Data);將該數(shù)據(jù)寫出到控制臺(tái),而term.on則是xterm中提供的接收方法,其作用是接收用戶的輸入并將該輸入傳遞給后臺(tái)來(lái)處理。

那后臺(tái)是如何處理的呢,其實(shí)后端只是使用paramiko模塊建立一個(gè)SSH隧道,并在message函數(shù)內(nèi)處理發(fā)送接收數(shù)據(jù)。

from flask import Flask,render_template,request
from flask_socketio import SocketIO
import paramiko
async_mode = None
app = Flask(import_name=__name__,
            static_url_path='/python',   # 配置靜態(tài)文件的訪問(wèn)url前綴
            static_folder='static',      # 配置靜態(tài)文件的文件夾
            template_folder='templates') # 配置模板文件的文件夾
app.config['SECRET_KEY'] = "lyshark"
socketio = SocketIO(app)
def ssh_cmd():
    tran = paramiko.Transport(('192.168.150.129', 22,))
    tran.start_client()
    tran.auth_password('root', '1233')
    chan = tran.open_session()
    chan.get_pty(height=492,width=1312)
    chan.invoke_shell()
    return chan
sessions = ssh_cmd()
@app.route("/")
def index():
    return render_template("index.html")
# 出現(xiàn)消息后,率先執(zhí)行此處
@socketio.on("message",namespace="/Socket")
def socket(message):
    print("接收到消息:",message)
    sessions.send(message)
    ret = sessions.recv(4096)
    socketio.emit("response", {"Data": ret.decode("utf-8")}, namespace="/Socket")
    print(message)
# 當(dāng)websocket連接成功時(shí),自動(dòng)觸發(fā)connect默認(rèn)方法
@socketio.on("connect",namespace="/Socket")
def connect():
    ret = sessions.recv(4096)
    socketio.emit("response", {"Data": ret.decode("utf-8")}, namespace="/Socket")
    print("鏈接建立成功..")
# 當(dāng)websocket連接失敗時(shí),自動(dòng)觸發(fā)disconnect默認(rèn)方法
@socketio.on("disconnect",namespace="/Socket")
def disconnect():
    print("鏈接建立失敗..")
if __name__ == '__main__':
    socketio.run(app,debug=True,host="0.0.0.0")

代碼運(yùn)行后我們?cè)L問(wèn)Web頁(yè)面,即可成功登錄到Linux主機(jī),并執(zhí)行任意命令。

當(dāng)執(zhí)行輸出目錄時(shí)也是帶有顏色的,顏色的上色部分是xterm中自帶的并不需要自己去配置。

到此這篇關(guān)于Python Flask框架開(kāi)發(fā)之運(yùn)用SocketIO實(shí)現(xiàn)WebSSH方法詳解的文章就介紹到這了,更多相關(guān)Python SocketIO實(shí)現(xiàn)WebSSH內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決python 使用openpyxl讀寫大文件的坑

    解決python 使用openpyxl讀寫大文件的坑

    這篇文章主要介紹了解決python 使用openpyxl讀寫大文件的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-03-03
  • Python 多進(jìn)程、多線程效率對(duì)比

    Python 多進(jìn)程、多線程效率對(duì)比

    這篇文章主要介紹了Python 多進(jìn)程、多線程的效率對(duì)比,幫助大家選擇適合的技術(shù),感興趣的朋友可以了解下
    2020-11-11
  • Python Merge函數(shù)原理及用法解析

    Python Merge函數(shù)原理及用法解析

    這篇文章主要介紹了Python Merge函數(shù)原理及用法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • 淺談Python類的__getitem__和__setitem__特殊方法

    淺談Python類的__getitem__和__setitem__特殊方法

    下面小編就為大家?guī)?lái)一篇淺談Python類的__getitem__和__setitem__特殊方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-12-12
  • python之singledispatch單分派問(wèn)題

    python之singledispatch單分派問(wèn)題

    這篇文章主要介紹了python之singledispatch單分派問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • python判斷、獲取一張圖片主色調(diào)的2個(gè)實(shí)例

    python判斷、獲取一張圖片主色調(diào)的2個(gè)實(shí)例

    一幅圖片,想通過(guò)程序判斷獲得其主要色調(diào),應(yīng)該怎么樣處理?本文通過(guò)python實(shí)現(xiàn)判斷、獲取一張圖片的主色調(diào)方法,需要的朋友可以參考下
    2014-04-04
  • Python操作Mysql實(shí)例代碼教程在線版(查詢手冊(cè))

    Python操作Mysql實(shí)例代碼教程在線版(查詢手冊(cè))

    本文介紹了Python操作MYSQL、執(zhí)行SQL語(yǔ)句、獲取結(jié)果集、遍歷結(jié)果集、取得某個(gè)字段、獲取表字段名、將圖片插入數(shù)據(jù)庫(kù)、執(zhí)行事務(wù)等各種代碼實(shí)例和詳細(xì)介紹,代碼居多,是一桌豐盛唯美的代碼大餐
    2013-02-02
  • Python實(shí)現(xiàn)讀取json文件到excel表

    Python實(shí)現(xiàn)讀取json文件到excel表

    這篇文章主要介紹了Python實(shí)現(xiàn)讀取json文件到excel表,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 跟老齊學(xué)Python之賦值,簡(jiǎn)單也不簡(jiǎn)單

    跟老齊學(xué)Python之賦值,簡(jiǎn)單也不簡(jiǎn)單

    在《初識(shí)永遠(yuǎn)強(qiáng)大的函數(shù)》一文中,有一節(jié)專門討論“取名字的學(xué)問(wèn)”,就是有關(guān)變量名稱的問(wèn)題,本溫故而知新的原則,這里要復(fù)習(xí)一下
    2014-09-09
  • 如何理解python對(duì)象

    如何理解python對(duì)象

    在本篇文章里小編給大家分享的是一篇關(guān)于python對(duì)象的理解相關(guān)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2020-06-06

最新評(píng)論