詳解基于django實現(xiàn)的webssh簡單例子
本文介紹了詳解基于django實現(xiàn)的webssh簡單例子,分享給大家,具體如下:
說明
新建一個 django 程序,本文為 chain。
以下僅為簡單例子,實際應(yīng)用 可根據(jù)自己平臺情況 進行修改。
打開首頁后,需要輸入1,后臺去登錄主機,然后返回登錄結(jié)果。
正常項目 可以post 主機和登錄賬戶,進行權(quán)限判斷,然后去后臺讀取賬戶密碼,進行登錄。
djang后臺
需要安裝以下模塊
安裝后會有一個版本號報錯,不影響
channels==2.0.2 channels-redis==2.1.0 amqp==1.4.9 anyjson==0.3.3 asgi-redis==1.4.3 asgiref==2.3.0 async-timeout==2.0.0 attrs==17.4.0 cd /tmp/ wget https://files.pythonhosted.org/packages/12/2a/e9e4fb2e6b2f7a75577e0614926819a472934b0b85f205ba5d5d2add54d0/Twisted-18.4.0.tar.bz2 tar xf Twisted-18.4.0.tar.bz2 cd Twisted-18.4.0 python3 setup.py install
啟動redis
目錄
chain/ chain/ settings.py asgi.py consumers.py routing.py templates/ index.html
settings.py
# django-channels配置 CHANNEL_LAYERS = { "default": { "BACKEND": "channels_redis.core.RedisChannelLayer", "CONFIG": { "hosts": [("127.0.0.1", 6379)], }, }, } # 配置ASGI ASGI_APPLICATION = "chain.routing.application"
consumers.py
from asgiref.sync import async_to_sync from channels.generic.websocket import WebsocketConsumer import paramiko import threading import time from channels.layers import get_channel_layer channel_layer = get_channel_layer() class MyThread(threading.Thread): def __init__(self, id, chan): threading.Thread.__init__(self) self.chan = chan def run(self): while not self.chan.chan.exit_status_ready(): time.sleep(0.1) try: data = self.chan.chan.recv(1024) async_to_sync(self.chan.channel_layer.group_send)( self.chan.scope['user'].username, { "type": "user.message", "text": bytes.decode(data) }, ) except Exception as ex: print(str(ex)) self.chan.sshclient.close() return False class EchoConsumer(WebsocketConsumer): def connect(self): # 創(chuàng)建channels group, 命名為:用戶名,并使用channel_layer寫入到redis async_to_sync(self.channel_layer.group_add)(self.scope['user'].username, self.channel_name) # 返回給receive方法處理 self.accept() def receive(self, text_data): if text_data == '1': self.sshclient = paramiko.SSHClient() self.sshclient.load_system_host_keys() self.sshclient.set_missing_host_key_policy(paramiko.AutoAddPolicy()) self.sshclient.connect('47.104.140.38', 22, 'root', '123456') self.chan = self.sshclient.invoke_shell(term='xterm') self.chan.settimeout(0) t1 = MyThread(999, self) t1.setDaemon(True) t1.start() else: try: self.chan.send(text_data) except Exception as ex: print(str(ex)) def user_message(self, event): # 消費 self.send(text_data=event["text"]) def disconnect(self, close_code): async_to_sync(self.channel_layer.group_discard)(self.scope['user'].username, self.channel_name)
asgi.py
import os import django from channels.routing import get_default_application os.environ.setdefault("DJANGO_SETTINGS_MODULE", "chain.settings") django.setup() application = get_default_application() routing.py from channels.auth import AuthMiddlewareStack from channels.routing import URLRouter, ProtocolTypeRouter from django.urls import path from .consumers import EchoConsumer application = ProtocolTypeRouter({ "websocket": AuthMiddlewareStack( URLRouter([ path(r"ws/", EchoConsumer), # path(r"stats/", StatsConsumer), ]) ) })
網(wǎng)頁設(shè)置:
index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>django webssh 例子</title> <link href="/static/css/plugins/ztree/awesomeStyle/awesome.css" rel="external nofollow" rel="stylesheet"> <link href="/static/webssh_static/css/xterm.min.css" rel="external nofollow" rel="stylesheet" type="text/css"/> <style> body { padding-bottom: 30px; } .terminal { border: #000 solid 5px; font-family: cursive; {# font-family: Arial, Helvetica, Tahoma ,"Monaco", "DejaVu Sans Mono", "Liberation Mono", sans-serif;#}{# font-family: Tahoma, Helvetica, Arial, sans-serif;#}{# font-family: "\5B8B\4F53","","Monaco", "DejaVu Sans Mono", "Liberation Mono", "Microsoft YaHei", monospace;#} font-size: 15px; {# color: #f0f0f0;#} background: #000; {# width: 893px;#}{# height: 550px;#} box-shadow: rgba(0, 0, 0, 0.8) 2px 2px 20px; } .reverse-video { color: #000; background: #f0f0f0; } </style> </head> <body> <div id="terms"></div> </body> <script src="/static/webssh_static/js/xterm.min.js"></script> <script> var socket = new WebSocket('ws://' + window.location.host + '/ws/'); socket.onopen = function () { var term = new Terminal(); term.open(document.getElementById('terms')); term.on('data', function (data) { console.log(data); socket.send(data); }); socket.onmessage = function (msg) { console.log(msg); console.log(msg.data); term.write(msg.data); }; socket.onerror = function (e) { console.log(e); }; socket.onclose = function (e) { console.log(e); term.destroy(); }; }; </script> </html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python 把序列轉(zhuǎn)換為元組的函數(shù)tuple方法
今天小編就為大家分享一篇Python 把序列轉(zhuǎn)換為元組的函數(shù)tuple方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06Python for循環(huán)搭配else常見問題解決
這篇文章主要介紹了Python for循環(huán)搭配else常見問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-02-02Python Selenium實現(xiàn)無可視化界面過程解析
這篇文章主要介紹了Python Selenium實現(xiàn)無可視化界面過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08- Python由荷蘭數(shù)學(xué)和計算機科學(xué)研究學(xué)會的Guido van Rossum 于1990 年代初設(shè)計,作為一門叫做ABC語言的替代品。 Python提供了高效的高級數(shù)據(jù)結(jié)構(gòu),還能簡單有效地面向?qū)ο缶幊?/div> 2021-10-10
Python基于模塊Paramiko實現(xiàn)SSHv2協(xié)議
這篇文章主要介紹了Python基于模塊Paramiko實現(xiàn)SSHv2協(xié)議,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04最新評論