python在线编译器的简单原理及简单实现代码


Posted in Python onFebruary 02, 2018

我们先来看一下效果(简单的写了一个):

python在线编译器的简单原理及简单实现代码

python在线编译器的简单原理及简单实现代码

python在线编译器的简单原理及简单实现代码

原理:将post请求的代码数据写入了服务器的一个文件,然后用服务器的python编译器执行返回结果

实现代码:

#flaskrun.py 
# -*- coding: utf-8 -*- 
# __author__="ZJL"  
from flask import Flask 
from flask import request 
from flask import Response 
import json 
import zxby  
app = Flask(__name__) 
  
def Response_headers(content): 
  resp = Response(content) 
  resp.headers['Access-Control-Allow-Origin'] = '*' 
  return resp 
 
@app.route('/') 
def hello_world(): 
  return Response_headers('hello world!!!') 
 
@app.route('/run', methods=['POST']) 
def run(): 
  if request.method == 'POST' and request.form['code']: 
    code = request.form['code'] 
    print(code) 
    jsondata = zxby.main(code) 
    return Response_headers(str(jsondata)) 
 
@app.errorhandler(403) 
def page_not_found(error): 
  content = json.dumps({"error_code": "403"}) 
  resp = Response_headers(content) 
  return resp 
 
@app.errorhandler(404) 
def page_not_found(error): 
  content = json.dumps({"error_code": "404"}) 
  resp = Response_headers(content) 
  return resp 
 
@app.errorhandler(400) 
def page_not_found(error): 
  content = json.dumps({"error_code": "400"}) 
  resp = Response_headers(content) 
  return resp 
 
@app.errorhandler(405) 
def page_not_found(error): 
  content = json.dumps({"error_code": "405"}) 
  resp = Response_headers(content) 
  return resp 
 
@app.errorhandler(410) 
def page_not_found(error): 
  content = json.dumps({"error_code": "410"}) 
  resp = Response_headers(content) 
  return resp 
 
@app.errorhandler(500) 
def page_not_found(error): 
  content = json.dumps({"error_code": "500"}) 
  resp = Response_headers(content) 
  return resp 
 
if __name__ == '__main__': 
  app.run(debug=True)
#zxby.py 
# -*- coding: utf-8 -*- 
# __author__="ZJL" 
import os, sys, subprocess, tempfile, time  
# 创建临时文件夹,返回临时文件夹路径 
TempFile = tempfile.mkdtemp(suffix='_test', prefix='python_') 
# 文件名 
FileNum = int(time.time() * 1000) 
# python编译器位置 
EXEC = sys.executable 
  
# 获取python版本 
def get_version(): 
  v = sys.version_info 
  version = "python %s.%s" % (v.major, v.minor) 
  return version 
  
# 获得py文件名 
def get_pyname(): 
  global FileNum 
  return 'test_%d' % FileNum 
  
# 接收代码写入文件 
def write_file(pyname, code): 
  fpath = os.path.join(TempFile, '%s.py' % pyname) 
  with open(fpath, 'w', encoding='utf-8') as f: 
    f.write(code) 
  print('file path: %s' % fpath) 
  return fpath 
  
# 编码 
def decode(s): 
  try: 
    return s.decode('utf-8') 
  except UnicodeDecodeError: 
    return s.decode('gbk') 
 
  # 主执行函数  
 
def main(code): 
  r = dict() 
  r["version"] = get_version() 
  pyname = get_pyname() 
  fpath = write_file(pyname, code) 
  try: 
    # subprocess.check_output 是 父进程等待子进程完成,返回子进程向标准输出的输出结果 
    # stderr是标准输出的类型 
    outdata = decode(subprocess.check_output([EXEC, fpath], stderr=subprocess.STDOUT, timeout=5)) 
  except subprocess.CalledProcessError as e: 
    # e.output是错误信息标准输出 
    # 错误返回的数据 
    r["code"] = 'Error' 
    r["output"] = decode(e.output) 
    return r 
  else: 
    # 成功返回的数据 
    r['output'] = outdata 
    r["code"] = "Success" 
    return r 
  finally: 
    # 删除文件(其实不用删除临时文件会自动删除) 
    try: 
      os.remove(fpath) 
    except Exception as e: 
      exit(1) 
 
if __name__ == '__main__': 
  code = "print(11);print(22)" 
  print(main(code))

