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内置的字符串处理函数详细整理(覆盖日常所用)
Aug 19 Python
Python批量按比例缩小图片脚本分享
May 21 Python
深入解答关于Python的11道基本面试题
Apr 01 Python
python多线程socket编程之多客户端接入
Sep 12 Python
python 字典中取值的两种方法小结
Aug 02 Python
如何在Django中添加没有微秒的 DateTimeField 属性详解
Jan 30 Python
pyside+pyqt实现鼠标右键菜单功能
Dec 08 Python
python开启debug模式的方法
Jun 27 Python
Python入门Anaconda和Pycharm的安装和配置详解
Jul 16 Python
Python编写打字训练小程序
Sep 26 Python
Python实现遗传算法(二进制编码)求函数最优值方式
Feb 11 Python
Python爬虫之爬取二手房信息
Apr 27 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/03/04 星际争霸
破解图片防盗链的代码(asp/php)测试通过
2010/07/02 PHP
PHP利用Cookie设置用户30分钟未操作自动退出功能
2017/07/03 PHP
JS localStorage实现本地缓存的方法
2013/06/22 Javascript
处理及遍历XML文档DOM元素属性及方法整理
2013/08/23 Javascript
javascript的变量、传值、传址、参数之间关系
2015/07/26 Javascript
跟我学习javascript的闭包
2015/11/16 Javascript
Nodejs express框架一个工程中同时使用ejs模版和jade模版
2015/12/28 NodeJs
JS基础随笔(菜鸟必看篇)
2016/07/13 Javascript
jQuery.ajax向后台传递数组问题的解决方法
2017/05/12 jQuery
laydate 显示结束时间不小于开始时间的实例
2017/08/11 Javascript
AngularJS+Bootstrap3多级导航菜单的实现代码
2017/08/16 Javascript
elementUi vue el-radio 监听选中变化的实例代码
2019/06/28 Javascript
vue的注意规范之v-if 与 v-for 一起使用教程
2019/08/04 Javascript
部署vue+Springboot前后端分离项目的步骤实现
2020/05/31 Javascript
javascript实现移动端红包雨页面
2020/06/23 Javascript
如何用python整理附件
2018/05/13 Python
利用django-suit模板添加自定义的菜单、页面及设置访问权限
2018/07/13 Python
浅谈python编译pyc工程--导包问题解决
2019/03/20 Python
python对常见数据类型的遍历解析
2019/08/27 Python
详解python中index()、find()方法
2019/08/29 Python
python中利用matplotlib读取灰度图的例子
2019/12/07 Python
linux 下python多线程递归复制文件夹及文件夹中的文件
2020/01/02 Python
Python实现i人事自动打卡的示例代码
2020/01/09 Python
解决python中显示图片的plt.imshow plt.show()内存泄漏问题
2020/04/24 Python
flask项目集成swagger的方法
2020/12/09 Python
html5版canvas自由拼图实例
2014/10/15 HTML / CSS
网络安全类面试题
2015/08/01 面试题
怎样在 Applet 中建立自己的菜单(MenuBar/Menu)?
2012/06/20 面试题
最经典的商业地产项目广告词
2014/03/13 职场文书
3.15国际消费者权益日主题活动活动总结
2014/03/16 职场文书
敬老月活动总结
2014/08/28 职场文书
2015年初中元旦晚会活动总结
2014/11/28 职场文书
优秀党支部申报材料
2014/12/24 职场文书
政审证明范文
2015/06/19 职场文书
iPhone13将有八大升级
2021/04/15 数码科技