찾다
백엔드 개발파이썬 튜토리얼Python 개발 WEB 프레임워크 Flask에 대한 자세한 소개

Flask 소개

Flask는 Django에 비해 가벼운 웹프레임워크입니다.

Django와 달리 Flask는 일련의 오픈 소스 소프트웨어 패키지를 기반으로 구축되었으며, 그 중 가장 중요한 것은 WSGI 애플리케이션 개발 라이브러리 Werkzeug와 템플릿 엔진 Jinja:

전략: Werkzeug와 Jinja는 Flask와 마찬가지로 둘 다 pocoo 팀에서 개발했습니다. 이는 Django와 경쟁할 때 Pocoo의 생태학적 전략을 반영할 수 있습니다. 이 전략의 자연스러운 확장은 Flask 프레임워크가 ORM이든 다른 것이든 데이터베이스 구성 요소를 포함하지 않는다는 것입니다.

초점: Flask는 WSGI 애플리케이션 프레임워크이므로 Flask를 개발할 때 네트워크 운영에 주의를 기울일 필요가 없습니다. Flask 애플리케이션의 입구는 캡슐화된 네트워크 요청 패킷이고 출구는 입니다. 이 단계에서는 네트워크 응답에만 주의하면 됩니다.

WSGI 서버: Flask에는 간단한 WSGI 서버가 내장되어 있지만 성능은 개발 기간 동안의 디버깅에만 적합합니다. Flask 공식 웹사이트에서는 다중 프로세스에서 다중 스레드, 코루틴에 이르는 다양한 구현 방법을 갖춘 다양한 WSGI 서버를 권장합니다. 이 과정에서는 이에 대한 선택을 다루지 않습니다.

REST 적응성: Flask와 Django는 동일하지만 초기 시작점은 서버 측 동적 웹 애플리케이션입니다. 하지만 Flask의 디자인은 리소스 중심의 REST 아키텍처에 상당히 적합합니다. 모바일이 점점 더 모바일화되고 단일 페이지 애플리케이션이 점점 더 중요해지고 있는 WEB 개발 분야에서 이는 그렇습니다. Django에 비해 Flask의 상당한 장점.

Hello Flask

Flask를 기반으로 Hello World를 작성하는 것은 매우 쉽습니다.

1. Flask 클래스를 가져옵니다.

from flask import Flask

Flask 클래스는 다음과 같습니다. WSGI 애플리케이션 사양을 구현하는 Flask 프레임워크의 핵심 클래스입니다.

2. Flask 인스턴스 만들기

app = Flask(name)

Flask생성자의 첫 번째 매개변수 는 가져오기 이름/가져오기 이름을 지정합니다. Flask 프레임워크는 이 이름을 사용하여 정적 리소스, 템플릿 및 오류 메시지를 찾습니다. 목적을 명확하게 이해하지 않는 한 일반적으로 항상 특수 변수 _name을 사용해야 합니다.

Flask 인스턴스는 호출 가능하며(호출 메소드 있음) 이 인스턴스는 WSGI 서버에 직접 연결할 수 있습니다.

3. 경로 등록

@route('/')
def index():
    return 'Hello,Flask!'

경로 등록은 URL 규칙과 처리 기능 간의 연관성을 설정하는 것입니다. Flask 프레임워크는 라우팅을 사용하여 HTTP 요청 배포를 완료합니다.

경로에 있는 함수를 보기 함수라고 하며, 해당 반환 값은 HTTP 응답의 본문 내용으로 사용됩니다.

4. WSGI 서버 연결 및 시작

Flask는 개발을 위한 간단한 WSGI 서버를 캡슐화합니다. run()을 호출하여 서버를 시작할 수 있습니다.

app.run(host='0.0.0.0',port=80)

개요

라우팅은 MVC 아키텍처의 웹 프레임워크에서 매우 중요한 개념이며, 본 강좌에서도 중점적으로 다룹니다.

이름에서 알 수 있듯이 라우팅은 혼란에서 벗어날 길을 찾는 것을 의미합니다. Flask 프레임워크에서 라우팅이란 사용자가 요청한 URL에 해당하는 처리 기능을 찾는 것을 의미합니다.

이 강좌에서는 주로 Flask 프레임워크의 라우팅을 다음 측면에서 설명합니다.

애플리케이션에 라우팅을 등록하는 방법은 무엇인가요? 경로가 지원하는 HTTP 메서드를 어떻게 지정합니까? 동적 URL을 일치시키는 방법은 무엇입니까? URL에서 변수 유형을 필터링하는 방법은 무엇입니까? 액세스 포인트/엔드포인트를 이해하는 방법은 무엇입니까? 애플리케이션에 대한 정적 라우팅을 설정하는 방법은 무엇입니까? 다른 보기를 가리키는 URL을 하드코딩하는 것을 방지하는 방법은 무엇입니까?

