답변:
Armin이 받아 들여진 대답으로 나를 펀치로 이겼지 만 누군가가 어떻게 할 수 있는지에 대한 실제 예제를 원할 경우 Flask에서 정규식 매처를 구현 한 방법에 대한 축약 된 예를 보여줄 것이라고 생각했습니다.
from flask import Flask
from werkzeug.routing import BaseConverter
app = Flask(__name__)
class RegexConverter(BaseConverter):
def __init__(self, url_map, *items):
super(RegexConverter, self).__init__(url_map)
self.regex = items[0]
app.url_map.converters['regex'] = RegexConverter
@app.route('/<regex("[abcABC0-9]{4,6}"):uid>-<slug>/')
def example(uid, slug):
return "uid: %s, slug: %s" % (uid, slug)
if __name__ == '__main__':
app.run(debug=True, host='0.0.0.0', port=5000)
이 URL은 200 : http : // localhost : 5000 / abc0-foo / 와 함께 반환되어야합니다 .
이 URL은 404 : http : // localhost : 5000 / abcd-foo / 와 함께 반환되어야합니다 .
self.regex
있지만 일치는 어디에서 발생합니까?
임의의 식과 일치하는 사용자 지정 변환기를 연결할 수 있습니다. 사용자 지정 변환기
from random import randrange
from werkzeug.routing import Rule, Map, BaseConverter, ValidationError
class BooleanConverter(BaseConverter):
def __init__(self, url_map, randomify=False):
super(BooleanConverter, self).__init__(url_map)
self.randomify = randomify
self.regex = '(?:yes|no|maybe)'
def to_python(self, value):
if value == 'maybe':
if self.randomify:
return not randrange(2)
raise ValidationError()
return value == 'yes'
def to_url(self, value):
return value and 'yes' or 'no'
url_map = Map([
Rule('/vote/<bool:werkzeug_rocks>', endpoint='vote'),
Rule('/vote/<bool(randomify=True):foo>', endpoint='foo')
], converters={'bool': BooleanConverter})
to_python
않습니다
캐치 모든 유형의 경로를 작성하고 메소드 내에서 복잡한 라우팅을 수행 할 수도 있습니다.
from flask import Flask
app = Flask(__name__)
@app.route('/', methods=['GET', 'POST'], defaults={'path': ''})
@app.route('/<path:path>', methods=['GET', 'POST'])
def catch_all(path):
return 'You want path: %s' % path
if __name__ == '__main__':
app.run()
이것은 모든 요청과 일치합니다. 자세한 내용은 Catch-All URL을 참조하세요 .