Еј Хабр!
Неодамна гледав преземена верзија на програмскиот поток „Како да креирате сопствена веб-апликација во Flask“. И решив да го консолидирам моето знаење во некој проект. Долго време не знаев што да напишам и ми дојде идејата: „Зошто да не направам мини-задна врата во Flask?“
Во мојата глава веднаш се појавија првите опции за имплементации и можности на задна врата. Но, решив веднаш да направам список со можности за задна врата:
- Знајте како да отворате веб-страници
- Имајте пристап до командната линија
- Бидете во можност да отворате програми, фотографии, видеа
Значи, првата точка е исклучително лесна за имплементација со користење на модулот за веб-прелистувач. Решив да ја спроведам втората точка користејќи го модулот OS. И третиот е исто така преку OS модулот, но ќе користам „линкови“ (повеќе за тоа подоцна).
Пишување сервер
Значи, *drumroll* целиот код на серверот:
from flask import Flask, request
import webbrowser
import os
import re
app = Flask(__name__)
@app.route('/mycomp', methods=['POST'])
def hell():
json_string = request.json
if json_string['command'] == 'test':
return 'The server is running and waiting for commands...'
if json_string['command'] == 'openweb':
webbrowser.open(url='https://www.'+json_string['data'], new=0)
return 'Site opening ' + json_string['data'] + '...'
if json_string['command'] == 'shell':
os.system(json_string['data'])
return 'Command execution ' + json_string['data'] + '...'
if json_string['command'] == 'link':
links = open('links.txt', 'r')
for i in range(int(json_string['data'])):
link = links.readline()
os.system(link.split('>')[0])
return 'Launch ' + link.split('>')[1]
if __name__ == '__main__':
app.run(host='0.0.0.0')
Веќе го фрлив целиот код, време е да ја објаснам суштината.
Целиот код работи на локалниот компјутер на портата 5000. За да комуницираме со серверот, мора да испратиме барање за JSON POST.
Структура на барање JSON:
{‘command’: ‘comecommand’, ‘data’: ‘somedata’}
Па, има смисла дека „командата“ е командата што сакаме да ја извршиме. А 'податоци' се командните аргументи.
Можете рачно да пишувате и испраќате JSON барања за интеракција со серверот (барањата ќе ви помогнат). Или можете да напишете клиент за конзола.
Пишување клиент
Код:
import requests
logo = ['nn',
'****** ********',
'******* *********',
'** ** ** **',
'** ** ** ** Written on Python',
'******* ** **',
'******** ** **',
'** ** ** ** Author: ROBOTD4',
'** ** ** **',
'** ** ** **',
'******** *********',
'******* ********',
'nn']
p = ''
iport = '192.168.1.2:5000'
host = 'http://' + iport + '/mycomp'
def test():
dict = {'command': 'test', 'data': 0}
r = requests.post(host, json=dict)
if r.status_code == 200:
print (r.content.decode('utf-8'))
def start():
for i in logo:
print(i)
start()
test()
while True:
command = input('>')
if command == '':
continue
a = command.split()
if command == 'test':
dict = {'command': 'test', 'data': 0}
r = requests.post(host, json=dict)
if r.status_code == 200:
print (r.content.decode('utf-8'))
if a[0] == 'shell':
for i in range(1, len(a)):
p = p + a[i] + ' '
dict = {'command': 'shell', 'data': p}
r = requests.post(host, json=dict)
if r.status_code == 200:
print (r.content.decode('utf-8'))
p = ''
if a[0] == 'link':
if len(a) > 1:
dict = {'command': 'link', 'data': int(a[1])}
r = requests.post(host, json=dict)
if r.status_code == 200:
print (r.content.decode('utf-8'))
else:
print('Комманда не содержит аргументов!')
if a[0] == 'openweb':
if len(a) > 1:
dict = {'command': 'openweb', 'data': a[1]}
r = requests.post(host, json=dict)
if r.status_code == 200:
print (r.content.decode('utf-8'))
else:
print('Комманда не содержит аргументов!')
if a[0] == 'set':
if a[1] == 'host':
ip = a[2] + ':5000'
if command == 'quit':
break
Објаснувања:
Пред сè, модулот за барања се увезува (за интеракција со серверот). Подолу се дадени описи на стартните и тест функциите. А потоа циклусот во кој се случува магијата. Дали го прочитавте кодот? Така го разбирате значењето на магијата што се случува во циклусот. Внесете ја командата - таа е извршена. Shell – команди за командната линија (логиката е исклучена од скалата).
Тест - проверете дали серверот работи (задна врата)
Врска - употреба на „кратенка“
Openweb – отворање веб-страница
Излезете - излезете од клиентот
Постави – поставување на IP на вашиот компјутер на локалната мрежа
И сега повеќе за врската.
До серверот има датотека link.txt. Содржи врски (целосна патека) до датотеки (видеа, фотографии, програми).
Структурата е вака:
полный_путь>описание
полный_путь>описание
Вкупно
Имаме сервер за задна врата за контролирање на компјутер на локална мрежа (во Wi-Fi мрежа). Технички, можеме да го извршиме клиентот од кој било уред што има толкувач на python.
П.С. Ја додадов командата set така што ако на компјутерот на локалната мрежа му е доделена друга IP адреса, таа може да се смени директно во клиентот.
Извор: www.habr.com