當我將文件名作為變量從 flask 發(fā)送到 jinja2 時,它中斷了:我正在使用 SQLAlchemy 來存儲有關項目的數據(標題、描述和用于說明的圖片),并使用 Flask 將此數據發(fā)送到 jinja2 頁面。這是路線:@app.route('/projects')def projects(): project_matrix = listOfProjects() for i in range(0, len(project_matrix)): print(project_matrix[i][3]) return render_template("projects.html", projects=project_matrix)print(project_matrix[i][3]) 在終端中顯示每個項目的圖片文件名。這是我重新加載頁面時出現在終端中的內容tethermc.jpggraph.png127.0.0.1 - - [13/May/2020 01:07:20] "GET /projects HTTP/1.1" 200 -127.0.0.1 - - [13/May/2020 01:07:20] "GET /static/css/main.css HTTP/1.1" 200 -127.0.0.1 - - [13/May/2020 01:07:20] "GET /static/img/uploads/%7B%7Bproject%5B3%5D%7D%7D HTTP/1.1" 200 -127.0.0.1 - - [13/May/2020 01:07:20] "GET /favicon.ico HTTP/1.1" 200 -這是頁面的模板: {% for project in projects %} <div class="project"> <div class="projectTitle"> {{ project[1] }} </div> <div class="projectHolding"> <div class="projectDescription" type="html"> {{ project[2] }} </div> <div class="projectImg"> <img src="{{ url_for('static', filename = 'img/uploads/'+'{{project[3]}}') }}" style="min-width: 100px; max-height: 300px;" alt="alt" /> </div> </div> </div> {% endfor %}當我加載頁面時,除了不顯示的圖像外,內容沒有改變。當我檢查元素(圖像塊)時,我看到:<img src="/static/img/uploads/%7B%7Bproject%5B3%5D%7D%7D" style="min-width: 100px; max-height: 300px;" alt="alt"/>有src="/static/img/uploads/%7B%7Bproject%5B3%5D%7D%7D" 代替src="/static/img/uploads/ethermc.jpg" 或src="/static/img/uploads/graph.png"你知道是什么導致了這個問題嗎?
1 回答

臨摹微笑
TA貢獻1982條經驗 獲得超2個贊
問題出在這一行:
src="{{ url_for('static', filename = 'img/uploads/'+'{{project[3]}}') }}"
.
首先,這部分有單引號:'{{project[3]}}'
這導致這些字符按字面解釋,而不是做“你想要的”并使用 project[3] 變量中的值。如果您對大括號進行 URL 編碼,您會得到 %7B 或 %7D,這可能有助于您了解錯誤文件名的組成方式!
其次,您正在“嵌套”花括號,這是不需要的。project[3] 旁邊的 {{ }} 按字面解釋為大括號,它們被編碼為您在最終文件名中看到的 %7B 和 %7D。這里不需要它們,因為當您打開“外部”花括號時,您現在處于一個代碼塊中,并且它們之間的所有內容(基本上)都是 python 代碼。
所以你要運行的 Python 代碼是:
url_for('static', filename = 'img/uploads/'+project[3])
這意味著您應該將該行替換為:
src="{{ url_for('static', filename = 'img/uploads/'+project[3]) }}"
添加回答
舉報
0/150
提交
取消