경로 등록

Flask 애플리케이션에서 라우팅이란 사용자가 요청한 URL과 보기 기능 간의 매핑을 의미합니다. Flask 프레임워크는 HTTP 요청의 URL에 따라 라우팅 테이블에 미리 정의된 URL 규칙을 일치시키고 해당 뷰 함수를 찾아 뷰 함수의 실행 결과를 WSGI 서버에 반환합니다.

Python 개발 WEB 프레임워크 Flask에 대한 자세한 소개

라우팅 테이블은 Flask 애플리케이션에서 매우 핵심적인 위치를 차지하고 있음을 알 수 있습니다. 라우팅 테이블의 내용은 애플리케이션 개발자가 채웁니다.

경로 데코레이터: Flask 애플리케이션 인스턴스의 경로 데코레이터를 사용하여 URL 규칙을 보기 기능에 바인딩할 수 있습니다.

예를 들어 다음 예에서는 URL 규칙 /test를 뷰 함수 test()에 바인딩합니다.

@app.route('/test')
def test():
    return 'this is response'

이 애플리케이션이 호스트 ezhost.com의 루트 디렉터리에 배포된 경우 사용자가 방문할 때:

http://pythontab.com/teset

Flask 프레임워크는 test() 함수를 호출하고 반환 결과는 WSGI 서버로 전달되어 전송됩니다. 방문자에게.

add_url_rule(): 또 다른 동등한 작성 방법은 Flask 애플리케이션 인스턴스의 add_url_route() 메소드를 사용하는 것입니다. 다음 예제에서는 이전 예제와 동일한 경로를 등록합니다.

def test():
    return 'this is response'
app.add_url_route('/test',view_func=test)

사실 경로 등록은 add_url_route() 메서드를 호출하여 경로 데코레이터 내부에서도 구현됩니다. 하지만 분명히 데코레이터를 사용하면 코드가 더 우아해 보입니다.

为路由指定HTTP方法

默认情况下,Flask路由仅支持HTTP的GET请求。可以使用methods关键字参数,在注册 路由时显式地声明视图方法支持的HTTP方法。

例如,下面的示例将URL规则/auth绑定到视图函数v_auth(),这个路由仅支持POST方法:

@app.route('/auth',methods=['POST'])
def v_auth():pass

指定多种HTTP方法支持

关键字参数methods的类型为list,因此可以同时指定多种HTTP方法。

下面的示例中,使URL规则/user同时支持POST方法和GET方法:

@app.route('/user',methods=['POST','GET'])
def v_users():
    if request.method == 'GET':
        return ... # 返回用户列表
    if request.method == 'POST'
        return ... #创建新用户

这个特性使Flask非常易于开发REST架构的后台服务,而不仅仅局限于传统的动态网页。

匹配动态URL

有时我们需要将同一类URL映射到同一个视图函数处理,比如,使用同一个视图函数 来显示不同用户的个人档案。我们希望以下的URL都可以分发到同一个视图函数:

Python 개발 WEB 프레임워크 Flask에 대한 자세한 소개

在Flask中,可以将URL中的可变部分使用一对小括号声明为变量, 并为视图函数声明同名的参数:

@app.route('/user/')
def v_user(uname):
    return '%s\'s Profile' % uname

在上面的示例中,URL规则中的

URL变量类型过滤

考虑下面的示例,我们希望通过HTTP共享文件夹/var/readonly中的文件:

/var

    /readonly

        /a.txt

        /b.txt

        /repo

           /c.txt

           /d.txt

简单思考一下就有答案了。我们可以构造URL规则/file/

@app.route('/file/')
def v_file(fname):
    fullname = os.path.join('/var/readonly',fname)
    f = open(fullname)
    cnt =  f.read()
    f.close()
    return cnt

测试结果表明,/file/a.txt和/file/b.txt都没有问题,但是/file/repo/c.txt和 /file/repo/d.txt却会失败。

这是因为,默认情况下,在URL规则中的变量被视为不包含/的字符串。/file/repo/c.txt 是没有办法匹配URL规则/file/

可以使用内置的path转换器告诉Flask框架改变这一默认行为。path转换器允许 规则匹配包含/的字符串:

@app.route('/file/')

在Flask中,转换器/converter用来对从URL中提取的变量进行预处理,这个过程 发生在调用视图函数之前。Flask预置了四种转换器:

string - 匹配不包含/的字符串,这是默认的转换器

path - 匹配包含/的字符串

int - 只有当URL中的变量是整型值时才匹配,并将变量转换为整型

