django/urls/resolvers.py
def get_resolver(urlconf=None):
if urlconf is None:
urlconf = settings.ROOT_URLCONF
return _get_cached_resolver(urlconf)
@functools.lru_cache(maxsize=None)
def _get_cached_resolver(urlconf=None):
return URLResolver(RegexPattern(r’^/'), urlconf)
传入参数 urlconf
,参数有个默认值 settings.ROOT_URLCONF
,打印出来是 myproject.urls
,其实就是项目全局下的路由文件。
返回值是 URLResolver
类,这个类就比较复杂了,看了源码也不是很明白应该怎么处理这个类。
django/urls/resolvers.py
class URLResolver:
省略了一堆代码
@cached_property
def urlconf_module(self):
if isinstance(self.urlconf_name, str):
return import_module(self.urlconf_name)
else:
return self.urlconf_name
@cached_property
def url_patterns(self):
urlconf_module might be a valid set of patterns, so we default to it
patterns = getattr(self.urlconf_module, “urlpatterns”, self.urlconf_module)
try:
iter(patterns)
except TypeError as e:
msg = (
"The included URLconf ‘{name}’ does not appear to have any "
"patterns in it. If you see valid patterns in the file then "
“the issue is probably caused by a circular import.”
)
raise ImproperlyConfigured(msg.format(name=self.urlconf_name)) from e
return patterns
不过还是有一个方法引起了我的注意,毕竟我们要取 url,那跟 url 相关的函数还是要特殊关照一下。
打印一下这个结果,看看有没有发现。
print(get_resolver(‘myproject.urls’).url_patterns)
输出
[
…
<URLPattern ‘api/v1/api-doc’ [name=‘api-doc’]>,
<URLResolver (api-docs:api-docs) # ‘api/v1/drf-api-doc’>]
结果是一个列表,元素有两种,分别是 URLPattern
类和 URLResolver
类。
django/urls/resolvers.py
class URLPattern:
def init(self, pattern, callback, default_args=None, name=None):
最后
🍅 硬核资料:关注即可领取PPT模板、简历模板、行业经典书籍PDF。
🍅 技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在群里喊一声。
🍅 面试题库:由技术群里的小伙伴们共同投稿,热乎的大厂面试真题,持续更新中。
🍅 知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库、Python、前端等等。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!