Flask入门(1)

Posted by Kody Black on November 24, 2022

毕设需要做一个前端,展示一下结果,虽然内容还没有开始弄,但是这个展示的平台可以同步弄一弄,也算是换个工作方向,比较有意思

当下思路

主要还是用别人的框架吧,应该会快一点而且美观一点,前端这东西没必要从头开始

看了下它的结构很简单,就是用了比较基础的flask框架,感觉自己稍微学一下flask框架,再找几个用于搜索的项目,黏合一下,应该就差不多了。

  • hybrid-analysis. Free Automated Malware Analysis Service[EB/OL]. https://www.hybrid-analysis.com/.
  • AnyRun. MITRE ATT&CK: The Most Comprehensive Behavior Database[EB/OL]. https://any.run/cybersecurity-blog/mitre-attack/, 2020-09.

这是两个网上的用于映射attack框架的,可以参考

Flask入门(1)

venv的配置

我用了这么久python,还一直没配置过venv,这次刚好用了一下,先记录一次

python -m venv . #在当前文件夹建立虚拟环境
ls
Mode                 LastWriteTime         Length Name
----                 -------------         ------ ----
d-----        2022/11/24     21:25                Include
d-----        2022/11/24     21:25                Lib
d-----        2022/11/24     21:25                Scripts
-a----        2022/11/24     21:25            117 pyvenv.cfg
# 创建了以上文件
# 其中,Scripts中的文件如下:
Mode                 LastWriteTime         Length Name
----                 -------------         ------ ----
-a----        2022/11/24     21:25           2294 activate
-a----        2022/11/24     21:25            971 activate.bat
-a----        2022/11/24     21:25           1502 Activate.ps1
-a----        2022/11/24     21:25            368 deactivate.bat
-a----        2022/11/24     21:25         106373 easy_install-3.7.exe
-a----        2022/11/24     21:25         106373 easy_install.exe
-a----        2022/11/24     21:25         106364 pip.exe
-a----        2022/11/24     21:25         106364 pip3.7.exe
-a----        2022/11/24     21:25         106364 pip3.exe
-a----        2022/11/24     21:25         501264 python.exe
-a----        2022/11/24     21:25         500240 pythonw.exe
# 运行activate即可激活环境
# 运行后可以看到命令行前缀会显示当前环境名(即创建时的目录名)
# 貌似需要运行deactivate.bat关闭环境,但是实际上运行该脚本没啥影响,直接退出就行了
# 在vscode中直接选择编译器即可

Hello_world

from flask import Flask
app = Flask(__name__)			#构造函数,使用当前模块(__name __)的名称作为参数

@app.route('/')					#路由表,这里在首页绑定了hello_world函数
def hello_world():
   return 'Hello World'

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

路由和变量规则

from flask import Flask
app = Flask(__name__)

@app.route('/hello/<name>')			# 默认类型为string
def hello_name(name):
   return 'Hello %s!' % name

@app.route('/blog/<int:postID>')	# int
def show_blog(postID):
   return 'Blog Number %d' % postID

@app.route('/rev/<float:revNo>')	# float
def revision(revNo):
   return 'Revision Number %f' % revNo

@app.route('/path/<path:subpath>')	#path相当于特殊的string(中间可以加斜杠/)
def show_subpath(subpath):
# show the subpath after /path/
    return 'Subpath %s' % escape(subpath)

@app.route('/flask')				# /flask/ URL会产生“404 Not Found”页面
def hello_flask():
   return 'Hello Flask'

@app.route('/python/')				# 访问 /python 或 /python/返回相同的输出
									# 实际上是访问/python会重定向到/python/
def hello_python():
   return 'Hello Python'


if __name__ == '__main__':
	app.run(debug=True, host='0.0.0.0', port=5000)

url_for

用于动态构建特定函数的url

from flask import Flask, redirect, url_for
app = Flask(__name__)

@app.route('/admin')
def hello_admin():
   return 'Hello Admin'

@app.route('/guest/<guest>')
def hello_guest(guest):
   return 'Hello %s as Guest' % guest

@app.route('/user/<name>')
def hello_user(name):
   if name =='admin':
      return redirect(url_for('hello_admin'))
   else:
      return redirect(url_for('hello_guest', guest = name))

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

模板

模板相当于表示一个响应文件的格式,用于将视图和数据处理分离

模板一般是存于./templates文件夹中html文件

题外话,博客用的jekll处理这个md的时候,竟然会把html代码块的内容认为是代码内容,运行时显示如下warning,不知道是jekll的问题还是这个博客框架的问题,代码数据分离做的不行呀~

所以这里放的是图片【而且好讨厌,gitee上的图片在这里也不能显示,吐了】

用如下方法给上面的模板传入数据:

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
    # 往模板中传入的数据
    my_str = 'Hello Word'
    my_int = 10
    my_array = [3, 4, 2, 1, 7, 9]
    my_dict = {'name': 'xiaoming','age': 18}
    return render_template('hello.html',
                           my_str=my_str,
                           my_int=my_int,
                           my_array=my_array,
                           my_dict=my_dict
                           )

静态文件

静态文件保存在./static文件夹中,一般是需要的js和css文件

这里的方法和html中正常使用js和css文件是一样的

例如

from flask import Flask, render_template
app = Flask(__name__)

@app.route("/")
def index():
   return render_template("index.html")

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

// filename:whattime.js
function whattime() {
    alert(Date())
}

这样,进入主界面显示模板index.html,上面有一个按钮click me to display time,点击后弹出时间。

Request对象

来自客户端网页的数据作为全局请求对象发送到服务器。为了处理请求数据,应该从Flask模块导入。

Request对象的重要属性如下所列:

  • Form - 它是一个字典对象,包含表单参数及其值的键和值对。
  • args - 解析查询字符串的内容,它是问号(?)之后的URL的一部分。
  • Cookies - 保存Cookie名称和值的字典对象。
  • files - 与上传文件有关的数据。
  • method - 当前请求方法。

之前看了一遍,现在记录又复习了一遍,基本掌握了,nice!

我这些基本上都是抄的https://www.w3cschool.cn/flask里面的内容哈哈哈,我只修改了一点点错误的内容,有点过分。。。

目前进度:Flask 静态文件_w3cschool

yysy,Flask这框架是真的方便,怪不得现在前端工程师好多都是搞设计的(bushi

最后,感觉我的这博客还是挺粗糙呀,html文件相当于直接放图片,有点不方便,以后尽可能就不会在这里面放html的内容了,反正自己也用的少。以后有大把闲时间了试着学一下修一修!