float - 只有当URL中的变量是浮点值时才匹配,并将变量转换为浮点型

访问点/endpoint

我们一直强调,路由的作用是根据请求的URL,找到对应的视图函数。这没错,但是在 Flask框架中,请求任务的分发并不是直接从用户请求的URL一步定位到视图函数, 两者之间隔着一个访问点/endpoint。

以下面的代码为例,我们看Flask怎样实现请求的分发:

@app.route('/home')
def home():pass

在Flask内部使用两张表维护路由:

url_map :维护URL规则和endpoint的映射

view_functions :维护endpoint和视图函数的映射。

以用户访问URL/home为例,Flask将首先利用url_map找到所请求URL对应的 endpoint,即访问点home,然后再利用view_functions表查找home这个访问点 对应的视图函数,最终匹配到函数home():

Python 개발 WEB 프레임워크 Flask에 대한 자세한 소개

默认访问点 :当我们使用route装饰器注册路由时,默认使用被装饰函数的 函数名(name)作为访问点,因此,你看到上面的表中,路由中的访问点为home。

自定义访问点 :可以在使用route装饰器或调用add_url_rule()方法注册路由时,使用 endpoint关键字参数改变这一默认行为:

@app.route('/home',endpoint='whocare')
def home():pass

此时的两张路由表将变成这样:

Python 개발 WEB 프레임워크 Flask에 대한 자세한 소개

静态目录路由

当创建应用实例时,Flask将自动添加一条静态目录路由,其访问点 始终被设置为static,URL规则默认被设置为/static,本地路径默认被 设置为应用文件夹下的static子文件夹:

+------------------------------------------------------------+ | url rule | endpoint | view_function | | /static | static | Flask.send_static_file | +------------------------------------------------------------+ 如果你的应用目录如下:

/app

    /web.py

    /static

        /main.css

        /jquery.min.js   

那么启动应用后就可以通过URL/static/main.css访问static文件夹下的main.css了。

除了访问点被固定为static,静态目录的URL规则和本地目录都是可以根据应用情况进行调整。

改变默认的本地路径 :可以在创建应用对象时使用关键字参数static_folder改变 默认的静态文件夹。例如,你的静态文件都存放在应用下的assets目录下, 那么可以按如下的方式创建应用对象:

app = Flask(name,static_folder='assets') 也可以使用一个绝对路径:

app = Flask(name,static_folder='/var/www/static') 改变默认的本地路径并不会对路由表产生影响。

改变默认的URL规则 : 如果不喜欢静态目录URL/static,也可以在创建应用 对象时使用关键字参数static_url_path换一个别的名字。

下面的示例中,将应用下的assets文件夹注册为静态目录/assets:

app = Flask(name,static_folder='assets',static_url_path='/assets') 当应用运行后,通过URL/assets/main.css就可以访问assets文件夹下的 main.css文件了。

这时的路由表变化为:

+------------------------------------------------------------+ | url | endpoint | view_function | | /assets | static | Flask.send_static_file | +------------------------------------------------------------+

构造URL

在一个实用的视图中,不可避免地存在指向其他视图的链接。在之前的课程示例中,我们 都是在视图函数中这样硬编码这些链接URL的:

@app.route('/')
def v_index():
    return 'tech'
@app.route('/tech') 
def v_tech():pass

大部分情况下这种硬编码URL是可以工作的。但如果这个应用被挂在WSGI服务器的一个 子路径下,比如:/app1,那么用户访问URL/tech是不会成功的,这时应当访问/app1/tech 才可以正确地路由到视图函数v_tech()。

我们应当使用访问点让Flask框架帮我们计算链接URL。简单地给url_for()函数传入 一个访问点,它返回将是一个可靠的URL地址:

@app.route('/')
def v_index():
    print url_for('v_contacts')  # /contact
    return 'see console output!'
@app.route('/contact')
def v_contacts():pass

添加查询参数 : 使用关键字参数,可以在构造的URL中生成查询串。下面的调用将生成 /contact?

format=json
@app.route('/')
def v_index():
    print url_for('v_contacts',format='json')
    return  ''
@app.route('/contact')     
def v_contacts():pass

添加URL变量 : 如果指定访问点对应的视图函数接收参数,那么关键字参数将生成对应的参数URL。下面的 示例将生成/contact/Julia?format=html:

@app.route('/')
def v_index():
    print url_for('v_contact',name='Julia',format='html')
    return ''
@app.route('/contact/')
def v_contact(name):pass

添加锚点 :使用_anchor关键字可以为生成的URL添加锚点。下面的示例将生成URL /contact#part2

@app.route('/')
def v_index():
    print url_for('v_contacts',_anchor='part2')
