Django View中跳转的陷阱

Django中在view中对接口做重定向常用的有两种方式。 - shortcuts.redirect 可以传入url或者view name,view name可以指定view的app方便加速查找 - HttpResponseRedirect 传入url直接做重定向

两种方式虽然都可以做跳转,但在不同场景中不当的使用可能带来性能问题

从上图可以看出,shortcuts.redirect这种方式的跳转耗时达到了3秒多,传入的url参数大致如下

'/api/v4/wap_service/obj_detail_view/?partner=test&obj_id=v3232nids_owqjrnrek'

细看了一下shortcuts.redirect代码,发现它的逻辑要更复杂一些,识别跳转的过程分三步。 - 如果传入的是model并且定义了get_absolute_url方法,则会按照该方法中定义的url跳转 - 假设传入的是view并尝试根据view解析(reverse)出url。怎么解析呢,正则匹配所有的url pattern,找出对应的url - 如果前面两项都失败了,则直接假设传入的字符串是url并做跳转

有意思的是shortcuts.redirect最终还是会构造HttpResponseRedirect对象来完成跳转,只不过如果一开始你就知道传入的参数是url的话,那它做的工作就会多了两步,其中有一步还是正则表达式来匹配。

可以确定的是,带着参数的url你去做reverse来识别view的时候,肯定是失败的。也就是说前两部都是没有意义的,遍历所有的url pattern自然是耗时的,url越长效果越明显。

如果明确是根据url跳转的话,直接借助HttpResponseRedirect就行了,简单明了。