python - Django前臺(tái)url未能正確訪問方法求助?
問題描述
大家好,小弟初學(xué)django,現(xiàn)在想學(xué)著做一個(gè)下載功能,前臺(tái)html設(shè)置超鏈接,通過后臺(tái)訪問方法獲取到文件名并下載。代碼如下:前臺(tái):(比較簡(jiǎn)單,只是一個(gè)table里面套帶超鏈接的字)
URL配置:
urlpatterns = [ url(r’^admin/’, admin.site.urls), url(r’^register/’,views.userRigister,name=’register’), url(r’^register/(.*)/$’,views.file_download,name=’download’),]
VIEW方法:
def userRigister(req):status=’welcome’#js alert出信息return render(req, ’register.html’, {’status’:json.dumps(status)})def file_download(request,filename): print(filename) def file_iterator(file_name, chunk_size=1024):with open(file_name) as f: while True:c = f.read(chunk_size)if c: yield celse: break if os.path.exists(’software/’ + filename):the_file_name = filenameresponse = StreamingHttpResponse(file_iterator(the_file_name))return response else:return HttpResponse(’error!no such file!’)
小弟的目的是正常訪問同一個(gè)頁面時(shí),選擇可下載的瀏覽器,點(diǎn)擊超鏈接按鈕后,訪問file_download方法并下載對(duì)應(yīng)瀏覽器。但是目前無法訪問到file_download方法,懇請(qǐng)各位大神指點(diǎn)。謝謝了
問題解答
回答1:Django匹配url的時(shí)候是在url列表中從上往下依次匹配能被^register/(.*)/$匹配的一定能被上面的^register/匹配所以就出現(xiàn)了^register/(.*)/$永遠(yuǎn)匹配不到的情況解決方法很簡(jiǎn)單,這兩個(gè)調(diào)個(gè)順序就好
url(r’^admin/’, admin.site.urls),url(r’^register/(.*)/$’,views.file_download,name=’download’),url(r’^register/’,views.userRigister,name=’register’),
在使用Django的url解析功能的時(shí)候,要記住越詳細(xì)的url要越往前放,越“模糊”的url要越靠后。
相關(guān)文章:
1. mysql - 數(shù)據(jù)庫表中,兩個(gè)表互為外鍵參考如何解決2. 哭遼 求大佬解答 控制器的join方法怎么轉(zhuǎn)模型方法3. sql語句 - 如何在mysql中批量添加用戶?4. mysql - 表名稱前綴到底有啥用?5. mysql儲(chǔ)存json錯(cuò)誤6. 編輯成功不顯示彈窗7. mysql - 怎么生成這個(gè)sql表?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實(shí)現(xiàn)存在即更新應(yīng)該使用哪個(gè)標(biāo)簽?9. Navicat for mysql 中以json格式儲(chǔ)存的數(shù)據(jù)存在大量反斜杠,如何去除?10. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。
