一、python服务端入门:读取文件并返回给前端

python读取文件内容并通过接口给前端使用

常规的python web开发是在服务器端根据url动态生成
html

这里还是采取前后端分离思想,通过python读取文件数据,通过接口给前端调用。

注意事项

  • 确保python版本为3.x

框架选型:

  • Django:全能型Web框架;
  • Flask:轻量实用的Web框架;
  • web.py:一个小巧的Web框架;
  • Bottle:和Flask类似的Web框架;
  • Tornado:Facebook的开源异步Web框架。

只是实现一个小工具实用Flask就好

安装方式

pip install flask

初衷和思路

博客的文章管理方式大体分两种:静态html、动态加载。动态加载文章一般通过数据库存取,为了简化此过程,就想通过直接加载文件的方式。
markdown语法在写文章上很受开发者青睐,因此直接加载md文件就比较便于维护。
现行方案中
github采用的后端加载方式,已有的一种前端直接加载md文件的方式是vue-markdown-loader
对此方式感兴趣可以直接采用这种loader方式,以下内容就可以忽略了。
之所以采取python读取文档并返回给前端而不是其他语言主要是因为python比较火热,应用面广。作为一枚小前端果断选择python来研究学习,这个小项目也是用来练练手。

注:md文章放在项目./static下就好

  • 1.注册接口,绑定处理函数
  • 2.接收前端传递的参数(文件名)
  • 3.读取文件,返回到前端

代码如下:

python代码就是简洁

@app.route('/getdata/md', methods=['post'])
def ajax_test_add():
    params = request.get_json()
    childPath = params.get('title')
    if(params.get('title') == None):
        print('未传title字段!')
        return json.dumps({'resCode':'4001','msg':'参数错误title为必传'})
    else:
        path = './static' + childPath + '.md'
        try:
            f_name = open(path, 'r', encoding='UTF-8').read()
            print(f_name)
            # 成功获取到md文件内容啦
            return json.dumps({'content':f_name,'resCode':2000})
        except OSError as reason:
            print('读取文件出错了T_T')
            print('出错原因是%s' % str(reason))
        return json.dumps({'err': str(reason),'resCode':5000})

问题总结

  • 跨域问题

from flask_cors import CORS

CORS(app, resources=r'/*')

r’/*’ 是通配符,让本服务器所有的URL 都允许跨域请求

  • 主机端口号设置

app.run(host = '0.0.0.0', port = 9001, debug = True)

前端代码

<article class="post post-1" repeat="blogData.data">
    <header class="entry-header">
        <h1 class="entry-title">
            <a href="javascript:;" data-id="{{item.key}}" onclick="showArticle(this)" >{{item.title}}</a>
        </h1>
        <div class="entry-meta">
            <span class="post-category"><a href="#">{{item.category}}</a></span>
            <span class="post-date"><a href="#">
                <time class="entry-date">{{item.updateAt}}</time>
            </a></span>
            <span class="post-author"><a href="#">{{item.author}}</a></span>
            <span class="comments-link"><a href="#">{{item.segs}} 评论</a></span>
            <span class="views-count"><a href="#">{{item.count}} 阅读</a></span>
        </div>
    </header>
    <div class="entry-content clearfix">
        <p>{{item.content}}</p>
        <div class="read-more cl-effect-14">
            <a href="#" class="more-link">继续阅读<span class="meta-nav">→</span></a>
        </div>
    </div>
</article>

在点击文章标题是,获取data-id属性的值,该值即为传给后端的文件名。

前端调用的接口地址:http://hostname:9001/getdata/md
请求方式:POST

必传参数:{“title”: 文章名(不用加后缀)},该文章要放在python项目的./static目录下

源码:
https://github.com/idongchen/docs/blob/master/example/getfile.py

    原文作者:idongchen
    原文地址: https://segmentfault.com/a/1190000015924251
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