@app.route('/contact')
def v_contacts():pass

外部URL : 默认情况下,url_for()生成站内URL,可以设置关键字参数_external 为True,生成包含站点地址的外部URL。下面的示例将生成URLhttp://

@app.route('/')
def v_index():
    print url_for('v_contacts',_external=True)
@app.route('/contact')
def v_contacts():pass

위 내용은 Python 개발 WEB 프레임워크 Flask에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Numpy 배열은 배열 모듈을 사용하여 생성 된 배열과 어떻게 다릅니 까?Numpy 배열은 배열 모듈을 사용하여 생성 된 배열과 어떻게 다릅니 까?Apr 24, 2025 pm 03:53 PM

numpyarraysarebetterfornumericaloperations 및 multi-dimensionaldata, mumemer-efficientArrays

Numpy Array의 사용은 Python에서 어레이 모듈 어레이를 사용하는 것과 어떻게 비교됩니까?Numpy Array의 사용은 Python에서 어레이 모듈 어레이를 사용하는 것과 어떻게 비교됩니까?Apr 24, 2025 pm 03:49 PM

numpyarraysarebetterforheavynumericalcomputing, whilearraymoduleisiMoresuily-sportainedprojectswithsimpledatatypes.1) numpyarraysofferversatively 및 formanceforgedatasets 및 complexoperations.2) Thearraymoduleisweighit 및 ep

CTYPES 모듈은 파이썬의 어레이와 어떤 관련이 있습니까?CTYPES 모듈은 파이썬의 어레이와 어떤 관련이 있습니까?Apr 24, 2025 pm 03:45 PM

ctypesallowscreatingandmanipulatingC-stylearraysinPython.1)UsectypestointerfacewithClibrariesforperformance.2)CreateC-stylearraysfornumericalcomputations.3)PassarraystoCfunctionsforefficientoperations.However,becautiousofmemorymanagement,performanceo

파이썬의 맥락에서 '배열'및 '목록'을 정의하십시오.파이썬의 맥락에서 '배열'및 '목록'을 정의하십시오.Apr 24, 2025 pm 03:41 PM

Inpython, "목록", isaversatile, mutablesequencetatcanholdmixeddatattypes, whilean "array"isamorememory-efficed, homogeneouseceenceRequiringElements ofthesAmeType.1) ListSareIdeAldiversEdatastorageandmanipulationDuetoIrflexibrieth

파이썬 목록은 변이 가능합니까? 파이썬 어레이는 어떻습니까?파이썬 목록은 변이 가능합니까? 파이썬 어레이는 어떻습니까?Apr 24, 2025 pm 03:37 PM

PythonlistsAndarraysareBotheBotheBothebothable.1) ListSareflexibleandsupporterogenousDatabutarabestemory-efficient.2) Arraysaremorememory-efforhomogeneousdatabutlessverstile, CorrectTypecodeusagetoavoidercer가 필요합니다.

Python vs. C : 주요 차이점 이해Python vs. C : 주요 차이점 이해Apr 21, 2025 am 12:18 AM

Python과 C는 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1) Python은 간결한 구문 및 동적 타이핑으로 인해 빠른 개발 및 데이터 처리에 적합합니다. 2) C는 정적 타이핑 및 수동 메모리 관리로 인해 고성능 및 시스템 프로그래밍에 적합합니다.

Python vs. C : 프로젝트를 위해 어떤 언어를 선택해야합니까?Python vs. C : 프로젝트를 위해 어떤 언어를 선택해야합니까?Apr 21, 2025 am 12:17 AM

Python 또는 C를 선택하는 것은 프로젝트 요구 사항에 따라 다릅니다. 1) 빠른 개발, 데이터 처리 및 프로토 타입 설계가 필요한 경우 Python을 선택하십시오. 2) 고성능, 낮은 대기 시간 및 근접 하드웨어 제어가 필요한 경우 C를 선택하십시오.

파이썬 목표에 도달 : 매일 2 시간의 힘파이썬 목표에 도달 : 매일 2 시간의 힘Apr 20, 2025 am 12:21 AM

매일 2 시간의 파이썬 학습을 투자하면 프로그래밍 기술을 효과적으로 향상시킬 수 있습니다. 1. 새로운 지식 배우기 : 문서를 읽거나 자습서를 시청하십시오. 2. 연습 : 코드를 작성하고 완전한 연습을합니다. 3. 검토 : 배운 내용을 통합하십시오. 4. 프로젝트 실무 : 실제 프로젝트에서 배운 것을 적용하십시오. 이러한 구조화 된 학습 계획은 파이썬을 체계적으로 마스터하고 경력 목표를 달성하는 데 도움이 될 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.