运行app.run()方法,通过post提交代码,就ok了。我们可以对输出结过做进一步的处理,我这只是为了解一下原理,就没继续了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python模拟新浪微博登陆功能(新浪微博爬虫)
Dec 24 Python
Python3.4实现远程控制电脑开关机
Feb 22 Python
python搭建服务器实现两个Android客户端间收发消息
Apr 12 Python
对python数据切割归并算法的实例讲解
Dec 12 Python
Python脚本完成post接口测试的实例
Dec 17 Python
Django框架会话技术实例分析【Cookie与Session】
May 24 Python
Python+Selenium使用Page Object实现页面自动化测试
Jul 14 Python
python 中xpath爬虫实例详解
Aug 26 Python
Python线程障碍对象Barrier原理详解
Dec 02 Python
python带参数打包exe及调用方式
Dec 21 Python
关于Pytorch的MLP模块实现方式
Jan 07 Python
Python logging模块写入中文出现乱码
May 21 Python
使用Python进行AES加密和解密的示例代码
Feb 02 #Python
为什么选择python编程语言入门黑客攻防 给你几个理由!
Feb 02 #Python
Python无损音乐搜索引擎实现代码
Feb 02 #Python
Python面向对象class类属性及子类用法分析
Feb 02 #Python
Python网络编程之TCP与UDP协议套接字用法示例
Feb 02 #Python
Python星号*与**用法分析
Feb 02 #Python
Python模块WSGI使用详解
Feb 02 #Python
You might like
重置版宣传动画
2020/04/09 魔兽争霸
重量级动漫纷纷停播!唯独OVERLORD第四季正在英魂之刃继续更新
2020/05/06 日漫
sqlyog 中文乱码问题的设置方法
2008/10/19 PHP
php中实现用数组妩媚地生成要执行的sql语句
2015/07/10 PHP
PHP实现基于文本的摩斯电码生成器
2016/01/11 PHP
利用php实现一周之内自动登录存储机制(cookie、session、localStorage)
2016/10/31 PHP
PHP版单点登陆实现方案的实例
2016/11/17 PHP
ext for eclipse插件安装方法
2008/04/27 Javascript
js点击更换背景颜色或图片的实例代码
2013/06/25 Javascript
ExtJS DOM元素操作经验分享
2013/08/28 Javascript
正则表达式中特殊符号及正则表达式的几种方法总结(replace,test,search)
2013/11/26 Javascript
node.js WEB开发中图片验证码的实现方法
2014/06/03 Javascript
总结在前端排序中遇到的问题
2016/07/19 Javascript
详解利用exif.js解决ios手机上传竖拍照片旋转90度问题
2016/11/04 Javascript
angular分页指令操作
2017/01/09 Javascript
JS字符串false转boolean的方法(推荐)
2017/03/08 Javascript
详解vue-resource promise兼容性问题
2017/06/20 Javascript
移动设备手势事件库Touch.js使用详解
2017/08/18 Javascript
element-ui table组件如何使用render属性的实现
2019/11/04 Javascript
Node.js开发之套接字(socket)编程入门示例
2019/11/05 Javascript
详解vue-template-admin三级路由无法缓存的解决方案
2020/03/10 Javascript
js抽奖转盘实现方法分析
2020/05/16 Javascript
vue实现购物车的小练习
2020/12/21 Vue.js
[40:29]2018DOTA2亚洲邀请赛 4.7总决赛 LGD vs Mineski 第一场
2018/04/10 DOTA
教你用Python脚本快速为iOS10生成图标和截屏
2016/09/22 Python
Python抽象和自定义类定义与用法示例
2018/08/23 Python
python将时分秒转换成秒的实例
2019/12/07 Python
某个公司的Java笔面试题
2016/03/11 面试题
德育标兵事迹材料
2014/08/24 职场文书
法制演讲稿
2014/09/10 职场文书
2015最新民情日记范文
2015/06/26 职场文书
道士塔读书笔记
2015/06/30 职场文书
计算机教师工作总结
2015/08/13 职场文书
《惊弓之鸟》教学反思
2016/02/20 职场文书
sql查询结果列拼接成逗号分隔的字符串方法
2021/05/25 SQL Server
python 判断字符串当中是否包含字符(str.contain)
2022/06/01 Python