使用flask开发网站后端

Flask 是一个用于 Python 的微型网络开发框架,能够用于快速的搭建一个小型的网站。javascript

个人搜索引擎:http://www.abelkhan.com 就是基于flask开发前端

 

一个flask的Hello Worldjava

from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello World!'

if __name__ == '__main__':
    app.run()

 

其中,app = Flask(__name__)建立的app对象就是咱们的网站应用的实例。python

能够看到,Flask经过@修饰符,app.route实现了对url请求到函数接口的路由。nginx

也就是说,你若是在浏览器请求http://url.com/,经过app.route的做用,最终就会调用到hello_world。git

 

使用flask作文件服务器,和nginx不一样,flask不能直接提供对文件的路由,github

而是须要用app.route实现对url的路由web

@app.route('/JSONError.js')
def file_JSONError():
    from io import BytesIO
    try:
        return Response(BytesIO(globalv.res_data['JSONError.js']), mimetype='js')
    except:
        traceback.print_exc()

并在对应得函数中,返回对应得文件内容。json

 

flask中的Response,就是对于的http请求中的的Request和Responseflask

包含以下信息:

status 状态码,元数据

status_code 只包含 code 的 status

headers 头,元数据

mimetype 去掉 charset 的 content type,如 application/json

data body,元数据

咱们经过Response便可返回文件数据

 

处理AJAX请求,也就是来至javascript的post的请求:

js的请求以下:

    table_regchange.onclick=function() {
        var params = {"sid":sid};
        JSONRequest.post("http://abelkhan.com/changecheck", params,
            function (requestNumber, value, exception){
                table_regcheck.innerHTML = value["check"];
            });
    };

后端的响应代码:

@app.route('/changecheck', methods=['POST'])
def changecheck():
    try:
        from io import BytesIO
        r = on_get_check(request.get_json())
        rsp = Response(BytesIO(json.dumps(r)), mimetype='text/json')
        return rsp
    except:
        traceback.print_exc()

这里是前端请求更换验证码,而后服务器返回新的验证码的代码,

如此便可完成请求-响应的逻辑流程。

 

 

开源的搜索引擎:http://www.abelkhan.com/
欢迎你们围观!


使用python编写了后端网络爬和前端网站



项目地址:http://www.abelkhan.com/
向咱们提出意见:http://www.abelkhan.com/guestbook/
对项目进行捐助:http://www.abelkhan.com/collection/
代码托管地址以下:https://github.com/qianqians/websearch欢迎你们参与

相关文章
相关标签/搜索