{"id":16690,"date":"2024-01-29T22:48:34","date_gmt":"2024-01-29T19:18:34","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/"},"modified":"2024-01-29T22:48:34","modified_gmt":"2024-01-29T19:18:34","slug":"%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/","title":{"rendered":"\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0628\u0627 \u0641\u0644\u0627\u0633\u06a9"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/#%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%81%d9%84%d8%a7%d8%b3%da%a9\" >\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0641\u0644\u0627\u0633\u06a9<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/#%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%db%8c%da%a9_%d9%81%d9%87%d8%b1%d8%b3%d8%aa_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9\" >\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0641\u0647\u0631\u0633\u062a \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/#%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%ac%d8%a7%d9%88%d8%a7_%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa\" >\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/#%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d8%aa%d8%b5%d8%a7%d9%88%db%8c%d8%b1_%d9%88_%d8%b3%d8%a7%db%8c%d8%b1_%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d9%81%d8%a7%db%8c%d9%84\" >\u0627\u0631\u0627\u0626\u0647 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u0633\u0627\u06cc\u0631 \u0627\u0646\u0648\u0627\u0639 \u0641\u0627\u06cc\u0644<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/#%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9_%d8%a8%d8%a7_%db%8c%da%a9_%d8%b3%db%8c%d8%b3%d8%aa%d9%85_%d8%b3%d8%a7%d8%ae%d8%aa\" >\u0622\u0645\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0628\u0627 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0633\u0627\u062e\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/#%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9_%d8%af%d8%b1_%d8%aa%d9%88%d9%84%db%8c%d8%af\" >\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u062f\u0631 \u062a\u0648\u0644\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b1%d8%a7%d8%a6%d9%87-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9-%d8%a8%d8%a7-%d9%81%d9%84%d8%a7%d8%b3%da%a9\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 8<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div><noscript><\/noscript><\/p>\n<h2 id=\"settingupflask\"><span class=\"ez-toc-section\" id=\"%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%81%d9%84%d8%a7%d8%b3%da%a9\"><\/span>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0641\u0644\u0627\u0633\u06a9<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p><a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/flask.pocoo.org\/\">\u0641\u0644\u0627\u0633\u06a9<\/a> \u06cc\u06a9 \u0627\u0646\u062a\u062e\u0627\u0628 \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0628\u0647 \u0631\u0648\u0634 \u0645\u0627\u0698\u0648\u0644\u0627\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a.  \u0628\u0631 \u062e\u0644\u0627\u0641 \u062c\u0646\u06af\u0648 \u0648 \u0622\u0646\u0627\u0644\u0648\u06af \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0645\u0627\u0646\u0646\u062f Ruby \u0631\u0648\u06cc  Rails, Flask \u06cc\u06a9 \u0645\u06cc\u06a9\u0631\u0648 \u0641\u0631\u06cc\u0645\u0648\u0631\u06a9 \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0641\u0642\u0637 \u0634\u0627\u0645\u0644 \u0645\u0648\u0627\u0631\u062f\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u0627\u0635\u0644\u06cc \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a\u060c \u0648 \u0628\u062e\u0634 \u0639\u0645\u062f\u0647 \u0627\u06cc \u0627\u0632 \u0627\u0646\u062a\u062e\u0627\u0628 \u0647\u0627 \u0631\u0627 \u0641\u0631\u0627\u062a\u0631 \u0627\u0632 \u0622\u0646 \u0632\u06cc\u0631 \u0645\u062c\u0645\u0648\u0639\u0647 \u062d\u062f\u0627\u0642\u0644 \u0628\u0647 \u0634\u0645\u0627 \u0648\u0627\u06af\u0630\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0627\u06cc\u0646 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0645\u0632\u06cc\u062a \u0628\u0632\u0631\u06af\u06cc \u062f\u0631 \u0633\u0627\u062f\u0647 \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 \u06a9\u062f \u0648 \u06af\u0631\u062f\u0634 \u06a9\u0627\u0631 \u0634\u0645\u0627 \u0628\u0647 \u0648\u06cc\u0698\u0647 \u062f\u0627\u0631\u062f \u0631\u0648\u06cc \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc \u06a9\u0648\u0686\u06a9\u062a\u0631  \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0628\u0647 \u0634\u0645\u0627 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062b\u0627\u0628\u062a \u0645\u0627\u0646\u0646\u062f JS\u060c CSS \u0648 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Flask \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u06cc\u062f.<\/p>\n<p>\u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u067e\u0627\u06cc\u062a\u0648\u0646 3 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u062f.  \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <strong>pyenv<\/strong> \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u06a9\u0647 \u0628\u0647 \u0634\u0645\u0627 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u0646\u0633\u062e\u0647 \u0647\u0627\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f.  \u062f\u0646\u0628\u0627\u0644 \u06a9\u0631\u062f\u0646 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.froehlichundfrei.de\/blog\/2014-11-30-my-transition-to-python3-and-pyenv-goodby-virtualenvwrapper\/\">\u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627<\/a> \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 3 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <strong>pyenv<\/strong>.  \u0627\u06af\u0631 \u062a\u0631\u062c\u06cc\u062d \u0645\u06cc \u062f\u0647\u06cc\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/docs.python-guide.org\/en\/latest\/dev\/virtualenvs\/#lower-level-virtualenv\">virtualenv<\/a> \u062f\u0631 \u0639\u0648\u0636\u060c \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0645\u0633\u062a\u0646\u062f\u0627\u062a \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0627\u0645\u0627 \u0641\u0642\u0637 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u06cc\u06a9 \u0645\u062d\u06cc\u0637 Python 3 \u0641\u0639\u0627\u0644 \u062f\u0627\u0631\u06cc\u062f.<\/p>\n<p>\u0642\u0628\u0644 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u062a\u0648\u0627\u0646\u06cc\u0645 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0631\u0627 \u0628\u0627 Flask \u0627\u0631\u0627\u0626\u0647 \u06a9\u0646\u06cc\u0645\u060c \u0628\u0627\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645 \u0648 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0633\u0627\u062f\u0647 \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645.  \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c Flask \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">$ pip install flask\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u067e\u0627\u06cc\u0647 \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f \u06a9\u0647 \u062f\u0631 \u062e\u062f\u0645\u062a \u0641\u0631\u0648\u062f \u0627\u0633\u062a page \u0631\u0648\u06cc  \u06a9\u0647 \u0645\u0627 \u0645\u062a\u0646 \u06a9\u0644\u0627\u0633\u06cc\u06a9 &#8220;Hello World&#8221; \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f.<\/p>\n<pre><code class=\"hljs\">$ mkdir serving_static\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u062c\u062f\u06cc\u062f\u060c \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0648 \u0622\u0646 \u0631\u0627 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u062f.  \u062f\u0631 \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u06cc\u06a9 \u0645\u0633\u06cc\u0631 Flask \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u067e\u06cc\u0627\u0645 \u062e\u0648\u0634 \u0622\u0645\u062f\u06af\u0648\u06cc\u06cc \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0642\u0627\u0644\u0628 Flask \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u06cc\u0645.<\/p>\n<pre><code class=\"hljs\">\n\n<span class=\"hljs-keyword\">from<\/span> flask <span class=\"hljs-keyword\">import<\/span> Flask\n<span class=\"hljs-keyword\">from<\/span> flask <span class=\"hljs-keyword\">import<\/span> render_template\n\n\napp = Flask(__name__)\n\n\n<span class=\"hljs-meta\">@app.route(<span class=\"hljs-params\"><span class=\"hljs-string\">\"\/\"<\/span><\/span>)<\/span>\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">hello<\/span>():<\/span>\n    message = <span class=\"hljs-string\">\"Hello, World\"<\/span>\n    <span class=\"hljs-keyword\">return<\/span> render_template(<span class=\"hljs-string\">'index.html'<\/span>, message=message)\n\n\n<span class=\"hljs-keyword\">if<\/span> __name__ == <span class=\"hljs-string\">\"__main__\"<\/span>:\n    app.run(debug=<span class=\"hljs-literal\">True<\/span>)\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0642\u0627\u0644\u0628\u06cc \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u067e\u06cc\u0627\u0645 \u062e\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.  \u06cc\u06a9 \u0641\u0627\u06cc\u0644 HTML \u062f\u0631 \u0645\u062d\u0644 &#8220;serving_static\/templates\/index.html&#8221; \u0628\u0627 \u06a9\u062f HTML \u0632\u06cc\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f.  \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 <code>message<\/code> \u0645\u062a\u063a\u06cc\u0631 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0632 <code>serve.py<\/code> \u0641\u0627\u06cc\u0644 \u0628\u0627\u0644\u0627<\/p>\n<pre><code class=\"hljs\">\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">html<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">head<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">title<\/span>&gt;<\/span>Flask Shop<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">title<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">head<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">body<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>{{message}}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">body<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">html<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0622\u0645\u0627\u062f\u0647 \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0633\u062a\u06cc\u0645.  \u0628\u0627\u0632\u06af\u0634\u062a \u0628\u0647 &#8220;serving_static&#8221; root \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc\u060c \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">$ python serve.py\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0633\u0631\u0648\u0631 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0634\u0648\u062f\u060c \u067e\u06cc\u0627\u0645\u06cc \u0645\u0628\u0646\u06cc \u0628\u0631 \u0634\u0631\u0648\u0639 \u0622\u0646 \u0648 \u06cc\u06a9 URL \u0628\u0631\u0627\u06cc \u0645\u0634\u0627\u0647\u062f\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631\u06cc\u0627\u0641\u062a \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f.  \u0627\u06cc\u0646 URL \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u062e\u0648\u062f \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f \u0648 \u0627\u06a9\u0646\u0648\u0646 \u0628\u0627\u06cc\u062f \u067e\u06cc\u0627\u0645 &#8220;Hello, World&#8221; \u0645\u0627 \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0628\u0628\u06cc\u0646\u06cc\u062f.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/serving-static-files-flask-1.png\" alt=\"\u0633\u0644\u0627\u0645 \u062f\u0646\u06cc\u0627\" title=\"\"><\/p>\n<p>Flask \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u06a9\u0648\u0631\u0627\u062a\u0648\u0631\u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f \u0622\u0646\u0686\u0647 \u062f\u0631 \u0622\u0646 \u062f\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f <code>serve.py<\/code> \u062f\u0631 \u0628\u0627\u0644\u0627.  \u06cc\u06a9 \u062f\u06a9\u0648\u0631\u0627\u062a\u0648\u0631 \u0645\u0627\u0646\u0646\u062f <code>@app.route(\"\/\")<\/code> \u06cc\u06a9 \u0645\u0633\u06cc\u0631 \u062c\u062f\u06cc\u062f \u062f\u0631 \u0645\u0633\u06cc\u0631 \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.  \u062a\u0639\u0631\u06cc\u0641 \u062a\u0627\u0628\u0639 \u0632\u06cc\u0631 \u062d\u0627\u0648\u06cc \u0645\u0646\u0637\u0642 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u062f\u0631 \u0622\u0646 URL \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<h2 id=\"servingstaticfilesusingastaticdirectory\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%db%8c%da%a9_%d9%81%d9%87%d8%b1%d8%b3%d8%aa_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9\"><\/span>\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0641\u0647\u0631\u0633\u062a \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0631\u0627\u06cc\u062c\u200c\u062a\u0631\u06cc\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9\u06cc \u06a9\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0627\u0631\u0627\u0626\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSS \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u062a\u0627\u0646 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0627\u06cc\u0644\u200c\u0633\u0627\u0632\u06cc \u0628\u0631\u0646\u0627\u0645\u0647\u060c \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u0631\u0641\u062a\u0627\u0631 \u067e\u0648\u06cc\u0627 \u0631\u0627 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. page.  \u062f\u0631 \u0627\u06cc\u0646 \u0628\u062e\u0634 \u0645\u06cc\u200c\u0628\u06cc\u0646\u06cc\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSS \u0648 JavaScript \u0631\u0627 \u0628\u0627 \u0627\u0641\u0632\u0648\u062f\u0646 \u0622\u0646\u0647\u0627 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0633\u0627\u062f\u0647\u200c\u0627\u06cc \u06a9\u0647 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u06cc\u0645\u060c \u0627\u0631\u0627\u0626\u0647 \u06a9\u0631\u062f.<\/p>\n<p>\u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u062f\u0631 Flask \u0645\u0633\u06cc\u0631 \u062e\u0627\u0635\u06cc \u062f\u0627\u0631\u0646\u062f.  \u0647\u0645\u0647 URL \u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0647 \u0628\u0627 &#8220;\/static&#8221; \u0634\u0631\u0648\u0639 \u0645\u06cc \u0634\u0648\u0646\u062f\u060c \u0637\u0628\u0642 \u0642\u0631\u0627\u0631\u062f\u0627\u062f\u060c \u0627\u0632 \u067e\u0648\u0634\u0647 \u0627\u06cc \u062f\u0631 &#8220;\/static&#8221; \u062f\u0631 \u062f\u0627\u062e\u0644 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f. root \u067e\u0648\u0634\u0647<\/p>\n<p>\u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u0627\u0633\u062a \u06a9\u0647 \u0627\u06af\u0631 \u06cc\u06a9 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221; \u062f\u0631 \u062f\u0627\u062e\u0644 \u067e\u0648\u0634\u0647 &#8220;serving_static&#8221; \u0627\u0635\u0644\u06cc \u062e\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0645\u0627\u0646\u0646\u062f CSS\u060c JS\u060c \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u0633\u0627\u06cc\u0631 \u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627 \u0631\u0627 \u0628\u0627 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646\u0647\u0627 \u062f\u0631 \u062f\u0627\u062e\u0644 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221; \u0627\u0631\u0627\u0626\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u067e\u06cc\u0627\u0645 \u062e\u0648\u0634\u0627\u0645\u062f\u06af\u0648\u06cc\u06cc \u0631\u0627 \u062f\u0631 \u0641\u0647\u0631\u0633\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u0645 page \u0628\u0631\u0627\u06cc \u0645\u0639\u0631\u0641\u06cc &#8220;The Flask Shop&#8221;\u060c \u06cc\u06a9 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u062e\u06cc\u0627\u0644\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0628\u0627\u0632\u062f\u06cc\u062f\u06a9\u0646\u0646\u062f\u06af\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u06a9\u062a\u0627\u0628 \u0647\u0627\u06cc Flask \u0631\u0627 \u062e\u0631\u06cc\u062f\u0627\u0631\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0627\u0628\u062a\u062f\u0627 \u0634\u0627\u062e\u0635 \u0631\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 page \u0627\u0644\u06af\u0648\u06cc\u06cc \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u0646\u0627\u0645 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0641\u0647\u0631\u0633\u062a\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u0627\u062e\u062a\u06cc\u0627\u0631 \u0628\u0627\u0632\u062f\u06cc\u062f\u06a9\u0646\u0646\u062f\u06af\u0627\u0646 \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f \u0631\u0648\u06cc \u0641\u0631\u0648\u0634.  \u0627\u0644\u06af\u0648\u06cc HTML \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 &#8220;serving_static_\/templates\/index.html&#8221; \u0628\u0627 \u0627\u06cc\u0646 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0628\u0647\u200c\u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<pre><code class=\"hljs\">\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">html<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">head<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">title<\/span>&gt;<\/span>Flask Shop<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">title<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">link<\/span> <span class=\"hljs-attr\">rel<\/span>=<span class=\"hljs-string\">\"stylesheet\"<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/static\/style.css\"<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">head<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">body<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>{{message}}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h3<\/span>&gt;<\/span>\u0631\u0648\u06cc sale this week alone:<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h3<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">ol<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span>&gt;<\/span>Flask By Example<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">li<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span>&gt;<\/span>Uncluttered Flask<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">li<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span>&gt;<\/span>Flask From First Principles<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">li<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">ol<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/static\/scripts.js\"<\/span> <span class=\"hljs-attr\">charset<\/span>=<span class=\"hljs-string\">\"utf-8\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">body<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">html<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 \u0639\u0646\u0648\u0627\u0646 page \u0627\u06a9\u0646\u0648\u0646 &#8220;\u0641\u0644\u0627\u0633\u06a9\u200c\u0641\u0631\u0648\u0634\u06cc&#8221; \u0627\u0633\u062a \u0648 \u0645\u0627 \u0641\u0647\u0631\u0633\u062a\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628\u200c\u0647\u0627\u06cc \u0641\u0644\u0627\u0633\u06a9 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0641\u0631\u0648\u0634 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0647\u200c\u0627\u06cc\u0645.  \u0628\u0627\u0632\u062f\u06cc\u062f \u06a9\u0646\u0646\u062f\u0647 \u0628\u0627\u06cc\u062f \u0628\u062a\u0648\u0627\u0646\u062f \u0628\u0628\u06cc\u0646\u062f \u0631\u0648\u06cc \u0631\u0627 page \u0627\u06cc\u0646 \u0644\u06cc\u0633\u062a \u0627\u0632 \u06a9\u062a\u0627\u0628 \u0647\u0627 \u0647\u0646\u06af\u0627\u0645 \u0628\u0627\u0632\u062f\u06cc\u062f \u0627\u0632 \u062e\u0627\u0646\u0647 page \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0645\u0627<\/p>\n<p>\u062f\u0648\u0628\u0627\u0631\u0647 \u0628\u0647 \u0642\u0633\u0645\u062a head \u0642\u0627\u0644\u0628 HTML \u0646\u06af\u0627\u0647\u06cc \u0628\u06cc\u0646\u062f\u0627\u0632\u06cc\u062f.  \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 \u0627\u06a9\u0646\u0648\u0646 \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u067e\u06cc\u0648\u0646\u062f \u062f\u0627\u062f\u0646 \u0628\u0647 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f\u060c \u0628\u0647 \u0648\u06cc\u0698\u0647 \u06cc\u06a9 \u0634\u06cc\u0648\u0647 \u0646\u0627\u0645\u0647 CSS \u0628\u0647 \u0646\u0627\u0645 \u0647\u0633\u062a\u06cc\u0645 <code>style.css<\/code>.  \u0645\u0633\u06cc\u0631\u060c <code>\/static\/style.css<\/code> \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u062f\u0631 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221; \u0645\u0627 \u0642\u0631\u0627\u0631 \u062f\u0627\u0631\u062f.<\/p>\n<p>\u0628\u0647 \u06cc\u0627\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 Flask \u0628\u0647 \u062c\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0633\u0639\u06cc \u06a9\u0646\u062f \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0645\u0646\u0628\u0639 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u062c\u0631\u0627 \u06a9\u0646\u062f\u060c \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u00ab\/static\u00bb \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06af\u06cc\u0631\u0646\u062f\u060c \u0628\u0647\u200c\u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0628\u0647\u200c\u0639\u0646\u0648\u0627\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>\u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0627\u06a9\u0646\u0648\u0646 \u06cc\u06a9 \u067e\u0648\u0634\u0647 \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u062f\u0631 &#8220;serving_static\/static&#8221; \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u062d\u0627\u0648\u06cc \u062a\u0645\u0627\u0645 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0645\u0627 \u0628\u0627\u0634\u062f.<\/p>\n<p>\u062f\u0631 \u062f\u0627\u062e\u0644 \u0627\u06cc\u0646 \u067e\u0648\u0634\u0647 \u062b\u0627\u0628\u062a\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>style.css<\/code>\u0648 \u0642\u0648\u0627\u0646\u06cc\u0646 CSS \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u06a9\u0645\u06cc \u0633\u0628\u06a9 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0645\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<pre><code class=\"hljs\">\n\n<span class=\"hljs-selector-tag\">h1<\/span> {\n    <span class=\"hljs-attribute\">color<\/span>: navajowhite;\n    <span class=\"hljs-attribute\">font-variant<\/span>-caps: all-small-caps;\n    <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">46px<\/span>;\n}\n\n<span class=\"hljs-selector-tag\">h3<\/span> {\n  <span class=\"hljs-attribute\">color<\/span>: white;\n  <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">36px<\/span>;\n}\n\n<span class=\"hljs-selector-tag\">li<\/span> {\n  <span class=\"hljs-attribute\">color<\/span>: red;\n  <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">50px<\/span>;\n}\n\n<span class=\"hljs-selector-tag\">body<\/span> {\n    <span class=\"hljs-attribute\">background<\/span>: firebrick;\n}\n<\/code><\/pre>\n<p>\u0628\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0627\u06cc\u0646 \u0642\u0648\u0627\u0646\u06cc\u0646 \u0633\u0628\u06a9\u060c \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u067e\u0633\u200c\u0632\u0645\u06cc\u0646\u0647 \u0633\u0641\u06cc\u062f \u0633\u0627\u062f\u0647\u200c\u0627\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0645\u062b\u0627\u0644 \u00abHello, World\u00bb \u062f\u06cc\u062f\u06cc\u0645\u060c \u0628\u0631\u0627\u06cc \u067e\u0633\u200c\u0632\u0645\u06cc\u0646\u0647 \u0642\u0631\u0645\u0632 \u0631\u0646\u06af\u0627\u0631\u0646\u06af\u200c\u062a\u0631 \u00ab\u0622\u062c\u0631 \u0646\u0633\u0648\u0632\u00bb \u0627\u0632 \u0628\u06cc\u0646 \u0645\u06cc\u200c\u0628\u0631\u062f.  \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u062f\u0631 \u062d\u0627\u0644 \u062a\u0639\u0631\u06cc\u0641 \u0627\u0633\u062a\u0627\u06cc\u0644 \u0633\u0641\u06cc\u062f \u0645\u062a\u0645\u0627\u06cc\u0632 \u0628\u0631\u0627\u06cc \u0645\u062a\u0646 \u0647\u0633\u062a\u06cc\u0645 \u0631\u0648\u06cc \u0631\u0627 page.<\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u067e\u06cc\u0627\u0645\u06cc \u0631\u0627 \u06a9\u0647 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u06cc\u0645 \u062f\u0631 \u0648\u0627\u0642\u0639 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0631\u0627 page.  \u0628\u0631\u06af\u0631\u062f \u0628\u0647 \u062f\u0627\u062e\u0644 <code>serving_static\/serve.py<\/code> \u0648 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u062f <code>message<\/code> \u0645\u062a\u063a\u06cc\u0631 \u0646\u0627\u0645 \u0645\u063a\u0627\u0632\u0647 \u0628\u0627\u0634\u062f.  \u067e\u06cc\u062f\u0627 \u06a9\u0646 <code>hello()<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f \u0648 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc <code>message<\/code> \u0645\u062a\u063a\u06cc\u0631 \u0628\u0647 \u0635\u0648\u0631\u062a \u0632\u06cc\u0631<\/p>\n<pre><code class=\"hljs\">\n\n...\n\n\n<span class=\"hljs-meta\">@app.route(<span class=\"hljs-params\"><span class=\"hljs-string\">\"\/\"<\/span><\/span>)<\/span>\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">hello<\/span>():<\/span>\n    message = <span class=\"hljs-string\">\"The Flask Shop\"<\/span>\n    <span class=\"hljs-keyword\">return<\/span> render_template(<span class=\"hljs-string\">'index.html'<\/span>, message=message)\n\n<span class=\"hljs-meta\">... <\/span>   \n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0633\u0631\u0648\u0631 \u062e\u0648\u062f \u0631\u0627 \u0631\u06cc\u0633\u062a\u0627\u0631\u062a \u06a9\u0646\u06cc\u062f \u0648 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f <code>python serve.py<\/code> \u0627\u0632 \u0646\u0648.  \u0633\u067e\u0633 \u0628\u0647 \u0622\u062f\u0631\u0633 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u0622\u062f\u0631\u0633 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f <strong>localhost: 5000<\/strong> \u0648 \u0628\u0627\u06cc\u062f \u0644\u06cc\u0633\u062a \u06a9\u062a\u0627\u0628 \u0647\u0627\u06cc \u0641\u0644\u0627\u0633\u06a9 \u0645\u0627 \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/serving-static-files-flask-2.png\" alt=\"\u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0641\u0644\u0627\u0633\u06a9\" title=\"\"><\/p>\n<p>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0633\u0628\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u06a9\u0646\u0648\u0646 \u0627\u0632 \u0641\u0627\u06cc\u0644 CSS \u0645\u0627 \u06a9\u0647 \u0627\u0632 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc &#8220;\/static&#8221; \u062a\u0648\u0633\u0637 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u0645\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f\u060c \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0627\u06af\u0631 \u062f\u0648\u0628\u0627\u0631\u0647 \u0628\u0647 \u0627\u0644\u06af\u0648\u06cc &#8220;serving_static\/templates\/index.html&#8221; \u0645\u0627 \u0646\u06af\u0627\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0642\u0628\u0644 \u0627\u0632 \u0628\u0633\u062a\u0647 \u0634\u062f\u0646 <code>&lt;\/body&gt;<\/code> \u0628\u0631\u0686\u0633\u0628\u060c \u0645\u0627 \u06cc\u06a9 \u062a\u06af \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0631\u0627 \u062f\u0631\u062c \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0622\u062f\u0631\u0633 \u0627\u06cc\u0646 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0633\u062a <code>\/static\/scripts.js<\/code>.  \u0627\u06cc\u0646 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062b\u0627\u0628\u062a \u062f\u06cc\u06af\u0631 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 Flask \u0627\u0632 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221; \u0645\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0627\u06a9\u0646\u0648\u0646 \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0631\u0627 \u062f\u0631 \u0622\u062f\u0631\u0633 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>serving_static\/static\/scripts.js<\/code>.  \u0645\u062d\u062a\u0648\u06cc\u0627\u062a \u06a9\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0631\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u067e\u0648\u06cc\u0627 \u0631\u0646\u06af \u067e\u0633 \u0632\u0645\u06cc\u0646\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0645\u0627 \u062f\u0631 \u0647\u0631 \u062b\u0627\u0646\u06cc\u0647 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f.  \u0627\u06cc\u0646 \u06cc\u06a9 \u0627\u062b\u0631 \u062f\u0631\u0627\u0645\u0627\u062a\u06cc\u06a9 \u0628\u0631\u0627\u06cc \u062c\u0644\u0628 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0632\u0645\u0627\u0646 \u0645\u062d\u062f\u0648\u062f \u0641\u0631\u0648\u0634 \u062f\u0631 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u062e\u06cc\u0627\u0644\u06cc \u0641\u0644\u0627\u0633\u06a9 \u0645\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<pre><code class=\"hljs\">\n\n\n<span class=\"hljs-keyword\">var<\/span> background1 = <span class=\"hljs-string\">'black'<\/span>;\n<span class=\"hljs-keyword\">var<\/span> background2 = <span class=\"hljs-string\">'firebrick'<\/span>;\n\n\n<span class=\"hljs-keyword\">var<\/span> color = <span class=\"hljs-literal\">true<\/span>;\n\n\n<span class=\"hljs-built_in\">setInterval<\/span>(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> (<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-built_in\">document<\/span>.body.style.backgroundColor = (color ? background1 : background2)\n  color = !color;\n}, <span class=\"hljs-number\">1000<\/span>);\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0633\u0631\u0648\u0631 \u062e\u0648\u062f \u0631\u0627 \u0645\u062a\u0648\u0642\u0641 \u06a9\u0631\u062f\u0647 \u0648 \u062f\u0648\u0628\u0627\u0631\u0647 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f <code>python serve.py<\/code> \u06cc\u06a9 \u0628\u0627\u0631 \u062f\u06cc\u06af\u0631.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0628\u0627\u0632\u062f\u06cc\u062f \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c page \u067e\u0633 \u0632\u0645\u06cc\u0646\u0647 \u0628\u0627\u06cc\u062f \u0686\u0634\u0645\u06a9 \u0628\u0632\u0646\u062f \u0648 \u0647\u0631 1 \u062b\u0627\u0646\u06cc\u0647 \u06cc\u06a9 \u0628\u0627\u0631 \u0627\u0632 \u0633\u0627\u06cc\u0647 \u0642\u0631\u0645\u0632 \u062a\u063a\u06cc\u06cc\u0631 \u06a9\u0646\u062f\u060c \u0627\u06cc\u0646:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/serving-static-files-flask-3.png\" alt=\"\u067e\u0633 \u0632\u0645\u06cc\u0646\u0647 \u0642\u0631\u0645\u0632\" title=\"\"><\/p>\n<p>\u0628\u0647 \u0633\u0627\u06cc\u0647 \u0633\u06cc\u0627\u0647\u060c \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/serving-static-files-flask-4.png\" alt=\"\u067e\u0633 \u0632\u0645\u06cc\u0646\u0647 \u0645\u0634\u06a9\u06cc\" title=\"\"><\/p>\n<p>\u0631\u0627 <code>setInterval<\/code> \u062a\u0627\u0628\u0639 \u062f\u0631 \u06a9\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0627 \u0647\u0631 \u062b\u0627\u0646\u06cc\u0647 \u067e\u0633 \u0632\u0645\u06cc\u0646\u0647 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u062d\u0644\u0642\u0647 \u0632\u0645\u0627\u0646\u06cc \u067e\u06cc\u0648\u0633\u062a\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0645\u0627 \u0627\u06a9\u0646\u0648\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 CSS \u0631\u0627 \u0627\u0632 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221; \u062e\u0648\u062f \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0627\u06cc\u0644 \u0648 \u0628\u0647\u0628\u0648\u062f \u0631\u0641\u062a\u0627\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0645\u0627\u0646 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0627\u06af\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSS \u06cc\u0627 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0636\u0627\u0641\u06cc \u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0647\u0645\u0627\u0646 \u0631\u0648\u0634\u06cc \u06a9\u0647 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f\u06cc\u0645 \u0628\u0647 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221; \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u0648 \u0628\u0647 \u0622\u0646\u0647\u0627 \u0627\u0631\u062c\u0627\u0639 \u062f\u0647\u06cc\u062f.<\/p>\n<h2 id=\"servingjavascriptfiles\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%ac%d8%a7%d9%88%d8%a7_%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa\"><\/span>\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9\u06cc \u062f\u06cc\u06af\u0631 \u0627\u0632 \u0645\u0648\u0627\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0631\u0627\u06cc\u062c \u062f\u0631 \u0645\u0648\u0631\u062f \u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u0648\u0628\u060c \u0627\u0631\u0627\u0626\u0647 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0634\u062e\u0635 \u062b\u0627\u0644\u062b \u0645\u0627\u0646\u0646\u062f Backbone.js\u060c Vue.js\u060c Bootstrap \u06cc\u0627 React \u0627\u0633\u062a.<\/p>\n<p>\u0647\u0631 \u0646\u0648\u0639 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u0627\u0645\u0644 \u0634\u0648\u062f \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062a\u0642\u0631\u06cc\u0628\u0627\u064b \u0628\u0647 \u0647\u0645\u0627\u0646 \u0631\u0648\u0634\u06cc \u06a9\u0647 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0627\u0632 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc &#8220;\/static&#8221; \u0645\u0627 \u062f\u06cc\u062f\u06cc\u0645\u060c \u0627\u0631\u0627\u0626\u0647 \u0634\u0648\u062f.<\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0631\u0648\u0634 \u06af\u0646\u062c\u0627\u0646\u062f\u0646 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a Backbone.js \u0631\u0627 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0628\u0628\u06cc\u0646\u06cc\u0645.<\/p>\n<p>\u06cc\u06a9 \u0627\u06cc\u062f\u0647 \u062e\u0648\u0628 \u0647\u0646\u06af\u0627\u0645 \u062e\u062f\u0645\u062a \u0628\u0647 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627\u06cc \u0634\u062e\u0635 \u062b\u0627\u0644\u062b \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0648\u06cc\u0698\u0647 \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f <strong>lib<\/strong> \u06cc\u0627 <strong>\u0641\u0631\u0648\u0634\u0646\u062f\u0647<\/strong> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u062f\u0627\u062e\u0644 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221;.  \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u06cc\u0646 \u067e\u0648\u0634\u0647 \u0634\u062e\u0635 \u062b\u0627\u0644\u062b \u0631\u0627 \u0647\u0631 \u0686\u0647 \u062f\u0648\u0633\u062a \u062f\u0627\u0631\u06cc\u062f \u0646\u0627\u0645 \u06af\u0630\u0627\u0631\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0646\u06a9\u062a\u0647 \u06a9\u0644\u06cc\u062f\u06cc \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627\u06cc \u062e\u0627\u0631\u062c\u06cc \u0631\u0627 \u062f\u0631 \u067e\u0648\u0634\u0647 \u062e\u0648\u062f \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f\u060c \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0646\u0633\u062e\u0647 \u0647\u0627 \u0631\u0627 \u0627\u0631\u062a\u0642\u0627 \u062f\u0647\u06cc\u062f \u06cc\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u06cc\u06af\u0631\u06cc \u0631\u0627 \u062c\u062f\u0627 \u0627\u0632 \u06a9\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f.<\/p>\n<p>\u0628\u0627 \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0646 \u0627\u06cc\u0646 \u0645\u0648\u0636\u0648\u0639\u060c \u06cc\u06a9 \u067e\u0648\u0634\u0647 \u062c\u062f\u06cc\u062f \u062f\u0631 &#8220;serving_static\/static\/lib&#8221; \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f.  \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0634\u0627\u0645\u0644 \u0645\u06cc \u0634\u0648\u06cc\u0645 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/backbonejs.org\/\">Backbone.js<\/a>\u060c \u062f\u0627\u0646\u0644\u0648\u062f \u0646\u0633\u062e\u0647 \u062a\u06a9 \u0641\u0627\u06cc\u0644\u06cc <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/backbonejs.org\/backbone-min.js\">Backbone.js \u0627\u06cc\u0646\u062c\u0627\u0633\u062a<\/a>\u060c \u0648 \u0633\u067e\u0633 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u062f\u0627\u062e\u0644 \u062c\u062f\u06cc\u062f \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f <code>lib<\/code> \u067e\u0648\u0634\u0647 \u062f\u0627\u062e\u0644 \u067e\u0648\u0634\u0647 &#8220;\/static&#8221; \u0645\u0627.<\/p>\n<p>Backbone.js \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0633\u062e\u062a\u06cc \u062f\u0627\u0631\u062f \u0631\u0648\u06cc <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/underscorejs.org\/\">Underscore.js<\/a>\u060c \u06cc\u06a9\u06cc \u062f\u06cc\u06af\u0631 \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u06a9\u0647 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u0636\u0631\u0648\u0631\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.  \u067e\u0633 \u062f\u0627\u0646\u0644\u0648\u062f \u06a9\u0646\u06cc\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/underscorejs.org\/underscore-min.js\">\u0622\u062e\u0631\u06cc\u0646 \u0646\u0633\u062e\u0647 \u0627\u0632 <code>Underscore.js<\/code> \u0627\u06cc\u0646\u062c\u0627<\/a> \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u06a9\u0646\u0627\u0631 Backbone.js \u062f\u0631 \u067e\u0648\u0634\u0647 &#8220;\/static\/lib&#8221; \u062e\u0648\u062f \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f.<\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 Backbone.js \u0628\u0627 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646 \u062f\u0631 \u0633\u0627\u06cc\u062a \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 page \u0642\u0627\u0644\u0628 \u0648 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u062a\u0648\u0627\u0628\u0639 \u0622\u0646.<\/p>\n<p>\u062f\u0631 \u0642\u0627\u0644\u0628 \u062e\u0648\u062f\u060c \u062f\u0631 \u0641\u0627\u06cc\u0644 &#8220;serving_static\/templates\/index.html&#8221;\u060c \u0622\u0646 \u0631\u0627 \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f <code>&lt;\/ol&gt;<\/code> \u0628\u0631\u0686\u0633\u0628 \u0628\u0633\u062a\u0647 \u0634\u062f\u0646  \u0628\u0639\u062f \u0627\u0632 \u0622\u0646\u060c \u0631\u0648\u06cc \u06cc\u06a9 \u062e\u0637 \u062c\u062f\u06cc\u062f\u060c \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0639\u0646\u0648\u0627\u0646 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0628\u0627 Backbone.js \u062f\u0633\u062a\u06a9\u0627\u0631\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u062a\u06af \u0647\u0627\u06cc \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u062c\u062f\u06cc\u062f \u0631\u0627 \u0642\u0628\u0644 \u0627\u0632 \u0628\u0633\u062a\u0647 \u0634\u062f\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f <code>&lt;\/body&gt;<\/code> \u0628\u0631\u0686\u0633\u0628 \u0632\u062f\u0646  \u062f\u0631 \u0627\u06cc\u0646 \u062a\u06af \u0647\u0627 \u0642\u0631\u0627\u0631 \u0645\u06cc \u062f\u0647\u06cc\u0645 <code>Underscore.js<\/code> \u0648 <code>Backbone.js<\/code>\u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u06a9\u062f\u06cc \u0628\u0631\u0627\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc DOM \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u062f Backbone \u0628\u0646\u0648\u06cc\u0633\u06cc\u062f.<\/p>\n<p>\u0628\u062e\u0634 \u0628\u0647 \u0631\u0648\u0632 \u0634\u062f\u0647 \u0627\u0632 <code>index.html<\/code> \u0642\u0627\u0644\u0628 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0628\u0627\u0634\u062f.<\/p>\n<pre><code class=\"hljs\">\n\n...\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">ol<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span>&gt;<\/span>Flask By Example<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">li<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span>&gt;<\/span>Uncluttered Flask<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">li<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span>&gt;<\/span>Flask From First Principles<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">li<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">ol<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h4<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"version\"<\/span> <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">\"color:white;\"<\/span>&gt;<\/span>Backbone<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h4<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/static\/scripts.js\"<\/span> <span class=\"hljs-attr\">charset<\/span>=<span class=\"hljs-string\">\"utf-8\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/static\/lib\/underscore.js\"<\/span> <span class=\"hljs-attr\">charset<\/span>=<span class=\"hljs-string\">\"utf-8\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/static\/lib\/backbone.js\"<\/span> <span class=\"hljs-attr\">charset<\/span>=<span class=\"hljs-string\">\"utf-8\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\/javascript\"<\/span>&gt;<\/span><span class=\"javascript\">\n      <span class=\"hljs-built_in\">document<\/span>.getElementById(<span class=\"hljs-string\">'version'<\/span>).innerHTML = <span class=\"hljs-string\">\"Proudly built with Backbone.js version \"<\/span> + Backbone.VERSION;\n    <\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">body<\/span>&gt;<\/span>\n  ...\n<\/code><\/pre>\n<p>\u0622\u062e\u0631\u06cc\u0646 \u0645\u0627 <code>&lt;script&gt;<\/code> \u062a\u06af \u0628\u0627\u0644\u0627 \u0627\u0632 Backbone.js \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06af\u0631 \u0627\u06a9\u0646\u0648\u0646 \u0633\u0631\u0648\u0631 \u0631\u0627 \u0645\u062c\u062f\u062f\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0628\u0627\u06cc\u062f \u0645\u062a\u0646 \u0631\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0631\u0627 page \u062f\u0631 \u067e\u0627\u06cc\u06cc\u0646 \u0646\u0633\u062e\u0647 \u0635\u062d\u06cc\u062d Backbone.js \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/serving-static-files-flask-5.png\" alt=\"\u0646\u0633\u062e\u0647 \u0633\u062a\u0648\u0646 \u0641\u0642\u0631\u0627\u062a\" title=\"\"><\/p>\n<p>\u0627\u06af\u0631 \u0627\u0632 Vue.js\u060c React \u06cc\u0627 \u0647\u0631 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062f\u06cc\u06af\u0631\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0631\u062f\u06cc\u0645\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0633\u062a\u06cc\u0645 \u0622\u0646 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 \u0648 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0647\u0645\u0627\u0646 \u0631\u0648\u0634 \u0627\u0631\u0627\u0626\u0647 \u06a9\u0646\u06cc\u0645 \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u0645.<\/p>\n<h2 id=\"servingimagesandotherfiletypes\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d8%aa%d8%b5%d8%a7%d9%88%db%8c%d8%b1_%d9%88_%d8%b3%d8%a7%db%8c%d8%b1_%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d9%81%d8%a7%db%8c%d9%84\"><\/span>\u0627\u0631\u0627\u0626\u0647 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u0633\u0627\u06cc\u0631 \u0627\u0646\u0648\u0627\u0639 \u0641\u0627\u06cc\u0644<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0646\u0648\u0627\u0639 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631\u060c \u0645\u0627\u0646\u0646\u062f \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u062d\u062a\u06cc <strong>txt<\/strong> \u0648 <strong>.pdf<\/strong> \u0641\u0627\u06cc\u0644\u200c\u0647\u0627 \u0631\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646 \u0645\u0634\u0627\u0628\u0647 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc JS \u0648 CSS \u06a9\u0647 \u0642\u0628\u0644\u0627 \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u06cc\u0645 \u0627\u0631\u0627\u0626\u0647 \u06a9\u0631\u062f.  \u0641\u0642\u0637 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 &#8220;\/static&#8221; \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f \u0648 \u0628\u0647 \u0622\u0646\u0647\u0627 \u067e\u06cc\u0648\u0646\u062f \u062f\u0647\u06cc\u062f.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u0645\u0648\u0646\u0647 \u06a9\u062f\u06cc \u0627\u0632 \u0627\u0631\u0627\u0626\u0647 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u0645.  \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u062f\u0648 \u062a\u0635\u0648\u06cc\u0631 \u0627\u0632 \u06a9\u062a\u0627\u0628 \u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637 \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a: <a href=\"https:\/\/s3.amazonaws.com\/stackabuse\/media\/serving-static-files-flask-7.png\" target=\"_blank\" rel=\"noopener\">\u06a9\u062a\u0627\u0628 1<\/a> \u0648 <a href=\"https:\/\/s3.amazonaws.com\/stackabuse\/media\/serving-static-files-flask-8.jpg\" target=\"_blank\" rel=\"noopener\">\u06a9\u062a\u0627\u0628 2<\/a>.  \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0627\u0646\u0644\u0648\u062f \u06a9\u0646\u06cc\u062f \u0648 \u062f\u0631 \u06cc\u06a9 \u067e\u0648\u0634\u0647 \u062c\u062f\u06cc\u062f \u062f\u0631 &#8220;serving_static\/static\/images&#8221; \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f.<\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u062e\u0634 \u00ab\u06a9\u062a\u0627\u0628\u200c\u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637\u00bb \u0631\u0627 \u0628\u0647 \u0642\u0627\u0644\u0628 \u0641\u0647\u0631\u0633\u062a \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645\u060c \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0627\u06cc\u0646 \u06a9\u062a\u0627\u0628\u200c\u0647\u0627 \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc\u200c\u062f\u0647\u06cc\u0645.<\/p>\n<p>\u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u06cc\u062f <code>index.html<\/code> \u0642\u0627\u0644\u0628 \u0628\u0627 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\">\n\n...\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h4<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"version\"<\/span> <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">\"color:white;\"<\/span>&gt;<\/span>Backbone<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h4<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h3<\/span>&gt;<\/span>Related<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h3<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">img<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/static\/images\/book1.png\"<\/span> <span class=\"hljs-attr\">alt<\/span>=<span class=\"hljs-string\">\"Related Book 1\"<\/span> <span class=\"hljs-attr\">width<\/span>=<span class=\"hljs-string\">\"20%\"<\/span> <span class=\"hljs-attr\">height<\/span>=<span class=\"hljs-string\">\"auto\"<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">img<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/static\/images\/book2.jpg\"<\/span> <span class=\"hljs-attr\">alt<\/span>=<span class=\"hljs-string\">\"Related Book 2\"<\/span> <span class=\"hljs-attr\">width<\/span>=<span class=\"hljs-string\">\"20%\"<\/span> <span class=\"hljs-attr\">height<\/span>=<span class=\"hljs-string\">\"auto\"<\/span>&gt;<\/span>\n\n...\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0648\u0642\u062a\u06cc \u0633\u0631\u0648\u0631 \u0631\u0627 \u0631\u06cc\u0633\u062a\u0627\u0631\u062a \u0645\u06cc \u06a9\u0646\u06cc\u062f \u0648 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0628\u0627\u0632\u062f\u06cc\u062f \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u062a\u0635\u0627\u0648\u06cc\u0631\u06cc \u0627\u0632 \u06a9\u062a\u0627\u0628 \u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637 \u0631\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/serving-static-files-flask-6.png\" alt=\"\u06a9\u062a\u0627\u0628 \u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637\" title=\"\"><\/p>\n<h2 id=\"preparingstaticfileswithabuildsystem\"><span class=\"ez-toc-section\" id=\"%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9_%d8%a8%d8%a7_%db%8c%da%a9_%d8%b3%db%8c%d8%b3%d8%aa%d9%85_%d8%b3%d8%a7%d8%ae%d8%aa\"><\/span>\u0622\u0645\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0628\u0627 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0633\u0627\u062e\u062a<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9\u06cc \u0627\u0632 \u0628\u0632\u0631\u06af\u062a\u0631\u06cc\u0646 \u0686\u06cc\u0632\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u062f\u0631 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u0627 \u06af\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u06a9\u0648\u0686\u06a9 \u0633\u0627\u0632\u06cc \u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9\u060c \u0627\u0644\u062d\u0627\u0642 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c CSS \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0647\u06cc\u0646\u0647 \u0633\u0627\u0632\u06cc \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0628\u0631\u0627\u06cc \u0633\u0631\u06cc\u0639\u062a\u0631 \u06a9\u0631\u062f\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0633\u062a.  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u06cc\u0634 \u067e\u0631\u062f\u0627\u0632\u0634\u06af\u0631\u0647\u0627 \u0648 \u06a9\u0627\u0645\u067e\u0627\u06cc\u0644\u0631\u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f Sass\u060c Coffeescript \u0648 Babel \u0628\u0627\u06cc\u062f \u0628\u0647 \u0635\u0648\u0631\u062a \u062f\u0633\u062a\u06cc \u062f\u0631 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0641\u0639\u0644\u06cc \u0645\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0634\u0648\u062f.<\/p>\n<p>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0633\u0627\u062e\u062a \u0645\u0627\u0646\u0646\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/webpack.js.org\/\">\u0628\u0633\u062a\u0647 \u0648\u0628<\/a>\u060c <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/gulpjs.com\/\">\u06af\u0644\u067e<\/a>\u060c <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/brunch.io\/\">\u0635\u0628\u062d\u0627\u0646\u0647<\/a>\u060c \u06cc\u0627 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/browserify.org\/\">\u0645\u0631\u0648\u0631\u06af\u0631<\/a> \u0628\u0647 \u0634\u0645\u0627 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u0627\u06cc\u0646 \u0631\u0627 \u062e\u0648\u062f\u06a9\u0627\u0631 \u06a9\u0646\u06cc\u062f process.<\/p>\n<p>\u0627\u06af\u0631 \u0634\u0645\u0627 \u0639\u0644\u0627\u0642\u0647 \u0645\u0646\u062f \u0628\u0647 \u06a9\u0627\u0648\u0634 \u062f\u0631 \u0627\u06cc\u0646 \u0647\u0633\u062a\u06cc\u062f\u060c \u0627\u06cc\u0646\u062c\u0627\u0633\u062a <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/brunch\/brunch-guide\/blob\/master\/content\/en\/chapter04-starting-from-scratch.md\">\u0631\u0627\u0647\u0646\u0645\u0627\u06cc \u0635\u0628\u062d\u0627\u0646\u0647<\/a> \u0628\u0631\u0627\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 Brunch \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0633\u0627\u062e\u062a \u0628\u0631\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f.<\/p>\n<p>\u06cc\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0645\u0633\u062a\u0646\u062f\u0627\u062a \u0633\u06cc\u0633\u062a\u0645 \u0633\u0627\u062e\u062a \u0645\u0648\u0631\u062f \u0646\u0638\u0631 \u062e\u0648\u062f \u0631\u0627 \u0645\u0631\u0648\u0631 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0628\u0627 \u0631\u0648\u0634 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0648 \u0627\u062f\u063a\u0627\u0645 \u0622\u0646 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u062e\u0648\u062f \u0622\u0634\u0646\u0627 \u0634\u0648\u06cc\u062f.<\/p>\n<h2 id=\"servingstaticfilesinproduction\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b1%d8%a7%d8%a6%d9%87_%d9%81%d8%a7%db%8c%d9%84_%d9%87%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d8%a7%d8%aa%db%8c%da%a9_%d8%af%d8%b1_%d8%aa%d9%88%d9%84%db%8c%d8%af\"><\/span>\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u062f\u0631 \u062a\u0648\u0644\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u062c\u0631\u0627\u06cc \u06a9\u062f \u0634\u0645\u0627 \u062f\u0631 \u062a\u0648\u0644\u06cc\u062f \u06a9\u0645\u06cc \u0628\u0627 \u0645\u062d\u06cc\u0637 \u062a\u0648\u0633\u0639\u0647 \u0645\u062a\u0641\u0627\u0648\u062a \u0627\u0633\u062a.  \u062f\u0631 \u062a\u0648\u0644\u06cc\u062f\u060c \u0628\u0633\u062a\u0647 \u0628\u0647 \u0631\u0648\u06cc \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0627 \u062d\u062c\u0645 \u0628\u0633\u06cc\u0627\u0631 \u0628\u0627\u0644\u0627\u062a\u0631\u06cc \u0627\u0632 \u062a\u0631\u0627\u0641\u06cc\u06a9 \u0645\u0648\u0627\u062c\u0647 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0639\u0648\u0627\u0631\u0636 \u0632\u06cc\u0627\u062f\u06cc \u0631\u0627 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f \u0631\u0648\u06cc \u0633\u0631\u0648\u0631 \u0634\u0645\u0627<\/p>\n<p>\u062f\u0631 \u062a\u0648\u0644\u06cc\u062f \u067e\u06cc\u0634\u0646\u0647\u0627\u062f \u0645\u06cc \u0634\u0648\u062f \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0628\u0627 \u0633\u0631\u0648\u0631\u06cc \u0645\u0627\u0646\u0646\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.nginx.com\/\">nginx<\/a> \u0628\u0631\u0627\u06cc \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 \u0628\u0627\u0631 \u0631\u0648\u06cc \u0633\u0631\u0648\u0631 \u0648\u0628 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0634\u0645\u0627 \u062a\u0627 \u062d\u062f \u0627\u0645\u06a9\u0627\u0646 \u0633\u0628\u06a9 \u0627\u0633\u062a.  \u0627\u06af\u0631 \u062a\u0639\u062f\u0627\u062f \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u062f\u0647\u06cc\u062f\u060c \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0633\u0631\u0639\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0627\u0641\u0632\u0627\u06cc\u0634 \u0645\u06cc\u200c\u062f\u0647\u062f.<\/p>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0647 \u062c\u0627\u06cc \u0633\u0631\u0648\u0631 \u062f\u0627\u062e\u0644\u06cc Flask \u0627\u0632 \u06cc\u06a9 \u0648\u0628 \u0633\u0631\u0648\u0631 \u067e\u0627\u06cc\u062a\u0648\u0646 \u062f\u0631\u062c\u0647 \u062a\u0648\u0644\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.  \u0628\u0631\u062e\u06cc \u0627\u0632 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u062e\u0648\u0628 \u0647\u0633\u062a\u0646\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/gunicorn.org\/\">\u06af\u0648\u0646\u06cc\u06a9\u0648\u0631\u0646<\/a>\u060c <a rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/www.gevent.org\/\">\u06af\u0626\u0648\u0646\u062a<\/a> \u0648 \u0622\u067e\u0627\u0686\u06cc \u0628\u0627 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/modwsgi.readthedocs.io\/en\/develop\/\">mod_wsgi<\/a>.<\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u062f\u06cc\u062f\u06cc\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Flask \u0628\u0647 \u0622\u0633\u0627\u0646\u06cc \u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u06cc\u062f.  \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c CSS\u060c \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0633\u0627\u06cc\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062b\u0627\u0628\u062a \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u06cc\u062f.  \u0627\u06cc\u0646 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0647 \u0631\u0648\u0634 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f\u060c \u0633\u0627\u062f\u0647 \u062a\u0631\u06cc\u0646 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc &#8220;\/static&#8221; \u0627\u0633\u062a \u06a9\u0647 Flask \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627 \u0628\u0647 \u0645\u0634\u062a\u0631\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<\/div>\n<p><script>\n                        !function(f,b,e,v,n,t,s)\n                        {if(f.fbq)return;n=f.fbq=function(){n.callMethod?\n                        n.callMethod.apply(n,arguments):n.queue.push(arguments)};\n                        if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0';\n                        n.queue=();t=b.createElement(e);t.async=!0;\n                        t.src=v;s=b.getElementsByTagName(e)(0);\n                        s.parentNode.insertBefore(t,s)}(window, document,'script',\n                        'https:\/\/connect.facebook.net\/en_US\/fbevents.js');\n                        fbq('init', '525232124909042');\n                        fbq('track', 'PageView');\n                    <\/script>    (\u0628\u0631\u0686\u0633\u0628\u200c\u0647\u0627 \u0628\u0647 \u062a\u0631\u062c\u0645\u0647)# python<br \/>\n<br \/><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-29 22:44:16<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;16690&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u0627\u0631\u0627\u0626\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0628\u0627 \u0641\u0644\u0627\u0633\u06a9&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 8<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0641\u0644\u0627\u0633\u06a9 \u0641\u0644\u0627\u0633\u06a9 \u06cc\u06a9 \u0627\u0646\u062a\u062e\u0627\u0628 \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0628\u0647 \u0631\u0648\u0634 \u0645\u0627\u0698\u0648\u0644\u0627\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a. \u0628\u0631 \u062e\u0644\u0627\u0641 \u062c\u0646\u06af\u0648 \u0648 \u0622\u0646\u0627\u0644\u0648\u06af \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0645\u0627\u0646\u0646\u062f Ruby \u0631\u0648\u06cc Rails, Flask \u06cc\u06a9 \u0645\u06cc\u06a9\u0631\u0648 \u0641\u0631\u06cc\u0645\u0648\u0631\u06a9 \u0627\u0633\u062a. \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0641\u0642\u0637 \u0634\u0627\u0645\u0644 \u0645\u0648\u0627\u0631\u062f\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u0627\u0635\u0644\u06cc \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a\u060c \u0648 \u0628\u062e\u0634 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1743,620],"tags":[],"class_list":["post-16690","post","type-post","status-publish","format-standard","hentry","category-python","category-programming"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16690","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=16690"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16690\/revisions"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=16690"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=16690"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=16690"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}