{"id":17424,"date":"2024-05-22T23:16:22","date_gmt":"2024-05-22T19:46:22","guid":{"rendered":"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/"},"modified":"2024-05-22T23:16:22","modified_gmt":"2024-05-22T19:46:22","slug":"%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/","title":{"rendered":"\u0686\u06af\u0648\u0646\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648 \u062e\u0648\u062f \u0631\u0627 \u0627\u06cc\u0645\u0646 \u06a9\u0646\u06cc\u0645 \u2013 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0648 \u0646\u0645\u0648\u0646\u0647 \u06a9\u062f"},"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\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2_%d9%87%d9%88%db%8c%d8%aa_%d9%88_%d9%85%d8%ac%d9%88%d8%b2\" >\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0648 \u0645\u062c\u0648\u0632<\/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\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%af%d8%b1_%d8%a8%d8%b1%d8%a7%d8%a8%d8%b1_%d8%ad%d9%85%d9%84%d8%a7%d8%aa_%d8%aa%d8%b2%d8%b1%db%8c%d9%82_sql\" >\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062d\u0645\u0644\u0627\u062a \u062a\u0632\u0631\u06cc\u0642 SQL<\/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\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%af%d8%b1_%d8%a8%d8%b1%d8%a7%d8%a8%d8%b1_%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa_%d8%a8%db%8c%d9%86_%d8%b3%d8%a7%db%8c%d8%aa%db%8c_xss\" >\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u06cc\u0646 \u0633\u0627\u06cc\u062a\u06cc (XSS)<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7%db%8c_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1\" >\u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d9%87%d9%86%da%af%d8%a7%d9%85_%d9%86%d9%85%d8%a7%db%8c%d8%b4_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7%db%8c_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%d8%8c_%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a2%d9%86_%d9%87%d8%a7_%d8%b1%d8%a7_%d8%b1%d9%85%d8%b2%da%af%d8%b0%d8%a7%d8%b1%db%8c_%da%a9%d9%86%db%8c%d8%af\" >\u0647\u0646\u06af\u0627\u0645 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u060c \u0647\u0645\u06cc\u0634\u0647 \u0622\u0646 \u0647\u0627 \u0631\u0627 \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%a7%d8%b2_%d9%87%d8%af%d8%b1%d9%87%d8%a7%db%8c_http_%d8%b5%d8%ad%db%8c%d8%ad_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\" >\u0627\u0632 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u0635\u062d\u06cc\u062d \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a7%d8%b2_%d8%b3%db%8c%d8%a7%d8%b3%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d9%85%d8%ad%d8%aa%d9%88%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\" >\u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 \u0633\u06cc\u0627\u0633\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0645\u062d\u062a\u0648\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%af%d8%b1_%d8%a8%d8%b1%d8%a7%d8%a8%d8%b1_%d8%ac%d8%b9%d9%84_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_%d8%a8%db%8c%d9%86_%d8%b3%d8%a7%db%8c%d8%aa%db%8c_csrf\" >\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062c\u0639\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u06cc\u0646 \u0633\u0627\u06cc\u062a\u06cc (CSRF)<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%a7%d8%b2_%d9%85%d8%ad%d8%af%d9%88%d8%af%db%8c%d8%aa_%d9%86%d8%b1%d8%ae_%d9%85%d8%a8%d8%aa%d9%86%db%8c_%d8%a8%d8%b1_middleware_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\" >\u0627\u0632 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u0646\u0631\u062e \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 Middleware \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#csrf_middleware_%d8%b1%d8%a7_%d9%81%d8%b9%d8%a7%d9%84_%da%a9%d9%86%db%8c%d8%af\" >CSRF Middleware \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a7%d8%b2_%d8%aa%d9%88%da%a9%d9%86_%d9%87%d8%a7%db%8c_crsf_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\" >\u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc CRSF \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-12\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%da%86%da%a9_%d9%84%db%8c%d8%b3%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%ac%d9%86%da%af%d9%88_%d8%af%d8%a7%d8%ae%d9%84%db%8c\" >\u0686\u06a9 \u0644\u06cc\u0633\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062c\u0646\u06af\u0648 \u062f\u0627\u062e\u0644\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%d8%b3%d8%a7%db%8c%d8%b1_%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c\" >\u0633\u0627\u06cc\u0631 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-14\" href=\"https:\/\/rasanegaar.com\/blog\/%da%86%da%af%d9%88%d9%86%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d8%ac%d9%86%da%af%d9%88-%d8%ae%d9%88%d8%af-%d8%b1%d8%a7-%d8%a7%db%8c%d9%85%d9%86-%da%a9%d9%86%db%8c%d9%85-%d8%a8%d9%87\/#%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\"> 7<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<section class=\"post-content \" data-test-label=\"post-content\">\n<p>\u0628\u0647\u200c\u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647 \u06cc\u0627 \u0645\u0647\u0646\u062f\u0633 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u060c \u062f\u0627\u0646\u0633\u062a\u0646 \u0631\u0648\u0634 \u0633\u0627\u062e\u062a \u0631\u0627\u0647\u200c\u062d\u0644\u200c\u0647\u0627\u06cc \u0645\u0641\u06cc\u062f \u06a9\u0627\u0641\u06cc \u0646\u06cc\u0633\u062a \u2013 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0627\u06cc\u062f \u0627\u0632 \u0627\u06cc\u0645\u0646 \u0628\u0648\u062f\u0646 \u0622\u0646\u0647\u0627 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f.  \u0627\u0648\u0644\u0648\u06cc\u062a \u0628\u0646\u062f\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0647\u0646\u06af\u0627\u0645 \u062a\u0648\u0633\u0639\u0647 \u0648 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0634\u0645\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0647\u0645 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0627\u06af\u0631 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0646\u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f\u060c \u0628\u06cc \u0641\u0627\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0645\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc\u0645\u0646 \u062c\u0646\u06af\u0648 \u0642\u0628\u0644 \u0627\u0632 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0628\u0639\u062f\u06cc \u0634\u0645\u0627 \u0645\u0648\u0631\u062f \u0628\u062d\u062b \u0642\u0631\u0627\u0631 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f. <\/p>\n<p>\u0628\u06cc\u0627 \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u06cc\u0645! <\/p>\n<h2 id=\"security-measures-for-authentication-and-authorization\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2_%d9%87%d9%88%db%8c%d8%aa_%d9%88_%d9%85%d8%ac%d9%88%d8%b2\"><\/span>\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0648 \u0645\u062c\u0648\u0632 <span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0647\u0646\u06af\u0627\u0645 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0627\u0631\u0628\u0631 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u0648\u0644\u0648\u06cc\u062a \u0628\u0646\u062f\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0648 \u0645\u062c\u0648\u0632 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0644\u06cc\u062f\u06cc \u062f\u0627\u0631\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0647\u0646\u06af\u0627\u0645 \u06a9\u0627\u0631 \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0648\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0648 \u0645\u062c\u0648\u0632:<\/p>\n<ol>\n<li>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0627 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0633\u0631 \u0648 \u06a9\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f\u060c \u0628\u0647\u062a\u0631 \u0627\u0633\u062a \u06cc\u06a9 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u06a9\u0627\u0631\u0628\u0631 \u0627\u06cc\u0645\u0646 \u0645\u0627\u0646\u0646\u062f \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631\u060c \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0648\u06a9\u0646 \u06cc\u0627 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0686\u0646\u062f \u0639\u0627\u0645\u0644\u06cc \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0634\u0648\u062f.  \u0627\u06cc\u0646 \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u062e\u0648\u062f \u0631\u0627 \u0628\u06cc\u0634 \u0627\u0632 \u06cc\u06a9 \u0628\u0627\u0631 \u0648 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u0646\u062f \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f \u062a\u0623\u06cc\u06cc\u062f \u0645\u06cc \u06a9\u0646\u06cc\u062f. <\/li>\n<li>\u0627\u06af\u0631 \u0627\u0632 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0627\u0632 \u06cc\u06a9 \u0627\u0644\u06af\u0648\u0631\u06cc\u062a\u0645 \u0647\u0634 \u0642\u0648\u06cc \u0645\u0627\u0646\u0646\u062f \u062c\u0646\u06af\u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f. <code>make_password<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f\u06cc \u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u0630\u062e\u06cc\u0631\u0647 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062a\u0646 \u0633\u0627\u062f\u0647. <\/li>\n<li>\u0647\u0646\u06af\u0627\u0645 \u0647\u0634 \u06a9\u0631\u062f\u0646 \u0631\u0645\u0632\u0647\u0627\u06cc \u0639\u0628\u0648\u0631 \u06a9\u0627\u0631\u0628\u0631\u060c \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062a\u0648\u0644\u06cc\u062f \u0646\u0645\u06a9 \u0631\u0627 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u062f.  \u06cc\u06a9 \u062f\u0627\u062f\u0647 \u062a\u0635\u0627\u062f\u0641\u06cc \u0645\u0646\u062d\u0635\u0631 \u0628\u0647 \u0641\u0631\u062f (\u0646\u0645\u06a9) \u0628\u0631\u0627\u06cc \u062a\u0642\u0648\u06cc\u062a \u0647\u0634 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f process \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0648 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062d\u0645\u0644\u0627\u062a \u0627\u0632 \u067e\u06cc\u0634 \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 <\/li>\n<li>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0648\u06a9\u0646 \u0631\u0627 \u062f\u0631 \u0646\u0638\u0631 \u0628\u06af\u06cc\u0631\u06cc\u062f \u0648 \u06cc\u06a9 \u062a\u0627\u06cc\u0645\u0631 \u0627\u0646\u0642\u0636\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u06cc\u06a9 \u0644\u0627\u06cc\u0647 \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u06cc\u06af\u0631 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.  \u0627\u06cc\u0646 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0631\u0645\u0632 \u062f\u0633\u062a\u0631\u0633\u06cc \u06a9\u0627\u0631\u0628\u0631 \u067e\u0633 \u0627\u0632 \u0645\u062f\u062a\u06cc \u0645\u0634\u062e\u0635 \u0645\u0646\u0642\u0636\u06cc \u0634\u0648\u062f \u0648 \u0622\u0646\u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u062f\u0627\u0645\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0628\u0627\u06cc\u062f \u0647\u0648\u06cc\u062a \u062e\u0648\u062f \u0631\u0627 \u062f\u0648\u0628\u0627\u0631\u0647 \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0646\u0646\u062f.  \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0647\u0646\u06af\u0627\u0645 \u0627\u062c\u0631\u0627\u06cc \u0627\u06cc\u0646\u060c \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062a\u0627\u06cc\u0645\u0631 \u0631\u0627 \u0647\u0631 5 \u062f\u0642\u06cc\u0642\u0647\u060c 30 \u062f\u0642\u06cc\u0642\u0647 \u06cc\u0627 \u06cc\u06a9 \u0633\u0627\u0639\u062a \u0645\u0646\u0642\u0636\u06cc \u0646\u06a9\u0646\u06cc\u062f \u062a\u0627 \u062a\u0623\u062b\u06cc\u0631 \u0645\u0646\u0641\u06cc \u0628\u0631 \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.  <\/li>\n<li>\u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0628\u0627 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0633\u0631\u0648\u06a9\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f\u060c \u0647\u0645\u06cc\u0634\u0647 \u06cc\u06a9 \u06a9\u0646\u062a\u0631\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0646\u0642\u0634 (RBAC) \u0628\u0631\u0627\u06cc \u0627\u062e\u062a\u0635\u0627\u0635 \u0646\u0642\u0634 \u0628\u0647 \u0647\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f.  \u06cc\u0639\u0646\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0641\u0642\u0637 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f \u0648 \u0627\u062f\u0645\u06cc\u0646 \u0647\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0648 \u0633\u0627\u06cc\u0631 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u06cc\u0627\u0641\u062a\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f. <\/li>\n<li>\u067e\u0633 \u0627\u0632 \u0647\u0634 \u06a9\u0631\u062f\u0646 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0648 \u062f\u0627\u0634\u062a\u0646 \u06a9\u0646\u062a\u0631\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc\u060c \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u06a9\u0646\u062a\u0631\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0648 \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u0645\u0646\u0627\u0633\u0628 \u0631\u0627 \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0641\u0642\u0637 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u062c\u0627\u0632 \u0628\u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u062e\u0648\u062f \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f. <\/li>\n<\/ol>\n<h2 id=\"security-measures-against-sql-injection-attacks\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%af%d8%b1_%d8%a8%d8%b1%d8%a7%d8%a8%d8%b1_%d8%ad%d9%85%d9%84%d8%a7%d8%aa_%d8%aa%d8%b2%d8%b1%db%8c%d9%82_sql\"><\/span>\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062d\u0645\u0644\u0627\u062a \u062a\u0632\u0631\u06cc\u0642 SQL<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062d\u0645\u0644\u0627\u062a \u062a\u0632\u0631\u06cc\u0642 SQL \u06cc\u06a9\u06cc \u0627\u0632 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u062a\u0631\u06cc\u0646 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0647\u0627\u06cc \u0648\u0628 \u0647\u0633\u062a\u0646\u062f \u0648 \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc \u062c\u0646\u06af\u0648 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0686\u0646\u06cc\u0646 \u062d\u0645\u0644\u0627\u062a\u06cc \u0645\u0648\u0631\u062f \u0633\u0648\u0621 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u060c \u0628\u0647 \u062e\u0635\u0648\u0635 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062f\u0631 \u062d\u0627\u0644 \u062d\u0631\u06a9\u062a \u0627\u0632 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0647 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631 \u0628\u0627\u0634\u0646\u062f. <\/p>\n<p>\u06cc\u06a9 \u0631\u0627\u0647 \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u062e\u0646\u062b\u06cc \u06a9\u0631\u062f\u0646 \u0627\u06cc\u0646 \u062d\u0645\u0644\u0627\u062a \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc \u062c\u0646\u06af\u0648\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.  \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u06cc \u06cc\u06a9 \u0631\u0627\u0647 \u0622\u0633\u0627\u0646 \u0628\u0631\u0627\u06cc \u062c\u062f\u0627 \u06a9\u0631\u062f\u0646 \u06a9\u062f SQL \u0627\u0632 \u0648\u0631\u0648\u062f\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a \u0648 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0628\u062e\u0634\u06cc \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 SQL \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 ORM \u0647\u0627\u06cc \u062c\u0646\u06af\u0648 \u0646\u06cc\u0633\u062a.<\/p>\n<p>\u0647\u0645 \u0627\u06a9\u0646\u0648\u0646 \u0628\u0647 \u0686\u06af\u0648\u0646\u06af\u06cc \u06a9\u0627\u0631\u06a9\u0631\u062f \u0622\u0646 \u0645\u06cc \u067e\u0631\u062f\u0627\u0632\u06cc\u0645.  \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u064b \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u0648\u062c\u0648\u062f \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u062c\u0633\u062a\u062c\u0648 \u06a9\u0646\u06cc\u062f:<\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code>from .models import User  \n\ndef user_search(request):\n    username = request.GET.get('username')\n    \n    # Vulnerable query construction\n    query = \"SELECT * FROM users WHERE username=\"\" + username + \"\"\"\n\n    # Return a response\n    return HttpResponse(\"User search query: \" + query)<\/code><\/pre><figcaption>\u0631\u0648\u0634 \u0627\u0634\u062a\u0628\u0627\u0647 \u0628\u0631\u0627\u06cc \u062c\u0645\u0639 \u0622\u0648\u0631\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631<\/figcaption><\/figure>\n<p>\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 Django QuerySet \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>filter()<\/code> \u0631\u0648\u0634 \u0641\u06cc\u0644\u062a\u0631 \u06a9\u0631\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0648 \u0636\u062f\u0639\u0641\u0648\u0646\u06cc \u06a9\u0631\u062f\u0646 \u0622\u0646\u0647\u0627\u060c \u0645\u0627\u0646\u0646\u062f \u0632\u06cc\u0631:<\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code class=\"language-python\">from .models import User\n\ndef user_search(request):\n    username = request.GET.get('username')\n    \n    # Safe query using parameterized query\n    users = User.objects.filter(username=username)\n    \n    # Return a response\n    return HttpResponse(\"User search executed securely.\")<\/code><\/pre><figcaption>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u06cc \u0634\u062f\u0647 \u062f\u0631 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631<\/figcaption><\/figure>\n<h2 id=\"security-measures-against-cross-site-scripting-xss-\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%af%d8%b1_%d8%a8%d8%b1%d8%a7%d8%a8%d8%b1_%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa_%d8%a8%db%8c%d9%86_%d8%b3%d8%a7%db%8c%d8%aa%db%8c_xss\"><\/span>\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u06cc\u0646 \u0633\u0627\u06cc\u062a\u06cc (XSS)<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u06cc\u0646 \u0633\u0627\u06cc\u062a\u06cc \u06cc\u0627 \u062d\u0645\u0644\u0647 XSS \u0628\u0627 \u062a\u0632\u0631\u06cc\u0642 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0647\u0627\u06cc \u0645\u062e\u0631\u0628 \u062f\u0631 \u06cc\u06a9 \u0648\u0628 \u0627\u062a\u0641\u0627\u0642 \u0645\u06cc \u0627\u0641\u062a\u062f page \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u06cc \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0633\u0627\u06cc\u0631 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0627\u0633\u062a.  \u0627\u06af\u0631 \u0641\u0631\u0627\u0645\u0648\u0634 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0646\u06cc\u062f\u060c \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u0631\u0627 \u0627\u0632 \u062a\u0641\u0633\u06cc\u0631 \u0645\u062d\u062a\u0648\u0627\u06cc \u0648\u0628 \u062e\u0648\u062f \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f \u06cc\u0627 \u062e\u0637\u200c\u0645\u0634\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0645\u062d\u062a\u0648\u0627 \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u06cc\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u062f\u0631 \u067e\u0631\u0648\u0698\u0647\u200c\u0647\u0627\u06cc \u062c\u0646\u06af\u0648 \u0634\u0645\u0627 \u0645\u0648\u0631\u062f \u0633\u0648\u0621 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0642\u0631\u0627\u0631 \u06af\u06cc\u0631\u0646\u062f. <\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0647\u0646\u06af\u0627\u0645 \u0627\u062c\u062a\u0646\u0627\u0628 \u0627\u0632 \u062d\u0645\u0644\u0627\u062a XSS \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<h3 id=\"validate-user-data\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7%db%8c_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1\"><\/span>\u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631 \u0633\u0631\u0648\u06a9\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f\u060c \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0647\u0645\u06cc\u0634\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u0645\u06cc \u06a9\u0646\u06cc\u062f.  \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u062f\u0627\u062e\u0644\u06cc \u0645\u0627\u0646\u0646\u062f <code>django.core.validators<\/code> \u062a\u0627\u0628\u0639. <\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0646\u0645\u0648\u0646\u0647 \u0627\u06cc \u0627\u0632 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u06cc\u06a9 \u0622\u062f\u0631\u0633 \u0627\u06cc\u0645\u06cc\u0644 \u062f\u0631\u06cc\u0627\u0641\u062a \u0634\u062f\u0647 \u0627\u0632 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code class=\"language-python\">from django.core.validators import validate_email\n\nemail = request.GET.get('email')\n\nif not validate_email(email):\n    raise ValueError(\"Invalid email address.\")<\/code><\/pre><figcaption>\u062a\u0627\u06cc\u06cc\u062f \u0627\u06cc\u0645\u06cc\u0644 \u06a9\u0627\u0631\u0628\u0631<\/figcaption><\/figure>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u062b\u0627\u0644 \u062f\u06cc\u06af\u0631\u06cc \u0627\u0632 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc URL \u062f\u0631\u06cc\u0627\u0641\u062a \u0634\u062f\u0647 \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631 \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code class=\"language-python\">from django.core.validators import URLValidator\nfrom django.core.exceptions import ValidationError\n\ndef validate_url(url):\n    validator = URLValidator()\n    try:\n        validator(url)\n    except ValidationError as e:\n        return e.message\n    return None\n<\/code><\/pre><figcaption>\u062f\u0631 \u062d\u0627\u0644 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc URL \u062f\u0631\u06cc\u0627\u0641\u062a \u0634\u062f\u0647 \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631<\/figcaption><\/figure>\n<h3 id=\"always-encode-user-data-when-displaying-it\"><span class=\"ez-toc-section\" id=\"%d9%87%d9%86%da%af%d8%a7%d9%85_%d9%86%d9%85%d8%a7%db%8c%d8%b4_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7%db%8c_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%d8%8c_%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a2%d9%86_%d9%87%d8%a7_%d8%b1%d8%a7_%d8%b1%d9%85%d8%b2%da%af%d8%b0%d8%a7%d8%b1%db%8c_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0647\u0646\u06af\u0627\u0645 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u060c \u0647\u0645\u06cc\u0634\u0647 \u0622\u0646 \u0647\u0627 \u0631\u0627 \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06af\u0631 \u067e\u0631\u0648\u0698\u0647 \u0634\u0645\u0627 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f \u0648 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc\u200c\u062f\u0647\u062f\u060c \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0644\u06af\u0648\u06cc \u0641\u0631\u0627\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u062c\u0646\u06af\u0648 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u062f. <code>{% autoescape %}<\/code>.  \u0631\u0627 <code>autoescape<\/code> \u0627\u0632 \u062a\u06af \u0628\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0622\u06cc\u0627 <code>autoescape<\/code> \u0627\u0633\u062a \u0631\u0648\u06cc \u06cc\u0627 \u062e\u0627\u0645\u0648\u0634  \u0627\u06af\u0631 \u0647\u0633\u062a \u0631\u0648\u06cc\u060c \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u06a9\u062f HTML \u0645\u0648\u062c\u0648\u062f \u062f\u0631 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0634\u0645\u0627 \u0641\u0631\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644:<\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code class=\"language-python\">{% autoescape \u0631\u0648\u06cc %}\n    {{ user_input }}\n{% endautoescape %}<\/code><\/pre><figcaption>\u067e\u06cc\u0686 \u0631\u0648\u06cc \u0641\u0631\u0627\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0631\u0648\u06cc \u06a9\u062f HTML<\/figcaption><\/figure>\n<h3 id=\"use-the-correct-http-headers\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b2_%d9%87%d8%af%d8%b1%d9%87%d8%a7%db%8c_http_%d8%b5%d8%ad%db%8c%d8%ad_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0627\u0632 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u0635\u062d\u06cc\u062d \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648\u060c \u0647\u0645\u06cc\u0634\u0647 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u0645\u0646\u0627\u0633\u0628 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0627\u0632 \u062a\u0641\u0633\u06cc\u0631 \u0645\u062d\u062a\u0648\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0647\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc\u06cc \u062a\u0648\u0633\u0637 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0634\u0648\u062f.  \u0627\u06cc\u0646 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u062c\u0632\u0626\u06cc \u0628\u0627\u0634\u062f\u060c \u0627\u0645\u0627 \u0627\u0632 \u062d\u062f\u0633 \u0632\u062f\u0646 \u0646\u0648\u0639 \u067e\u0627\u0633\u062e \u0634\u0645\u0627 \u062a\u0648\u0633\u0637 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0645\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u062f\u0648 \u0647\u062f\u0631 HTTP \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<ol>\n<li><code>X-Content-Type-Options<\/code>: \u0627\u06cc\u0646 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u0646\u0648\u0639 \u067e\u0627\u0633\u062e \u0631\u0627 \u0646\u0645\u06cc\u200c\u0628\u06cc\u0646\u0646\u062f \u06cc\u0627 \u062d\u062f\u0633 \u0646\u0645\u06cc\u200c\u0632\u0646\u0646\u062f \u06a9\u0647 \u067e\u0633\u0648\u0646\u062f\u0647\u0627\u06cc \u0627\u06cc\u0645\u06cc\u0644 \u0686\u0646\u062f \u0645\u0646\u0638\u0648\u0631\u0647 \u0627\u06cc\u0646\u062a\u0631\u0646\u062a\u06cc (MIME) \u0628\u0627\u0634\u062f.  MIME \u0628\u0631\u0627\u06cc \u062a\u0639\u06cc\u06cc\u0646 \u0641\u0631\u0645\u062a \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u0627\u06cc\u0646\u062a\u0631\u0646\u062a\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. <\/li>\n<li><code>Content-Type: text\/html: charset=UTF-8<\/code>: \u0627\u06cc\u0646 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627\u06cc \u0648\u0628 \u0634\u0645\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 HTML \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u06a9\u062f\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u062f. <\/li>\n<\/ol>\n<p>\u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062d\u0645\u0644\u0627\u062a XSS \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u06cc\u0646 \u0647\u062f\u0631\u0647\u0627 \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0642\u0627\u0644\u0628 \u062e\u0648\u062f \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f. <\/p>\n<h3 id=\"always-use-content-security-policy\"><span class=\"ez-toc-section\" id=\"%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a7%d8%b2_%d8%b3%db%8c%d8%a7%d8%b3%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d9%85%d8%ad%d8%aa%d9%88%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 \u0633\u06cc\u0627\u0633\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0645\u062d\u062a\u0648\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0633\u06cc\u0627\u0633\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0645\u062d\u062a\u0648\u0627 (CSP) \u06cc\u06a9 \u0627\u0642\u062f\u0627\u0645 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627\u06cc \u0648\u0628 \u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062d\u0645\u0644\u0627\u062a \u0645\u062e\u0631\u0628\u060c \u062d\u0645\u0644\u0627\u062a XSS \u0648 \u062a\u0632\u0631\u06cc\u0642 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0627\u06cc\u0646 \u062e\u0637 \u0645\u0634\u06cc \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0648\u0628 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u0645\u0646\u0627\u0628\u0639 \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f\u06cc \u0645\u0627\u0646\u0646\u062f \u062a\u0635\u0627\u0648\u06cc\u0631\u060c \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0647\u0627\u060c \u0633\u0628\u06a9 \u0647\u0627\u06cc CSS \u0648 \u063a\u06cc\u0631\u0647 \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u0646\u062f. \u0631\u0648\u06cc\u060c \u0631\u0648\u06cc \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc \u0622\u0646\u0647\u0627 <\/p>\n<p>\u0633\u06cc\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0645\u062d\u062a\u0648\u0627 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u06cc\u0627 \u0645\u062a\u0627 \u062a\u06af\u200c\u0647\u0627\u06cc HTML \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u062a\u0627 \u0627\u0645\u0646\u06cc\u062a \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u0634\u0645\u0627 \u0631\u0627 \u0627\u0641\u0632\u0627\u06cc\u0634 \u062f\u0647\u0646\u062f. <\/p>\n<p>\u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u062e\u0648\u062f \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f CSP \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code class=\"language-python\">from django.http import HttpResponse\n\nresponse = HttpResponse(\"Your content here\")\nresponse['Content-Security-Policy'] = \"default-src 'self'; script-src 'self' https:\/\/trusted-cdn.com;\"\n<\/code><\/pre><figcaption>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc CSP \u062f\u0631 \u062c\u0646\u06af\u0648<\/figcaption><\/figure>\n<h2 id=\"security-measures-against-cross-site-request-forgery-csrf-\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%af%d8%b1_%d8%a8%d8%b1%d8%a7%d8%a8%d8%b1_%d8%ac%d8%b9%d9%84_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_%d8%a8%db%8c%d9%86_%d8%b3%d8%a7%db%8c%d8%aa%db%8c_csrf\"><\/span>\u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062c\u0639\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u06cc\u0646 \u0633\u0627\u06cc\u062a\u06cc (CSRF)<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062c\u0639\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0628\u06cc\u0646 \u0633\u0627\u06cc\u062a\u06cc (CSRF) \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u0641\u0631\u06cc\u0628 \u062f\u0627\u062f\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u0647 \u0627\u0646\u062c\u0627\u0645 \u0627\u0642\u062f\u0627\u0645\u0627\u062a\u06cc \u0628\u0631 \u062e\u0644\u0627\u0641 \u062f\u0627\u0646\u0634 \u06cc\u0627 \u0631\u0636\u0627\u06cc\u062a \u0622\u0646\u0647\u0627 \u062d\u0645\u0644\u0647 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u062d\u0645\u0644\u0627\u062a \u0627\u0632 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0641\u0631\u06cc\u0628 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u067e\u06cc\u0648\u0646\u062f \u06cc\u0627 \u0641\u0631\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f \u0631\u0648\u06cc \u06cc\u06a9 \u0648\u0628\u200c\u0633\u0627\u06cc\u062a \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062a\u0641\u0627\u0648\u062a \u0648 \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u0632 \u062c\u0644\u0633\u0647 \u062a\u0623\u06cc\u06cc\u062f \u0634\u062f\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0645\u06cc\u200c\u0622\u06cc\u062f\u060c \u0622\u0646 \u0631\u0627 \u0648\u0627\u0631\u062f \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u0645\u0647\u0627\u062c\u0645 \u0628\u0647 \u0627\u0646\u062c\u0627\u0645 \u062f\u0633\u062a\u06a9\u0627\u0631\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u06cc\u0627 \u0627\u0646\u062c\u0627\u0645 \u0647\u0631\u06af\u0648\u0646\u0647 \u0627\u0642\u062f\u0627\u0645 \u063a\u06cc\u0631\u0645\u062c\u0627\u0632 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0631\u062f. <\/p>\n<p>\u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u0686\u0646\u06cc\u0646 \u062d\u0645\u0644\u0627\u062a\u06cc \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u062e\u0648\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u06cc\u0646 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<h3 id=\"use-middleware-based-rate-limiting\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b2_%d9%85%d8%ad%d8%af%d9%88%d8%af%db%8c%d8%aa_%d9%86%d8%b1%d8%ae_%d9%85%d8%a8%d8%aa%d9%86%db%8c_%d8%a8%d8%b1_middleware_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0627\u0632 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u0646\u0631\u062e \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 Middleware \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>Rate-limiting \u0628\u0631\u0627\u06cc \u06a9\u0646\u062a\u0631\u0644 \u0641\u0631\u06a9\u0627\u0646\u0633 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631\u060c API \u06cc\u0627 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0627\u06cc\u0646 \u0628\u0627 \u062f\u0627\u0634\u062a\u0646 \u0645\u062d\u062f\u0648\u062f\u06cc\u062a \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f \u0631\u0648\u06cc \u062a\u0639\u062f\u0627\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646 \u062f\u0631 \u06cc\u06a9 \u0628\u0627\u0632\u0647 \u0632\u0645\u0627\u0646\u06cc \u0645\u0639\u06cc\u0646 \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f. <\/p>\n<p>\u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648\u060c \u0627\u06cc\u062c\u0627\u062f \u06cc\u0627 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u0645\u06cc\u0627\u0646 \u0627\u0641\u0632\u0627\u0631 \u0633\u0641\u0627\u0631\u0634\u06cc \u0628\u0631\u0627\u06cc \u0631\u062f\u06cc\u0627\u0628\u06cc \u0648 \u0645\u062d\u062f\u0648\u062f \u06a9\u0631\u062f\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0627\u0631\u0628\u0631\u060c \u062a\u0645\u0631\u06cc\u0646 \u062e\u0648\u0628\u06cc \u0627\u0633\u062a. \u0631\u0648\u06cc \u0622\u062f\u0631\u0633 IP \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631  \u0627\u06af\u0631 \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u0645\u06cc\u0627\u0646 \u0627\u0641\u0632\u0627\u0631 \u0633\u0641\u0627\u0631\u0634\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0628\u0633\u062a\u0647 \u0645\u062d\u062f\u0648\u062f \u06a9\u0646\u0646\u062f\u0647 django-rate \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f. <\/p>\n<h3 id=\"enable-csrf-middleware\"><span class=\"ez-toc-section\" id=\"csrf_middleware_%d8%b1%d8%a7_%d9%81%d8%b9%d8%a7%d9%84_%da%a9%d9%86%db%8c%d8%af\"><\/span>CSRF Middleware \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f <span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0645\u06cc\u0627\u0646\u200c\u0627\u0641\u0632\u0627\u0631 \u062c\u0639\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0645\u062a\u0642\u0627\u0628\u0644 (CSRF) \u062f\u0631 \u062c\u0646\u06af\u0648 \u06cc\u06a9 \u0627\u0628\u0632\u0627\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0627\u062e\u0644\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u062a\u0648\u06a9\u0646 CRSF \u0647\u0646\u06af\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u060c \u0645\u0627\u0646\u0646\u062f \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u062f \u0648\u0627\u0631\u062f \u0633\u06cc\u0633\u062a\u0645 \u0634\u0648\u062f\u060c \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062d\u0645\u0644\u0627\u062a CSRF \u0645\u062d\u0627\u0641\u0638\u062a \u0645\u06cc\u200c\u06a9\u0646\u062f. <\/p>\n<p>\u0627\u06cc\u0646 \u0627\u06cc\u062f\u0647 \u062e\u0648\u0628\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc\u0627\u0646 \u0627\u0641\u0632\u0627\u0631 CRSF \u062c\u0646\u06af\u0648 \u0631\u0627 \u062f\u0631 \u062e\u0648\u062f \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f <strong>\u062a\u0646\u0638\u06cc\u0645\u0627\u062a.py<\/strong>. <\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code class=\"language-python\">MIDDLEWARE = [\n ...\n 'django.middleware.csrf.CsrfViewMiddleware'\n ...\n]<\/code><\/pre><figcaption>\u0627\u0641\u0632\u0648\u062f\u0646 \u0645\u06cc\u0627\u0646 \u0627\u0641\u0632\u0627\u0631 CRSF<\/figcaption><\/figure>\n<h3 id=\"always-use-crsf-tokens\"><span class=\"ez-toc-section\" id=\"%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a7%d8%b2_%d8%aa%d9%88%da%a9%d9%86_%d9%87%d8%a7%db%8c_crsf_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc CRSF \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062a\u0648\u06a9\u0646\u200c\u0647\u0627\u06cc \u062c\u0639\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0645\u062a\u0642\u0627\u0637\u0639 (CSRF) \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u062a\u0635\u0627\u062f\u0641\u06cc \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u0634\u0645\u0627 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0648 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0641\u06cc\u0644\u062f\u0647\u0627\u06cc \u0645\u062e\u0641\u06cc \u062f\u0631 \u0641\u0631\u0645\u200c\u0647\u0627\u06cc HTML \u0634\u0645\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u06cc\u0627 \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc AJAX \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f. <\/p>\n<p>\u062a\u0648\u06a9\u0646\u200c\u0647\u0627\u06cc CRSF \u0628\u0627 \u0645\u06cc\u0627\u0646\u200c\u0627\u0641\u0632\u0627\u0631 CRSF \u06a9\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u0634\u0645\u0627 \u0646\u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u06cc\u06a9\u06cc \u0628\u062f\u0648\u0646 \u062f\u06cc\u06af\u0631\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.  \u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646\u200c\u0647\u0627\u06cc CRSF\u060c \u062c\u0646\u06af\u0648 \u0628\u0647\u200c\u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u062a\u0648\u06a9\u0646\u200c\u0647\u0627 \u0631\u0627 \u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0634\u0645\u0627 \u06a9\u0646\u062a\u0631\u0644 \u0645\u06cc\u200c\u06a9\u0646\u062f <code>{% crsf token %}<\/code> \u062a\u06af \u0642\u0627\u0644\u0628 <\/p>\n<figure class=\"kg-card kg-code-card\">\n<pre><code class=\"language-html\">&amp;lt;form method=\"post\"&gt;\n    {% csrf_token %}\n    ...\n&amp;lt;\/form&gt;\n<\/code><\/pre><figcaption>\u062a\u0639\u0631\u06cc\u0641 \u062a\u0648\u06a9\u0646 CRSF \u062f\u0631 \u06a9\u062f HTML<\/figcaption><\/figure>\n<h2 id=\"built-in-django-security-checklist\"><span class=\"ez-toc-section\" id=\"%da%86%da%a9_%d9%84%db%8c%d8%b3%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c_%d8%ac%d9%86%da%af%d9%88_%d8%af%d8%a7%d8%ae%d9%84%db%8c\"><\/span>\u0686\u06a9 \u0644\u06cc\u0633\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062c\u0646\u06af\u0648 \u062f\u0627\u062e\u0644\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u06cc\u0646 \u0631\u0627 \u0646\u0645\u06cc \u062f\u0627\u0646\u0646\u062f\u060c \u0627\u0645\u0627 \u062c\u0646\u06af\u0648 \u06cc\u06a9 \u0686\u06a9 \u0644\u06cc\u0633\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0627\u062e\u0644\u06cc \u062f\u0627\u0631\u062f \u062a\u0627 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u062f \u06a9\u0647 \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc \u06a9\u0627\u0645\u0644\u0627\u064b \u0627\u06cc\u0645\u0646 \u0634\u062f\u0647 \u0631\u0627 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u062f. <\/p>\n<p>\u0627\u06cc\u0646 \u062f\u0633\u062a\u0648\u0631\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0627\u0633\u06a9\u0646 \u0645\u06cc \u06a9\u0646\u062f <strong>\u062a\u0646\u0638\u06cc\u0645\u0627\u062a.py<\/strong>  \u0648 \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u062f\u0633\u062a\u0648\u0631\u0627\u0644\u0639\u0645\u0644 \u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u062c\u0646\u06af\u0648 \u0631\u0627 \u062a\u0635\u0648\u06cc\u0628 \u0645\u06cc \u06a9\u0646\u06cc\u062f \u06cc\u0627 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0647\u0627\u06cc\u06cc \u062f\u0627\u0631\u06cc\u062f \u06a9\u0647 \u0647\u06a9\u0631\u0647\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u0622\u0646\u0647\u0627 \u0633\u0648\u0621 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f.  \u0641\u0631\u0645\u0627\u0646 \u0627\u0633\u062a <code>python manage.py check --deploy<\/code><\/p>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u062f\u0633\u062a\u0648\u0631 \u0631\u0627 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0628\u0627\u06cc\u062f \u0647\u0645\u0647 \u0627\u062e\u0637\u0627\u0631\u0647\u0627 \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f \u0648 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0631\u062e\u06cc \u0627\u0632 \u062e\u0637\u0627\u0647\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 (\u062f\u0631 \u0635\u0648\u0631\u062a \u0648\u062c\u0648\u062f \u062e\u0637\u0627) \u0631\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0686\u06cc\u0632\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0627\u06cc\u0646:<\/p>\n<figure class=\"kg-card kg-image-card kg-width-wide kg-card-hascaption\"><img decoding=\"async\" src=\"https:\/\/rasanegaar.com\/blog\/wp-content\/uploads\/2024\/05\/TJJQfxXbJaC4e9Jnwdu16ESNJa4rr6Ju84ltFfc9cIY_CtCUzNtY7ovh1k-fv9HamrY-dPVUn1izNw5_0siyuCSlP3dQNIN4YU57.png\" class=\"kg-image\" alt=\"preencoded.png\" width=\"1385\" height=\"397\" loading=\"lazy\" title=\"\"><figcaption>\u0627\u0633\u06a9\u0631\u06cc\u0646 \u0634\u0627\u062a \u0646\u062a\u0627\u06cc\u062c \u0641\u0631\u0645\u0627\u0646 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f<\/figcaption><\/figure>\n<h2 id=\"other-security-practices\"><span class=\"ez-toc-section\" id=\"%d8%b3%d8%a7%db%8c%d8%b1_%d8%a7%d9%82%d8%af%d8%a7%d9%85%d8%a7%d8%aa_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c\"><\/span>\u0633\u0627\u06cc\u0631 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0631\u0648\u06cc\u0647\u200c\u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0647 \u0622\u0633\u06cc\u0628\u200c\u067e\u0630\u06cc\u0631\u06cc\u200c\u0647\u0627\u06cc \u0648\u0628 \u062e\u0627\u0635 \u0631\u0627 \u0647\u062f\u0641 \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u062f\u0647\u0646\u062f\u060c \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u062c\u0632\u0626\u06cc \u0646\u06cc\u0632 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0642\u062f\u0631\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0644\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0627\u0641\u0632\u0627\u06cc\u0634 \u062f\u0647\u062f.<\/p>\n<ol>\n<li>\u0631\u0648\u0634\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0646\u0638\u0627\u0631\u062a \u0645\u0633\u062a\u0645\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648 \u0645\u0633\u062a\u0642\u0631 \u0634\u062f\u0647 \u062e\u0648\u062f \u0628\u0631\u0627\u06cc \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0648 \u067e\u0627\u0633\u062e\u06af\u0648\u06cc\u06cc \u0628\u0647 \u062d\u0648\u0627\u062f\u062b \u0627\u0645\u0646\u06cc\u062a\u06cc \u06cc\u0627 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u062f\u0631 \u0632\u0645\u0627\u0646 \u0648\u0627\u0642\u0639\u06cc \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f. <\/li>\n<li>\u0686\u0627\u0631\u0686\u0648\u0628 \u062c\u0646\u06af\u0648\u060c \u0648\u0627\u0628\u0633\u062a\u06af\u06cc\u200c\u0647\u0627 \u0648 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647\u200c\u0647\u0627\u06cc \u0634\u062e\u0635 \u062b\u0627\u0644\u062b \u062e\u0648\u062f \u0631\u0627 \u0647\u0631 \u06f2 \u062a\u0627 \u06f4 \u0645\u0627\u0647 \u06cc\u06a9\u0628\u0627\u0631 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u062f \u062a\u0627 \u067e\u0631\u0648\u0698\u0647 \u0634\u0645\u0627 \u0628\u0647\u200c\u0631\u0648\u0632 \u0628\u0627\u0634\u062f \u0648 \u0627\u0632 \u0622\u062e\u0631\u06cc\u0646 \u0648\u0635\u0644\u0647\u200c\u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f \u0648 \u0628\u062f\u0648\u0646 \u0627\u0634\u06a9\u0627\u0644 \u0628\u0627\u0634\u062f. <\/li>\n<li>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0627\u06cc \u0646\u0638\u0627\u0631\u062a \u0648 \u062b\u0628\u062a \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u06cc\u0627 \u0641\u0639\u0627\u0644\u06cc\u062a\u200c\u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637 \u0628\u0627 \u0627\u0645\u0646\u06cc\u062a \u06a9\u0647 \u062f\u0631 \u067e\u0631\u0648\u0698\u0647\u200c\u0647\u0627\u06cc\u062a\u0627\u0646 \u0627\u062a\u0641\u0627\u0642 \u0645\u06cc\u200c\u0627\u0641\u062a\u062f\u060c \u0644\u0627\u06af \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f.  \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062d\u0648\u0627\u062f\u062b \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u062d\u062a\u0645\u0627\u0644\u06cc \u0631\u0627 \u0645\u0648\u0631\u062f \u062a\u0648\u062c\u0647 \u0642\u0631\u0627\u0631 \u062f\u0647\u062f. <\/li>\n<\/ol>\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 \u0646\u062a\u06cc\u062c\u0647\u060c \u0627\u06cc\u0645\u0646 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u062a\u0648\u062c\u0647 \u0632\u06cc\u0627\u062f\u06cc \u0648 \u06cc\u06a9 \u0627\u0633\u062a\u0631\u0627\u062a\u0698\u06cc \u0686\u0646\u062f \u0644\u0627\u06cc\u0647 \u062f\u0627\u0631\u062f.  \u0627\u06cc\u0646 \u0634\u0627\u0645\u0644 \u0627\u062c\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u06cc\u0645\u0646\u060c \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0648\u0631\u0648\u062f\u06cc \u06a9\u0627\u0631\u0628\u0631\u060c \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u0631\u062a\u0628\u0627\u0637 \u0633\u0631\u062a\u0627\u0633\u0631 \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 (\u0627\u0639\u0645 \u0627\u0632 \u0645\u0634\u062a\u0631\u06cc \u0628\u0647 \u0633\u0631\u0648\u0631 \u06cc\u0627 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631) \u0648 \u0627\u0639\u0645\u0627\u0644 \u0645\u0639\u06cc\u0627\u0631\u0647\u0627\u06cc \u0645\u062d\u062f\u0648\u062f\u06a9\u0646\u0646\u062f\u0647 \u0646\u0631\u062e \u0627\u0633\u062a. <\/p>\n<p>\u0627\u06cc\u0646 \u0634\u06cc\u0648\u0647 \u0647\u0627 \u0628\u0647 \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc \u0642\u0648\u06cc \u062a\u0631 \u0648 \u0627\u06cc\u0645\u0646 \u062a\u0631 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<\/section>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-05-22 23:16:17<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;17424&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;\u0686\u06af\u0648\u0646\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648 \u062e\u0648\u062f \u0631\u0627 \u0627\u06cc\u0645\u0646 \u06a9\u0646\u06cc\u0645 \u2013 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0648 \u0646\u0645\u0648\u0646\u0647 \u06a9\u062f&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\"> 7<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0628\u0647\u200c\u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647 \u06cc\u0627 \u0645\u0647\u0646\u062f\u0633 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631\u060c \u062f\u0627\u0646\u0633\u062a\u0646 \u0631\u0648\u0634 \u0633\u0627\u062e\u062a \u0631\u0627\u0647\u200c\u062d\u0644\u200c\u0647\u0627\u06cc \u0645\u0641\u06cc\u062f \u06a9\u0627\u0641\u06cc \u0646\u06cc\u0633\u062a \u2013 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0627\u06cc\u062f \u0627\u0632 \u0627\u06cc\u0645\u0646 \u0628\u0648\u062f\u0646 \u0622\u0646\u0647\u0627 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f. \u0627\u0648\u0644\u0648\u06cc\u062a \u0628\u0646\u062f\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0647\u0646\u06af\u0627\u0645 \u062a\u0648\u0633\u0639\u0647 \u0648 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u0634\u0645\u0627 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0647\u0645 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0627\u06af\u0631 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0646\u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f\u060c \u0628\u06cc \u0641\u0627\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0645\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 [&hellip;]<\/p>\n","protected":false},"author":6,"featured_media":17425,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1743],"tags":[2099,1938,1919,1916,5124,1909,1877,1915,1822,1802,1803,2123,2001,2552,1788,2958,1765,1745,1927],"class_list":["post-17424","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-python","tag-2099","tag-1938","tag----python","tag-1916","tag-5124","tag-1909","tag-1877","tag-1915","tag-1822","tag-1802","tag-1803","tag-2123","tag---python","tag-2552","tag-1788","tag-2958","tag-1765","tag-1745","tag-1927"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/17424","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\/6"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=17424"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/17424\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/17425"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=17424"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=17424"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=17424"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}