{"id":18917,"date":"2025-04-17T01:59:14","date_gmt":"2025-04-16T22:29:14","guid":{"rendered":"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/"},"modified":"2025-04-17T01:59:14","modified_gmt":"2025-04-16T22:29:14","slug":"%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/","title":{"rendered":"\u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u062a\u0648\u06a9\u0646 \u0648\u0628 JSON \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 REST Django"},"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 ' ><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d9%81%d9%87%d8%b1%d8%b3%d8%aa_%d9%85%d8%b7%d8%a7%d9%84%d8%a8\" >\u0641\u0647\u0631\u0633\u062a \u0645\u0637\u0627\u0644\u0628:<\/a><\/li><\/ul><\/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%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#jwt_%da%86%db%8c%d8%b3%d8%aa%d8%9f\" >JWT \u0686\u06cc\u0633\u062a\u061f<\/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%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%da%86%d8%b1%d8%a7_%d8%a7%d8%b2_jwt_%d8%af%d8%b1_%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8_rest_django_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d9%85%db%8c_%da%a9%d9%86%db%8c%d8%af%d8%9f\" >\u0686\u0631\u0627 \u0627\u0632 JWT \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 REST Django \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u061f<\/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%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%b1%d9%88%d8%b4_%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_jwt_%d8%af%d8%b1_%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8_%d8%a7%d8%b3%d8%aa%d8%b1%d8%a7%d8%ad%d8%aa_django\" >\u0631\u0648\u0634 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc JWT \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 \u0627\u0633\u062a\u0631\u0627\u062d\u062a Django<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d9%85%d8%b1%d8%ad%d9%84%d9%87_1_%d8%a8%d8%b3%d8%aa%d9%87_%d9%87%d8%a7%db%8c_%d9%85%d9%88%d8%b1%d8%af_%d9%86%db%8c%d8%a7%d8%b2_%d8%b1%d8%a7_%d9%86%d8%b5%d8%a8_%da%a9%d9%86%db%8c%d8%af\" >\u0645\u0631\u062d\u0644\u0647 1: \u0628\u0633\u062a\u0647 \u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0631\u0627 \u0646\u0635\u0628 \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\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d9%85%d8%b1%d8%ad%d9%84%d9%87_2_%d8%aa%d9%86%d8%b8%db%8c%d9%85%d8%a7%d8%aa_django_%d8%ae%d9%88%d8%af_%d8%b1%d8%a7_%d8%a8%d9%87_%d8%b1%d9%88%d8%b2_%da%a9%d9%86%db%8c%d8%af\" >\u0645\u0631\u062d\u0644\u0647 2: \u062a\u0646\u0638\u06cc\u0645\u0627\u062a Django \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \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\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d9%85%d8%b1%d8%ad%d9%84%d9%87_3_url_%d9%87%d8%a7%db%8c_%d8%aa%d9%88%da%a9%d9%86_%d8%b1%d8%a7_%d8%a8%d9%87_%d8%ae%d9%88%d8%af_%d8%a7%d8%b6%d8%a7%d9%81%d9%87_%da%a9%d9%86%db%8c%d8%af_urlspy\" >\u0645\u0631\u062d\u0644\u0647 3: URL \u0647\u0627\u06cc \u062a\u0648\u06a9\u0646 \u0631\u0627 \u0628\u0647 \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f urls.py<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d9%85%d8%b1%d8%ad%d9%84%d9%87_4_%d8%a2%d9%86_%d8%b1%d8%a7_%d8%a2%d8%b2%d9%85%d8%a7%db%8c%d8%b4_%da%a9%d9%86%db%8c%d8%af\" >\u0645\u0631\u062d\u0644\u0647 4: \u0622\u0646 \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \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-9\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%b1%d9%88%d8%b4_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%d8%a7%db%8c%d9%86_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7\" >\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%a7%db%8c%d9%85%d9%86_%da%a9%d8%b1%d8%af%d9%86_%d9%86%d9%85%d8%a7%d9%87%d8%a7%db%8c_api_%d8%ae%d9%88%d8%af\" >\u0627\u06cc\u0645\u0646 \u06a9\u0631\u062f\u0646 \u0646\u0645\u0627\u0647\u0627\u06cc API \u062e\u0648\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\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%ae%d9%84%d8%a7%d8%b5%d9%87\" >\u062e\u0644\u0627\u0635\u0647<\/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\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d9%85%d8%aa%d8%af%d8%a7%d9%88%d9%84\" >\u0645\u062a\u062f\u0627\u0648\u0644<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%aa%d9%88%da%a9%d9%86_%da%86%d9%87_%d9%85%d8%af%d8%aa_%d8%b7%d9%88%d9%84_%d9%85%db%8c_%da%a9%d8%b4%d8%af%d8%9f\" >\u062a\u0648\u06a9\u0646 \u0686\u0647 \u0645\u062f\u062a \u0637\u0648\u0644 \u0645\u06cc \u06a9\u0634\u062f\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-14\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%da%a9%d8%ac%d8%a7_%d8%a8%d8%a7%db%8c%d8%af_%d8%aa%d9%88%da%a9%d9%86_%d8%b1%d8%a7_%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%da%a9%d9%86%d9%85_%d8%b1%d9%88%db%8c_%d8%ac%d9%84%d9%88%d8%9f\" >\u06a9\u062c\u0627 \u0628\u0627\u06cc\u062f \u062a\u0648\u06a9\u0646 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u0645 \u0631\u0648\u06cc \u062c\u0644\u0648\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-15\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%a2%db%8c%d8%a7_%d9%85%db%8c_%d8%aa%d9%88%d8%a7%d9%86%d9%85_%d8%b2%d9%85%db%8c%d9%86%d9%87_%d9%87%d8%a7%db%8c_%d8%b3%d9%81%d8%a7%d8%b1%d8%b4%db%8c_%d8%b1%d8%a7_%d8%a8%d9%87_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d8%a7%d8%b6%d8%a7%d9%81%d9%87_%da%a9%d9%86%d9%85%d8%9f\" >\u0622\u06cc\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0632\u0645\u06cc\u0646\u0647 \u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u0631\u0627 \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u0645\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-16\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%ae%d9%84%d8%a7%d8%b5%d9%87-2\" >\u062e\u0644\u0627\u0635\u0647:<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-17\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%a8%d9%87%d8%aa%d8%b1%db%8c%d9%86_%d8%b1%d9%88%d8%b4%d9%87%d8%a7\" >\u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-18\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#1_%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a7%d8%b2_https_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\" >1 \u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 https \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-19\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#2_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7%db%8c_%d8%ad%d8%b3%d8%a7%d8%b3_%d8%b1%d8%a7_%d8%af%d8%b1_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%d9%86%da%a9%d9%86%db%8c%d8%af\" >2 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u0631\u0627 \u062f\u0631 \u0646\u0634\u0627\u0646\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0646\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-20\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#3_%da%a9%d9%84%db%8c%d8%af_%d8%a7%d9%85%d8%b6%d8%a7%db%8c_%d8%ae%d9%88%d8%af_%d8%b1%d8%a7_%d9%85%d8%ae%d9%81%db%8c_%d9%86%da%af%d9%87_%d8%af%d8%a7%d8%b1%db%8c%d8%af\" >3 \u06a9\u0644\u06cc\u062f \u0627\u0645\u0636\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0645\u062e\u0641\u06cc \u0646\u06af\u0647 \u062f\u0627\u0631\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-21\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#4_%d8%af%d8%b1_%d8%b5%d9%88%d8%b1%d8%aa_%d9%84%d8%b2%d9%88%d9%85_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7_%d8%b1%d8%a7_%d8%a8%da%86%d8%b1%d8%ae%d8%a7%d9%86%db%8c%d8%af\" >4 \u062f\u0631 \u0635\u0648\u0631\u062a \u0644\u0632\u0648\u0645 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627 \u0631\u0627 \u0628\u0686\u0631\u062e\u0627\u0646\u06cc\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-22\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#5_%db%8c%da%a9_%d8%b9%d9%85%d8%b1_%da%a9%d9%88%d8%aa%d8%a7%d9%87_%d8%a8%d8%b1%d8%a7%db%8c_%d8%af%d8%b3%d8%aa%d8%b1%d8%b3%db%8c_%d8%a8%d9%87_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7%db%8c_%d8%af%d8%b3%d8%aa%d8%b1%d8%b3%db%8c_%d8%aa%d9%86%d8%b8%db%8c%d9%85_%da%a9%d9%86%db%8c%d8%af_%d9%88_%d8%a7%d8%b2_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7%db%8c_%d8%aa%d8%a7%d8%b2%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%b9%d8%a7%d9%82%d9%84%d8%a7%d9%86%d9%87_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\" >5 \u06cc\u06a9 \u0639\u0645\u0631 \u06a9\u0648\u062a\u0627\u0647 \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f \u0648 \u0627\u0632 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u0639\u0627\u0642\u0644\u0627\u0646\u0647 \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-23\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%a7%d9%81%da%a9%d8%a7%d8%b1_%d9%86%d9%87%d8%a7%db%8c%db%8c\" >\u0627\u0641\u06a9\u0627\u0631 \u0646\u0647\u0627\u06cc\u06cc<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-24\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%aa%d9%88%da%a9%d9%86-%d9%88%d8%a8-json-%d8%af%d8%b1-%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8-rest-django\/#%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86_%d9%88_%d9%85%d9%86%d8%a7%d8%a8%d8%b9_%d8%a8%db%8c%d8%b4%d8%aa%d8%b1\" >\u062e\u0648\u0627\u0646\u062f\u0646 \u0648 \u0645\u0646\u0627\u0628\u0639 \u0628\u06cc\u0634\u062a\u0631<\/a><\/li><\/ul><\/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<section class=\"post-content \" data-test-label=\"post-content\">\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 API \u0647\u0633\u062a\u06cc\u062f \u060c \u0627\u0645\u0646\u06cc\u062a \u0628\u0627\u06cc\u062f \u062f\u0631 \u0635\u062f\u0631 \u0644\u06cc\u0633\u062a \u0634\u0645\u0627 \u0628\u0627\u0634\u062f. \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0641\u0642\u0637 \u0627\u0641\u0631\u0627\u062f \u0645\u0646\u0627\u0633\u0628 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0645\u0648\u0627\u0631\u062f \u0645\u0646\u0627\u0633\u0628 \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0646\u0646\u062f &#8211; \u0648 \u0627\u06cc\u0646\u062c\u0627\u0633\u062a \u06a9\u0647 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0648\u0627\u0631\u062f \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u06cc\u06a9\u06cc \u0627\u0632 \u0645\u062a\u062f\u0627\u0648\u0644 \u062a\u0631\u06cc\u0646 \u0648 \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f \u062a\u0631\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062a\u0623\u06cc\u06cc\u062f \u0627\u0639\u062a\u0628\u0627\u0631 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0645\u062f\u0631\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 JWT \u060c \u06a9\u0648\u062a\u0627\u0647 \u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u0648\u0628 JSON \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06af\u0631 \u062f\u0631 \u062d\u0627\u0644 \u06a9\u0627\u0631 \u0628\u0627 \u0686\u0627\u0631\u0686\u0648\u0628 Django Rest (DRF) \u0647\u0633\u062a\u06cc\u062f \u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0627\u0632 \u0642\u0628\u0644 \u0628\u062f\u0627\u0646\u06cc\u062f \u06a9\u0647 \u0627\u06cc\u0646 \u0627\u0628\u0632\u0627\u0631 \u0628\u0627 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u0645\u0641\u06cc\u062f \u0632\u06cc\u0627\u062f\u06cc \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a API \u0647\u0645\u0631\u0627\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u0645\u0627 \u0648\u0642\u062a\u06cc \u0635\u062d\u0628\u062a \u0627\u0632 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0648\u06a9\u0646 \u0645\u06cc \u0634\u0648\u062f \u060c \u0628\u0627\u06cc\u062f \u06a9\u0645\u06cc \u06a9\u0645\u06a9 \u0627\u0636\u0627\u0641\u06cc \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f. JWT \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u062f\u0631 DRF \u0633\u0627\u062e\u062a\u0647 \u0646\u0634\u062f\u0647 \u0627\u0633\u062a \u060c \u0627\u0645\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0622\u0646 \u0628\u0633\u06cc\u0627\u0631 \u0622\u0633\u0627\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0645\u0631\u0627\u062d\u0644 \u0631\u0627 \u0628\u062f\u0627\u0646\u06cc\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u060c \u0645\u0646 \u062f\u0642\u06cc\u0642\u0627\u064b \u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 JWT \u0647\u0627 \u0631\u0627 \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 REST Django \u0642\u062f\u0645 \u0628\u0647 \u0642\u062f\u0645 \u0637\u06cc \u0645\u06cc \u06a9\u0646\u0645.<\/p>\n<h3 id=\"heading-table-of-contents\"><span class=\"ez-toc-section\" id=\"%d9%81%d9%87%d8%b1%d8%b3%d8%aa_%d9%85%d8%b7%d8%a7%d9%84%d8%a8\"><\/span>\u0641\u0647\u0631\u0633\u062a \u0645\u0637\u0627\u0644\u0628:<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<ol>\n<li>\n<p>JWT \u0686\u06cc\u0633\u062a\u061f<\/p>\n<\/li>\n<li>\n<p>\u0686\u0631\u0627 \u0627\u0632 JWT \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 REST Django \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u061f<\/p>\n<\/li>\n<li>\n<p>\u0631\u0648\u0634 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc JWT \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 \u0627\u0633\u062a\u0631\u0627\u062d\u062a Django<\/p>\n<\/li>\n<li>\n<p>\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627<\/p>\n<\/li>\n<li>\n<p>\u0645\u062a\u062f\u0627\u0648\u0644<\/p>\n<\/li>\n<li>\n<p>\u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627<\/p>\n<\/li>\n<li>\n<p>\u0627\u0641\u06a9\u0627\u0631 \u0646\u0647\u0627\u06cc\u06cc<\/p>\n<\/li>\n<\/ol>\n<h2 id=\"heading-what-is-a-jwt\"><span class=\"ez-toc-section\" id=\"jwt_%da%86%db%8c%d8%b3%d8%aa%d8%9f\"><\/span>JWT \u0686\u06cc\u0633\u062a\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>JWT (JSON Web Token) \u0631\u0648\u0634\u06cc \u062c\u0645\u0639 \u0648 \u062c\u0648\u0631 \u0648 \u062f\u0627\u0631\u0627\u06cc \u062e\u0648\u062f \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0627\u06cc\u0645\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0646 \u062f\u0648 \u0637\u0631\u0641 \u0627\u0633\u062a. \u0627\u06cc\u0646 \u0627\u063a\u0644\u0628 \u0628\u0631\u0627\u06cc \u062a\u0623\u06cc\u06cc\u062f \u0627\u0639\u062a\u0628\u0627\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0648\u0642\u062a\u06cc \u06a9\u0633\u06cc \u0648\u0627\u0631\u062f \u0633\u06cc\u0633\u062a\u0645 \u0645\u06cc \u0634\u0648\u062f \u060c \u0646\u0634\u0627\u0646\u0647 \u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u0646\u0634\u0627\u0646\u0647 \u062f\u0631 \u062c\u0628\u0647\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u0634\u0648\u062f (\u0645\u0627\u0646\u0646\u062f LocalStorage) \u060c \u0648 \u0647\u0631 \u0628\u0627\u0631 \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0645\u06cc \u06a9\u0646\u062f \u060c \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u0622\u0646 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0633\u0631\u0648\u0631 \u0622\u0646 \u0646\u0634\u0627\u0646\u0647 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc \u06a9\u0646\u062f \u060c \u0648 \u0627\u06af\u0631 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u062e\u0648\u0628 \u0627\u0633\u062a \u060c \u0628\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u0645\u06cc \u06a9\u0646\u062f. \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u06a9\u0648\u06a9\u06cc \u06cc\u0627 \u062c\u0644\u0633\u0627\u062a \u0646\u06cc\u0633\u062a.<\/p>\n<p>JWT \u0627\u0632 \u0633\u0647 \u0642\u0633\u0645\u062a \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<ol>\n<li>\n<p><strong>\u0647\u062f\u0631<\/strong> &#8211; \u062d\u0627\u0648\u06cc \u0646\u0648\u0639 \u062a\u0648\u06a9\u0646 \u0648 \u0627\u0644\u06af\u0648\u0631\u06cc\u062a\u0645 \u0627\u0645\u0636\u0627 \u0627\u0633\u062a.<\/p>\n<\/li>\n<li>\n<p><strong>\u0628\u0627\u0631<\/strong> &#8211; \u0634\u0627\u0645\u0644 \u062f\u0627\u062f\u0647 \u0647\u0627 (\u0645\u0627\u0646\u0646\u062f \u0634\u0646\u0627\u0633\u0647 \u06a9\u0627\u0631\u0628\u0631).<\/p>\n<\/li>\n<li>\n<p><strong>\u0627\u0645\u0636\u0627\u0621<\/strong> &#8211; \u0628\u0631\u0627\u06cc \u062a\u0623\u06cc\u06cc\u062f \u0646\u0634\u0627\u0646\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0646\u06a9\u0631\u062f.<\/p>\n<\/li>\n<\/ol>\n<h2 id=\"heading-why-use-jwt-in-the-django-rest-framework\"><span class=\"ez-toc-section\" id=\"%da%86%d8%b1%d8%a7_%d8%a7%d8%b2_jwt_%d8%af%d8%b1_%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8_rest_django_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d9%85%db%8c_%da%a9%d9%86%db%8c%d8%af%d8%9f\"><\/span>\u0686\u0631\u0627 \u0627\u0632 JWT \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 REST Django \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 JWT \u06cc\u06a9 \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u062d\u06a9\u0645 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc DRF \u0627\u0633\u062a:<\/p>\n<ul>\n<li>\n<p><strong>\u0628\u06cc \u0631\u0648\u06cc\u0647<\/strong>: \u0647\u06cc\u0686 \u062c\u0644\u0633\u06cc \u0644\u0627\u0632\u0645 \u0646\u06cc\u0633\u062a \u0631\u0648\u06cc \u0633\u0631\u0648\u0631<\/p>\n<\/li>\n<li>\n<p><strong>\u0645\u0642\u06cc\u0627\u0633 \u067e\u0630\u06cc\u0631<\/strong>: \u0627\u0632 \u0622\u0646\u062c\u0627 \u06a9\u0647 \u0628\u062f\u0648\u0646 \u062a\u0627\u0628\u0639\u06cc\u062a \u0627\u0633\u062a \u060c \u0628\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0628\u0632\u0631\u06af\u062a\u0631 \u0648 \u0645\u06cc\u06a9\u0631\u0648\u0633\u0631\u0648\u06cc\u0633 \u0647\u0627 \u0628\u0647 \u062e\u0648\u0628\u06cc \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p><strong>\u0628\u0647 \u0637\u0648\u0631 \u06af\u0633\u062a\u0631\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f<\/strong>: JWT \u06cc\u06a9 \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u0645\u0634\u062a\u0631\u06a9 \u0627\u0633\u062a. \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0686\u0627\u0631\u0686\u0648\u0628 \u0647\u0627\u06cc \u062c\u0644\u0648\u06cc (\u0645\u0627\u0646\u0646\u062f React \u060c Vue \u0648 SO \u0631\u0648\u06cc) \u0627\u0632 \u0642\u0628\u0644 \u0645\u06cc \u062f\u0627\u0646\u06cc\u062f \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0628\u0627 \u0622\u0646 \u06a9\u0627\u0631 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<\/ul>\n<h2 id=\"heading-how-to-set-up-jwt-in-the-django-rest-framework\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%88%d8%b4_%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_jwt_%d8%af%d8%b1_%da%86%d8%a7%d8%b1%da%86%d9%88%d8%a8_%d8%a7%d8%b3%d8%aa%d8%b1%d8%a7%d8%ad%d8%aa_django\"><\/span>\u0631\u0648\u0634 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc JWT \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 \u0627\u0633\u062a\u0631\u0627\u062d\u062a Django<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0648\u0627\u0631\u062f \u0622\u0646 \u0634\u0648\u06cc\u0645. \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0631\u0648\u0634 \u062a\u0646\u0638\u06cc\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a JWT \u062f\u0631 DRF \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<h3 id=\"heading-step-1-install-required-packages\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87_1_%d8%a8%d8%b3%d8%aa%d9%87_%d9%87%d8%a7%db%8c_%d9%85%d9%88%d8%b1%d8%af_%d9%86%db%8c%d8%a7%d8%b2_%d8%b1%d8%a7_%d9%86%d8%b5%d8%a8_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0645\u0631\u062d\u0644\u0647 1: \u0628\u0633\u062a\u0647 \u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 JWT \u0628\u0647 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f. \u0645\u062d\u0628\u0648\u0628 \u062a\u0631\u06cc\u0646 \u0645\u0648\u0631\u062f DjangorestFrameWork-SimpleJwt \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06cc\u0646 \u0631\u0627 \u062f\u0631 \u062e\u0648\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f terminal:<\/p>\n<pre><code class=\"lang-bash\">pip install djangorestframework-simplejwt\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0647\u0645\u0647 \u0686\u06cc\u0632\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u060c \u062a\u0627\u0632\u0647 \u06a9\u0631\u062f\u0646 \u0648 \u062a\u0623\u06cc\u06cc\u062f \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u0648\u0628 JSON \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 DRF \u062e\u0648\u062f \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f \u060c \u0646\u0635\u0628 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<h3 id=\"heading-step-2-update-your-django-settings\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87_2_%d8%aa%d9%86%d8%b8%db%8c%d9%85%d8%a7%d8%aa_django_%d8%ae%d9%88%d8%af_%d8%b1%d8%a7_%d8%a8%d9%87_%d8%b1%d9%88%d8%b2_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0645\u0631\u062d\u0644\u0647 2: \u062a\u0646\u0638\u06cc\u0645\u0627\u062a Django \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0647 \u0633\u0645\u062a \u062e\u0648\u062f \u0628\u0631\u0648\u06cc\u062f <code>settings.py<\/code> \u0648 \u0628\u0647 \u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc <code>REST_FRAMEWORK<\/code> \u0628\u062e\u0634\u06cc \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"lang-python\">REST_FRAMEWORK = {\n    <span class=\"hljs-string\">'DEFAULT_AUTHENTICATION_CLASSES'<\/span>: (\n        <span class=\"hljs-string\">'rest_framework_simplejwt.authentication.JWTAuthentication'<\/span>,\n    )\n}\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0628\u0647 DRF \u0645\u06cc \u06af\u0648\u06cc\u062f \u06a9\u0647 \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 JWT \u062f\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u0627\u0634\u062f <code>Authorization<\/code> \u0647\u062f\u0631 \u0648 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u062a\u0623\u06cc\u06cc\u062f \u0627\u0639\u062a\u0628\u0627\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f. \u0627\u06cc\u0646 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062c\u0644\u0633\u0647 \u060c \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0645\u0639\u0645\u0648\u0644\u06cc \u0627\u0633\u062a \u060c \u0628\u0627 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0648\u06a9\u0646 \u060c \u0627\u06cc\u062f\u0647 \u0622\u0644 \u0628\u0631\u0627\u06cc API \u0627\u0633\u062a.<\/p>\n<h3 id=\"heading-step-3-add-token-urls-to-your-urlspy\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87_3_url_%d9%87%d8%a7%db%8c_%d8%aa%d9%88%da%a9%d9%86_%d8%b1%d8%a7_%d8%a8%d9%87_%d8%ae%d9%88%d8%af_%d8%a7%d8%b6%d8%a7%d9%81%d9%87_%da%a9%d9%86%db%8c%d8%af_urlspy\"><\/span>\u0645\u0631\u062d\u0644\u0647 3: URL \u0647\u0627\u06cc \u062a\u0648\u06a9\u0646 \u0631\u0627 \u0628\u0647 \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f <code>urls.py<\/code><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>JWT \u0628\u0627 \u0635\u062f\u0648\u0631 \u06cc\u06a9 \u062c\u0641\u062a \u0646\u0634\u0627\u0646\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f: A <code>access<\/code> \u062a\u0648\u06a9\u0646 (\u06a9\u0648\u062a\u0627\u0647 \u0645\u062f\u062a) \u0648 \u0627\u0644\u0641 <code>refresh<\/code> \u0646\u0634\u0627\u0646\u0647 (\u0637\u0648\u0644\u0627\u0646\u06cc \u0645\u062f\u062a). \u0627\u06cc\u0646 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u062f\u0648 \u062f\u06cc\u062f\u06af\u0627\u0647 \u0627\u0635\u0644\u06cc \u0627\u062f\u0627\u0631\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0634\u0645\u0627 <code>urls.py<\/code> (\u0645\u0639\u0645\u0648\u0644\u0627\u064b \u062f\u0631 root \u067e\u0631\u0648\u0698\u0647 \u06cc\u0627 <code>api<\/code> \u0628\u0631\u0646\u0627\u0645\u0647):<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-keyword\">from<\/span> django.urls <span class=\"hljs-keyword\">import<\/span> path\n<span class=\"hljs-keyword\">from<\/span> rest_framework_simplejwt.views <span class=\"hljs-keyword\">import<\/span> (\n    TokenObtainPairView,\n    TokenRefreshView,\n)\n\nurlpatterns = [\n    path(<span class=\"hljs-string\">'api\/token\/'<\/span>, TokenObtainPairView.as_view(), name=<span class=\"hljs-string\">'token_obtain_pair'<\/span>),\n    path(<span class=\"hljs-string\">'api\/token\/refresh\/'<\/span>, TokenRefreshView.as_view(), name=<span class=\"hljs-string\">'token_refresh'<\/span>),\n]\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u06a9\u062f:<\/p>\n<ul>\n<li>\n<p><code>\/api\/token\/<\/code>: \u0645\u0634\u062a\u0631\u06cc (\u0645\u0627\u0646\u0646\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc Frontend \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u0644\u0641\u0646 \u0647\u0645\u0631\u0627\u0647) \u0627\u0639\u062a\u0628\u0627\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u0648 \u062a\u0627\u0632\u0647 \u06a9\u0631\u062f\u0646 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p><code>\/api\/token\/refresh\/<\/code>: \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0645\u0646\u0642\u0636\u06cc \u0645\u06cc \u0634\u0648\u062f \u060c \u0645\u0634\u062a\u0631\u06cc \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u06cc\u06a9 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062c\u062f\u06cc\u062f \u060c \u062a\u0648\u06a9\u0646 \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u0631\u0627 \u0628\u0647 \u0627\u06cc\u0646\u062c\u0627 \u0645\u06cc \u0641\u0631\u0633\u062a\u062f.<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-step-4-test-it-out\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87_4_%d8%a2%d9%86_%d8%b1%d8%a7_%d8%a2%d8%b2%d9%85%d8%a7%db%8c%d8%b4_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0645\u0631\u062d\u0644\u0647 4: \u0622\u0646 \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u06af\u0648\u06cc\u06cc\u0645 \u0634\u0645\u0627 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0627 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u062f\u0627\u0631\u06cc\u062f.<\/p>\n<p>\u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u067e\u0633\u062a \u0628\u0631\u0627\u06cc <code>\/api\/token\/<\/code>:<\/p>\n<pre><code class=\"lang-json\">{\n  <span class=\"hljs-attr\">\"username\"<\/span>: <span class=\"hljs-string\">\"your_username\"<\/span>,\n  <span class=\"hljs-attr\">\"password\"<\/span>: <span class=\"hljs-string\">\"your_password\"<\/span>\n}\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0627\u0639\u062a\u0628\u0627\u0631 \u0635\u062d\u06cc\u062d \u0628\u0627\u0634\u062f \u060c \u0686\u06cc\u0632\u06cc \u0645\u0627\u0646\u0646\u062f:<\/p>\n<pre><code class=\"lang-json\">{\n  <span class=\"hljs-attr\">\"refresh\"<\/span>: <span class=\"hljs-string\">\"long_refresh_token\"<\/span>,\n  <span class=\"hljs-attr\">\"access\"<\/span>: <span class=\"hljs-string\">\"short_lived_access_token\"<\/span>\n}\n<\/code><\/pre>\n<p>\u0634\u0645\u0627 \u0627\u0632 <code>access<\/code> \u0646\u0634\u0627\u0646\u0647 \u0627\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0645\u0639\u062a\u0628\u0631. \u0648\u0642\u062a\u06cc \u0645\u0646\u0642\u0636\u06cc \u0634\u062f \u060c \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u062f <code>refresh<\/code> \u0628\u0647 <code>\/api\/token\/refresh\/<\/code> \u0628\u0631\u0627\u06cc \u06af\u0631\u0641\u062a\u0646 \u06cc\u06a9 \u0645\u0648\u0631\u062f \u062c\u062f\u06cc\u062f<\/p>\n<h2 id=\"heading-how-to-use-these-tokens\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%88%d8%b4_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%d8%a7%db%8c%d9%86_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7\"><\/span>\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0634\u0627\u0645\u0644 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0631 <code>Authorization<\/code> \u0647\u062f\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc API \u0634\u0645\u0627 \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"lang-javascript\">Authorization: Bearer your_access_token_here\n<\/code><\/pre>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0645\u0646\u0642\u0636\u06cc \u0645\u06cc \u0634\u0648\u062f \u060c \u0646\u0634\u0627\u0646\u0647 \u062a\u0627\u0632\u0647 \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u062f <code>\/api\/token\/refresh\/<\/code> \u0645\u062b\u0644 \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"lang-json\">{\n  <span class=\"hljs-attr\">\"refresh\"<\/span>: <span class=\"hljs-string\">\"your_refresh_token_here\"<\/span>\n}\n<\/code><\/pre>\n<p>\u0648 \u06cc\u06a9 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062c\u062f\u06cc\u062f \u062f\u0631\u06cc\u0627\u0641\u062a \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f.<\/p>\n<h3 id=\"heading-securing-your-api-views\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d9%85%d9%86_%da%a9%d8%b1%d8%af%d9%86_%d9%86%d9%85%d8%a7%d9%87%d8%a7%db%8c_api_%d8%ae%d9%88%d8%af\"><\/span>\u0627\u06cc\u0645\u0646 \u06a9\u0631\u062f\u0646 \u0646\u0645\u0627\u0647\u0627\u06cc API \u062e\u0648\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0641\u0642\u0637 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u0639\u062a\u0628\u0631 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u062e\u0627\u0635\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0646\u0646\u062f \u060c \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f <code>IsAuthenticated<\/code> \u06a9\u0644\u0627\u0633 \u0627\u062c\u0627\u0632\u0647 \u0628\u0647 \u0646\u0638\u0631\u0627\u062a \u0634\u0645\u0627.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u06cc\u06a9 \u0645\u062b\u0627\u0644 \u0622\u0648\u0631\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-keyword\">from<\/span> rest_framework.permissions <span class=\"hljs-keyword\">import<\/span> IsAuthenticated\n<span class=\"hljs-keyword\">from<\/span> rest_framework.views <span class=\"hljs-keyword\">import<\/span> APIView\n<span class=\"hljs-keyword\">from<\/span> rest_framework.response <span class=\"hljs-keyword\">import<\/span> Response\n\n<span class=\"hljs-class\"><span class=\"hljs-keyword\">class<\/span> <span class=\"hljs-title\">SecureView<\/span>(<span class=\"hljs-params\">APIView<\/span>):<\/span>\n    permission_classes = [IsAuthenticated]\n\n    <span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">get<\/span>(<span class=\"hljs-params\">self, request<\/span>):<\/span>\n        <span class=\"hljs-keyword\">return<\/span> Response({<span class=\"hljs-string\">\"message\"<\/span>: <span class=\"hljs-string\">\"You are authenticated!\"<\/span>})\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u062f\u06cc\u062f\u06af\u0627\u0647 \u0641\u0642\u0637 \u062f\u0631 \u0635\u0648\u0631\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a JWT \u0645\u0639\u062a\u0628\u0631 \u060c \u067e\u0627\u0633\u062e\u06cc \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f. \u0627\u06af\u0631 \u0647\u06cc\u0686 \u0646\u0634\u0627\u0646\u0647 \u0627\u06cc \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f \u06cc\u0627 \u0646\u0627\u0645\u0639\u062a\u0628\u0631 \u0628\u0627\u0634\u062f\/\u0645\u0646\u0642\u0636\u06cc \u0634\u062f\u0647 \u0628\u0627\u0634\u062f \u060c \u06a9\u0627\u0631\u0628\u0631 \u062e\u0637\u0627\u06cc 401 \u063a\u06cc\u0631 \u0645\u062c\u0627\u0632 \u062f\u0627\u0631\u062f.<\/p>\n<h3 id=\"heading-summary\"><span class=\"ez-toc-section\" id=\"%d8%ae%d9%84%d8%a7%d8%b5%d9%87\"><\/span>\u062e\u0644\u0627\u0635\u0647<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06cc\u0646 \u0647\u0645\u0627\u0646 \u06a9\u0627\u0631\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0641\u0642\u0637 \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f\u06cc\u0645:<\/p>\n<ul>\n<li>\n<p>\u0646\u0635\u0628 \u0648 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0634\u062f\u0647 <code>simplejwt<\/code> \u0628\u0631\u0627\u06cc DRF<\/p>\n<\/li>\n<li>\n<p>\u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0646\u0633\u0644 \u0648 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0646\u0645\u0627\u0647\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0628\u0627 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0648\u06a9\u0646.<\/p>\n<\/li>\n<li>\n<p>\u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u0648 \u062a\u0627\u0632\u0647 \u06a9\u0631\u062f\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0648\u06a9\u0646 \u0631\u0627 \u062a\u0648\u0636\u06cc\u062d \u062f\u0627\u062f.<\/p>\n<\/li>\n<\/ul>\n<p>JWT \u0631\u0648\u0634\u06cc \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0648 \u0645\u0642\u06cc\u0627\u0633 \u067e\u0630\u06cc\u0631 \u0628\u0631\u0627\u06cc \u062a\u0623\u0645\u06cc\u0646 API \u0647\u0627\u06cc Django \u0634\u0645\u0627\u0633\u062a. \u0627\u06cc\u0646 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0645\u062f\u0631\u0646 \u0648\u0628 \u0648 \u062a\u0644\u0641\u0646 \u0647\u0645\u0631\u0627\u0647 \u0645\u0646\u0627\u0633\u0628 \u0627\u0633\u062a.<\/p>\n<p>\u0622\u06cc\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u06cc\u06a9 \u0645\u0631\u062d\u0644\u0647 \u062c\u0627\u06cc\u0632\u0647 \u0628\u0631\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u06a9\u0631\u062f\u0646 \u0628\u0627\u0631\u0647\u0627\u06cc \u062a\u0648\u06a9\u0646 (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u060c \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0646\u0642\u0634 \u06a9\u0627\u0631\u0628\u0631 \u06cc\u0627 \u0627\u06cc\u0645\u06cc\u0644 \u0628\u0647 JWT)\u061f \u0628\u0647 \u0645\u0646 \u0627\u0637\u0644\u0627\u0639 \u062f\u0647\u06cc\u062f!<\/p>\n<h2 id=\"heading-faqs\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%aa%d8%af%d8%a7%d9%88%d9%84\"><\/span>\u0645\u062a\u062f\u0627\u0648\u0644<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<h3 id=\"heading-how-long-does-the-token-last\"><span class=\"ez-toc-section\" id=\"%d8%aa%d9%88%da%a9%d9%86_%da%86%d9%87_%d9%85%d8%af%d8%aa_%d8%b7%d9%88%d9%84_%d9%85%db%8c_%da%a9%d8%b4%d8%af%d8%9f\"><\/span><strong>\u062a\u0648\u06a9\u0646 \u0686\u0647 \u0645\u062f\u062a \u0637\u0648\u0644 \u0645\u06cc \u06a9\u0634\u062f\u061f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u060c \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc 5 \u062f\u0642\u06cc\u0642\u0647 \u0637\u0648\u0644 \u0645\u06cc \u06a9\u0634\u062f \u0648 \u0646\u0634\u0627\u0646\u0647 \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc 1 \u0631\u0648\u0632 \u0637\u0648\u0644 \u0645\u06cc \u06a9\u0634\u062f. \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u06cc\u0646 \u0631\u0627 \u062f\u0631 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u062e\u0648\u062f \u0633\u0641\u0627\u0631\u0634\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-keyword\">from<\/span> datetime <span class=\"hljs-keyword\">import<\/span> timedelta\n\nSIMPLE_JWT = {\n    <span class=\"hljs-string\">'ACCESS_TOKEN_LIFETIME'<\/span>: timedelta(minutes=<span class=\"hljs-number\">15<\/span>),\n    <span class=\"hljs-string\">'REFRESH_TOKEN_LIFETIME'<\/span>: timedelta(days=<span class=\"hljs-number\">1<\/span>),\n}\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0628\u0647 \u0645\u0639\u0646\u0627\u06cc \u0627\u06cc\u0646 \u0627\u0633\u062a:<\/p>\n<ul>\n<li>\n<p>\u0627\u06cc\u0646 \u062a\u0627 \u0686\u0647 \u0645\u062f\u062a \u0634\u0645\u0627 \u0631\u0627 \u062a\u0639\u06cc\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f <strong>\u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc JWT<\/strong> \u0622\u062e\u0631:<\/p>\n<ul>\n<li>\n<p><code>ACCESS_TOKEN_LIFETIME<\/code>: \u0686\u0647 \u0645\u062f\u062a \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0645\u0639\u062a\u0628\u0631 \u0627\u0633\u062a (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u060c 15 \u062f\u0642\u06cc\u0642\u0647).<\/p>\n<\/li>\n<li>\n<p><code>REFRESH_TOKEN_LIFETIME<\/code>: \u0686\u0647 \u0645\u062f\u062a \u062a\u0648\u06a9\u0646 \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u0645\u0639\u062a\u0628\u0631 \u0627\u0633\u062a (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u060c 1 \u0631\u0648\u0632).<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<p>\u0686\u0631\u0627 \u0645\u0647\u0645 \u0627\u0633\u062a:<\/p>\n<ul>\n<li>\n<p>\u062f\u0631 <strong>\u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0646\u0634\u0627\u0646\u0647<\/strong> \u0647\u0645\u0627\u0646 \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0628\u0627 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u062a\u0639\u0627\u0645\u0644 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<\/p>\n<\/li>\n<li>\n<p>\u062f\u0631 <strong>\u0646\u0634\u0627\u0646\u0647<\/strong> \u0628\u0631\u0627\u06cc \u0628\u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u06cc\u06a9 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062c\u062f\u06cc\u062f \u0628\u062f\u0648\u0646 \u0648\u0631\u0648\u062f \u062f\u0648\u0628\u0627\u0631\u0647 \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-where-should-i-store-the-token-on-the-frontend\"><span class=\"ez-toc-section\" id=\"%da%a9%d8%ac%d8%a7_%d8%a8%d8%a7%db%8c%d8%af_%d8%aa%d9%88%da%a9%d9%86_%d8%b1%d8%a7_%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%da%a9%d9%86%d9%85_%d8%b1%d9%88%db%8c_%d8%ac%d9%84%d9%88%d8%9f\"><\/span><strong>\u06a9\u062c\u0627 \u0628\u0627\u06cc\u062f \u062a\u0648\u06a9\u0646 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u0645 \u0631\u0648\u06cc \u062c\u0644\u0648\u061f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u062d\u0627\u0644\u062a \u0627\u06cc\u062f\u0647 \u0622\u0644 \u062f\u0631 <code>localStorage<\/code> \u06cc\u0627 <code>sessionStorage<\/code>\u0628\u0634\u0631 \u0641\u0642\u0637 \u0627\u0632 \u062e\u0637\u0631\u0627\u062a XSS \u0622\u06af\u0627\u0647 \u0628\u0627\u0634\u06cc\u062f. \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u0631\u0627 \u062f\u0631 \u062e\u0648\u062f \u0646\u0634\u0627\u0646\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0646\u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc\/Refresh JWT \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u062c\u0628\u0647\u0647 \u062f\u0631:<\/p>\n<ul>\n<li>\n<p><code>localStorage<\/code>: \u062f\u0627\u062f\u0647 \u0647\u0627 \u062d\u062a\u06cc \u067e\u0633 \u0627\u0632 \u0628\u0633\u062a\u0647 \u0634\u062f\u0646 \u0628\u0631\u06af\u0647\/\u0645\u0631\u0648\u0631\u06af\u0631 \u0627\u062f\u0627\u0645\u0647 \u0645\u06cc \u06cc\u0627\u0628\u062f.<\/p>\n<\/li>\n<li>\n<p><code>sessionStorage<\/code>: \u062f\u0627\u062f\u0647 \u0647\u0627 \u0647\u0646\u06af\u0627\u0645 \u0628\u0633\u062a\u0647 \u0634\u062f\u0646 \u0628\u0631\u06af\u0647\/\u0645\u0631\u0648\u0631\u06af\u0631 \u0627\u0632 \u0628\u06cc\u0646 \u0645\u06cc \u0631\u0648\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p>\u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u062f\u0631 \u0646\u0634\u0627\u0646\u0647 \u06cc\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0633\u0627\u0632\u06cc \u0630\u062e\u06cc\u0631\u0647 \u0646\u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u0630\u062e\u06cc\u0631\u0647 \u0634\u062f\u0647 \u062f\u0631 <code>localStorage<\/code> \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062d\u0645\u0644\u0627\u062a XSS \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631 \u0628\u0627\u0634\u062f.<\/p>\n<\/li>\n<li>\n<p>\u062f\u0631 \u0635\u0648\u0631\u062a \u0627\u0645\u06a9\u0627\u0646 \u060c \u0628\u0631\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a \u0628\u0647\u062a\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0648\u06a9\u06cc \u0647\u0627\u06cc httponly \u0631\u0627 \u062f\u0631 \u0646\u0638\u0631 \u0628\u06af\u06cc\u0631\u06cc\u062f (\u0647\u0631\u0686\u0646\u062f \u06a9\u0647 \u067e\u06cc\u0686\u06cc\u062f\u0647 \u062a\u0631 \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0627\u0633\u062a).<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-can-i-add-custom-fields-to-the-token\"><span class=\"ez-toc-section\" id=\"%d8%a2%db%8c%d8%a7_%d9%85%db%8c_%d8%aa%d9%88%d8%a7%d9%86%d9%85_%d8%b2%d9%85%db%8c%d9%86%d9%87_%d9%87%d8%a7%db%8c_%d8%b3%d9%81%d8%a7%d8%b1%d8%b4%db%8c_%d8%b1%d8%a7_%d8%a8%d9%87_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d8%a7%d8%b6%d8%a7%d9%81%d9%87_%da%a9%d9%86%d9%85%d8%9f\"><\/span><strong>\u0622\u06cc\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0632\u0645\u06cc\u0646\u0647 \u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u0631\u0627 \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u0645\u061f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0644\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0646\u0627\u062f\u06cc\u062f\u0647 \u0628\u06af\u06cc\u0631\u06cc\u062f <code>TokenObtainPairSerializer<\/code> \u0628\u0631\u0627\u06cc \u0634\u0627\u0645\u0644 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u062f\u0631 \u0628\u0627\u0631 \u060c \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-keyword\">from<\/span> rest_framework_simplejwt.serializers <span class=\"hljs-keyword\">import<\/span> TokenObtainPairSerializer\n\n<span class=\"hljs-class\"><span class=\"hljs-keyword\">class<\/span> <span class=\"hljs-title\">MyTokenObtainPairSerializer<\/span>(<span class=\"hljs-params\">TokenObtainPairSerializer<\/span>):<\/span>\n<span class=\"hljs-meta\">    @classmethod<\/span>\n    <span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">get_token<\/span>(<span class=\"hljs-params\">cls, user<\/span>):<\/span>\n        token = super().get_token(user)\n        token[<span class=\"hljs-string\">'username'<\/span>] = user.username\n        <span class=\"hljs-keyword\">return<\/span> token\n<\/code><\/pre>\n<p>\u0633\u067e\u0633 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u062e\u0648\u062f \u0633\u06cc\u0645 \u0628\u0632\u0646\u06cc\u062f <code>urls.py<\/code>\u0628\u0634\u0631<\/p>\n<ul>\n<li>\n<p>\u0634\u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0641\u0627\u0631\u0634\u06cc \u06a9\u0631\u062f\u0646 \u0628\u0627\u0631 JWT \u0628\u0631\u0627\u06cc \u0634\u0627\u0645\u0644 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0647\u0633\u062a\u06cc\u062f (\u0645\u0627\u0646\u0646\u062f <code>username<\/code>).<\/p>\n<\/li>\n<li>\n<p>\u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0648\u0642\u062a\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0648\u0627\u0631\u062f \u0633\u06cc\u0633\u062a\u0645 \u0645\u06cc \u0634\u0648\u062f \u060c JWT \u0627\u06a9\u0646\u0648\u0646 \u062d\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f <code>username<\/code> \u062f\u0631 \u062f\u0627\u062e\u0644 \u0628\u0627\u0631.<\/p>\n<\/li>\n<li>\n<p>\u0627\u06af\u0631 \u062c\u0644\u0648\u06cc \u0634\u0645\u0627 \u0628\u062e\u0648\u0627\u0647\u062f \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u062f\u0648\u0646 \u0628\u0631\u0642\u0631\u0627\u0631\u06cc \u062a\u0645\u0627\u0633 API \u062f\u06cc\u06af\u0631 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0647\u062f \u060c \u0645\u0641\u06cc\u062f \u0627\u0633\u062a.<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-summary-1\"><span class=\"ez-toc-section\" id=\"%d8%ae%d9%84%d8%a7%d8%b5%d9%87-2\"><\/span>\u062e\u0644\u0627\u0635\u0647:<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<div class=\"hn-table\">\n<table>\n<thead>\n<tr>\n<td><strong>\u0642\u0633\u0645\u062a<\/strong><\/td>\n<td><strong>\u0647\u062f\u0641<\/strong><\/td>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>SIMPLE_JWT<\/code>  \u062a\u0646\u0638\u06cc\u0645\u0627\u062a<\/td>\n<td>\u0627\u0646\u0642\u0636\u0627 \u0631\u0627 \u06a9\u0646\u062a\u0631\u0644 \u0645\u06cc \u06a9\u0646\u062f<\/td>\n<\/tr>\n<tr>\n<td><code>localStorage\/sessionStorage<\/code><\/td>\n<td>\u0627\u0632 \u06a9\u062c\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0631\u062f \u0631\u0648\u06cc \u062c\u0628\u0647\u0647<\/td>\n<\/tr>\n<tr>\n<td>\u0633\u0631\u06cc\u0627\u0644 \u06a9\u0646\u0646\u062f\u0647 \u062a\u0648\u06a9\u0646 \u0633\u0641\u0627\u0631\u0634\u06cc<\/td>\n<td>\u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0636\u0627\u0641\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0647 \u062a\u0648\u06a9\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u060c \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc)<\/td>\n<\/tr>\n<tr>\n<td><code>urls.py<\/code>  \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc<\/td>\n<td>\u0646\u0645\u0627\u06cc \u062a\u0648\u06a9\u0646 \u0633\u0641\u0627\u0631\u0634\u06cc \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0645\u062a\u0635\u0644 \u0645\u06cc \u06a9\u0646\u062f<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<h2 id=\"heading-best-practices\"><span class=\"ez-toc-section\" id=\"%d8%a8%d9%87%d8%aa%d8%b1%db%8c%d9%86_%d8%b1%d9%88%d8%b4%d9%87%d8%a7\"><\/span>\u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062d\u0627\u0644 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0647 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627\u06cc DRF \u0646\u06af\u0627\u0647 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0637\u0648\u0631 \u0645\u0648\u062b\u0631\u06cc \u0627\u0632 \u0627\u06cc\u0646 \u0686\u0627\u0631\u0686\u0648\u0628 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<h3 id=\"heading-1-use-https-always\"><span class=\"ez-toc-section\" id=\"1_%d9%87%d9%85%db%8c%d8%b4%d9%87_%d8%a7%d8%b2_https_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\"><\/span>1 <strong>\u0647\u0645\u06cc\u0634\u0647 \u0627\u0632 https \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>HTTPS \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u0646\u062a\u0642\u0644 \u0634\u062f\u0647 \u0628\u06cc\u0646 \u0645\u0634\u062a\u0631\u06cc (\u0645\u0631\u0648\u0631\u06af\u0631 \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647) \u0648 \u0633\u0631\u0648\u0631 \u0631\u0627 \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06af\u0631 \u0628\u0647 \u062c\u0627\u06cc \u0622\u0646 \u0627\u0632 http \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u060c \u0647\u0631 \u06a9\u0633\u06cc \u0631\u0648\u06cc \u0647\u0645\u0627\u0646 \u0634\u0628\u06a9\u0647 (\u0645\u0627\u0646\u0646\u062f Wi-Fi \u0639\u0645\u0648\u0645\u06cc) \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0631\u0648\u0634\u06cc \u0628\u0647 \u0646\u0627\u0645 \u062d\u0645\u0644\u0627\u062a Man-in-the-Mdle (MITM) \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633-\u0627\u0632 \u062c\u0645\u0644\u0647 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc-\u0631\u0627 \u0631\u0647\u06af\u06cc\u0631\u06cc \u06a9\u0646\u062f.<\/p>\n<h4 id=\"heading-best-practices-1\">\u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627:<\/h4>\n<ul>\n<li>\n<p>\u0628\u0631\u0627\u06cc \u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 HTTPS \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0627\u0632 \u06cc\u06a9 \u06af\u0648\u0627\u0647\u06cc SSL \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u062a\u0645\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc HTTP \u0631\u0627 \u0628\u0647 HTTPS \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc HTTPS \u0627\u0632 \u0647\u062f\u0631 HSTS (HTTP Security Transport Security) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0637\u0631\u0641 \u0645\u0634\u062a\u0631\u06cc<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-2-dont-store-sensitive-data-in-the-token\"><span class=\"ez-toc-section\" id=\"2_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7%db%8c_%d8%ad%d8%b3%d8%a7%d8%b3_%d8%b1%d8%a7_%d8%af%d8%b1_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%d9%86%da%a9%d9%86%db%8c%d8%af\"><\/span>2 <strong>\u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u0631\u0627 \u062f\u0631 \u0646\u0634\u0627\u0646\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0646\u06a9\u0646\u06cc\u062f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0646\u0634\u0627\u0646\u0647 \u0647\u0627 \u0645\u0627\u0646\u0646\u062f <strong>jwts<\/strong> \u063a\u0627\u0644\u0628\u0627\u064b \u062f\u0631 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f (\u062f\u0631 \u0645\u062d\u0644\u06cc \u060c SessionStorage \u06cc\u0627 \u06a9\u0648\u06a9\u06cc \u0647\u0627).<\/p>\n<p>\u0627\u06af\u0631 \u0622\u0646\u0647\u0627 \u062d\u0627\u0648\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u0628\u0627\u0634\u0646\u062f (\u0645\u0627\u0646\u0646\u062f \u0631\u0645\u0632\u0647\u0627\u06cc \u0639\u0628\u0648\u0631 \u060c \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0634\u062e\u0635\u06cc \u06cc\u0627 \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc \u0645\u062e\u0641\u06cc) \u060c \u0622\u0646\u0647\u0627 \u0628\u0647 \u06cc\u06a9 \u062e\u0637\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0628\u0632\u0631\u06af \u062a\u0628\u062f\u06cc\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f &#8211; \u0628\u0647 \u062e\u0635\u0648\u0635 \u0627\u06af\u0631 \u0628\u0647 \u0633\u0631\u0642\u062a \u0631\u0641\u062a\u0647 \u06cc\u0627 \u0628\u0647 \u062e\u0637\u0631 \u0628\u06cc\u0627\u06cc\u0646\u062f.<\/p>\n<h4 id=\"heading-what-to-do-instead\">\u062f\u0631 \u0639\u0648\u0636 \u0686\u0647 \u06a9\u0627\u0631\u06cc \u0628\u0627\u06cc\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645:<\/h4>\n<ul>\n<li>\n<p>\u0641\u0642\u0637 \u062d\u062f\u0627\u0642\u0644 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 (\u0645\u0627\u0646\u0646\u062f \u0634\u0646\u0627\u0633\u0647 \u06a9\u0627\u0631\u0628\u0631 \u06cc\u0627 \u0646\u0642\u0634) \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0627\u0632 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u0645\u0627\u062a (\u0631\u0634\u062a\u0647 \u0647\u0627\u06cc \u062a\u0635\u0627\u062f\u0641\u06cc) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0635\u0648\u0631\u062a \u0627\u0645\u06a9\u0627\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062a\u0639\u0628\u06cc\u0647 \u0634\u062f\u0647 \u0631\u0627 \u062d\u0645\u0644 \u0646\u0645\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p>\u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u0631\u0627 \u0627\u06cc\u0645\u0646 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0633\u0631\u0648\u0631 \u060c \u0646\u0647 \u062f\u0631 \u0646\u0634\u0627\u0646\u0647.<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-3-keep-your-signing-key-secret\"><span class=\"ez-toc-section\" id=\"3_%da%a9%d9%84%db%8c%d8%af_%d8%a7%d9%85%d8%b6%d8%a7%db%8c_%d8%ae%d9%88%d8%af_%d8%b1%d8%a7_%d9%85%d8%ae%d9%81%db%8c_%d9%86%da%af%d9%87_%d8%af%d8%a7%d8%b1%db%8c%d8%af\"><\/span>3 <strong>\u06a9\u0644\u06cc\u062f \u0627\u0645\u0636\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0645\u062e\u0641\u06cc \u0646\u06af\u0647 \u062f\u0627\u0631\u06cc\u062f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<h4 id=\"heading-whats-a-signing-key\">\u06a9\u0644\u06cc\u062f \u0627\u0645\u0636\u0627\u06cc \u0686\u06cc\u0633\u062a\u061f<\/h4>\n<p>\u062f\u0631 \u0633\u06cc\u0633\u062a\u0645 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0632 JWTS \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f \u060c \u0627\u0632 \u06a9\u0644\u06cc\u062f \u0627\u0645\u0636\u0627\u06cc (\u06cc\u0627 \u06a9\u0644\u06cc\u062f \u0645\u062e\u0641\u06cc) \u0628\u0631\u0627\u06cc \u0627\u0645\u0636\u0627\u06cc \u0646\u0634\u0627\u0646\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f &#8211; \u06cc\u06a9 \u0631\u0648\u0634 \u0631\u0645\u0632\u0646\u06af\u0627\u0631\u06cc \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u06cc\u0646 \u06a9\u0647 \u0627\u06cc\u0646 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u06a9\u0627\u0631\u06cc \u0646\u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06af\u0631 \u06a9\u0633\u06cc \u06a9\u0644\u06cc\u062f \u0627\u0645\u0636\u0627\u06cc \u0634\u0645\u0627 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u062f \u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u0645\u0639\u062a\u0628\u0631 \u0628\u0647 \u0646\u0638\u0631 \u0628\u0631\u0633\u062f \u0648 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0631\u0627 \u062c\u0639\u0644 \u06a9\u0646\u062f.<\/p>\n<h4 id=\"heading-best-practices-2\">\u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627:<\/h4>\n<ul>\n<li>\n<p>\u06a9\u0644\u06cc\u062f \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u0645\u062d\u06cc\u0637 \u0647\u0627\u06cc \u0627\u0645\u0646 (\u0645\u0627\u0646\u0646\u062f \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u06cc\u0637 \u060c \u0645\u062f\u06cc\u0631\u0627\u0646 \u0645\u062e\u0641\u06cc) \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0647\u0631\u06af\u0632 \u06a9\u0644\u06cc\u062f \u06a9\u0646\u062a\u0631\u0644 \u0645\u0646\u0628\u0639 \u0631\u0627 \u0645\u0631\u062a\u06a9\u0628 \u0646\u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0627\u0632 \u0627\u0633\u0631\u0627\u0631 \u0642\u0648\u06cc \u0648 \u0628\u0647 \u0637\u0648\u0631 \u062a\u0635\u0627\u062f\u0641\u06cc \u062a\u0648\u0644\u06cc\u062f \u0634\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0628\u0631\u0627\u06cc \u0645\u0642\u06cc\u0627\u0633 \u067e\u0630\u06cc\u0631\u06cc \u0648 \u0627\u0645\u0646\u06cc\u062a \u0628\u0647\u062a\u0631 (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u060c \u0628\u0627 \u0627\u0644\u06af\u0648\u0631\u06cc\u062a\u0645 Rs256) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc \u0646\u0627\u0645\u062a\u0642\u0627\u0631\u0646 (\u062c\u0641\u062a \u0647\u0627\u06cc \u06a9\u0644\u06cc\u062f \u0639\u0645\u0648\u0645\u06cc\/\u062e\u0635\u0648\u0635\u06cc) \u0631\u0627 \u062f\u0631 \u0646\u0638\u0631 \u0628\u06af\u06cc\u0631\u06cc\u062f.<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-4-rotate-tokens-if-needed\"><span class=\"ez-toc-section\" id=\"4_%d8%af%d8%b1_%d8%b5%d9%88%d8%b1%d8%aa_%d9%84%d8%b2%d9%88%d9%85_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7_%d8%b1%d8%a7_%d8%a8%da%86%d8%b1%d8%ae%d8%a7%d9%86%db%8c%d8%af\"><\/span>4 <strong>\u062f\u0631 \u0635\u0648\u0631\u062a \u0644\u0632\u0648\u0645 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627 \u0631\u0627 \u0628\u0686\u0631\u062e\u0627\u0646\u06cc\u062f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<h4 id=\"heading-what-is-token-rotation\">\u0686\u0631\u062e\u0634 \u0646\u0634\u0627\u0646\u0647 \u0686\u06cc\u0633\u062a\u061f<\/h4>\n<p>\u0686\u0631\u062e\u0634 \u062a\u0648\u06a9\u0646 \u0628\u0647 process \u0627\u0632 \u062a\u0648\u0644\u06cc\u062f \u062f\u0648\u0631\u0647 \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f \u0648 \u0628\u06cc \u0627\u0639\u062a\u0628\u0627\u0631 \u06a9\u0631\u062f\u0646 \u0645\u0648\u0627\u0631\u062f \u0642\u062f\u06cc\u0645\u06cc.<\/p>\n<p>\u0627\u06cc\u0646 \u0645\u0647\u0645 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0627\u06af\u0631 \u06cc\u06a9 \u0646\u0634\u0627\u0646\u0647 \u0628\u0647 \u0633\u0631\u0642\u062a \u0631\u0641\u062a\u0647 \u06cc\u0627 \u062f\u0631\u0632 \u0634\u0648\u062f \u060c \u0686\u0631\u062e\u0627\u0646\u062f\u0646 \u0622\u0646 \u0628\u0647 \u0637\u0648\u0631 \u0645\u0631\u062a\u0628 \u067e\u0646\u062c\u0631\u0647 \u0627\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0645\u0647\u0627\u062c\u0645 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f \u060c \u0645\u062d\u062f\u0648\u062f \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u0627\u0645\u0631 \u0628\u0647 \u0648\u06cc\u0698\u0647 \u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u060c \u06a9\u0647 \u062a\u0645\u0627\u06cc\u0644 \u0628\u0647 \u0632\u0646\u062f\u06af\u06cc \u0637\u0648\u0644\u0627\u0646\u06cc \u062a\u0631 \u062f\u0627\u0631\u0646\u062f \u060c \u0645\u0647\u0645 \u0627\u0633\u062a.<\/p>\n<h4 id=\"heading-best-practices-3\">\u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627:<\/h4>\n<ul>\n<li>\n<p>\u0627\u0632 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u06a9\u0648\u062a\u0627\u0647 \u0645\u062f\u062a \u0648 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u0637\u0648\u0644\u0627\u0646\u06cc \u0645\u062f\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u067e\u0633 \u0627\u0632 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646\u0647\u0627 \u060c \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u0631\u0627 \u0628\u0627\u0637\u0644 \u06a9\u0646\u06cc\u062f (\u0639\u0645\u0644\u06cc \u0628\u0647 \u0646\u0627\u0645 &#8220;\u0686\u0631\u062e\u0634 \u062a\u0648\u06a9\u0646 \u062a\u0627\u0632\u0647&#8221;).<\/p>\n<\/li>\n<li>\n<p>Track \u0628\u0631\u0627\u06cc \u062a\u0634\u062e\u06cc\u0635 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u06cc\u0627 \u0633\u0631\u0642\u062a \u060c TREAKESS TOKENS SORE SORE SORE \u0631\u0627 \u0635\u0627\u062f\u0631 \u06a9\u0631\u062f.<\/p>\n<\/li>\n<\/ul>\n<h3 id=\"heading-5-set-a-short-lifetime-for-access-tokens-amp-use-refresh-tokens-wisely\"><span class=\"ez-toc-section\" id=\"5_%db%8c%da%a9_%d8%b9%d9%85%d8%b1_%da%a9%d9%88%d8%aa%d8%a7%d9%87_%d8%a8%d8%b1%d8%a7%db%8c_%d8%af%d8%b3%d8%aa%d8%b1%d8%b3%db%8c_%d8%a8%d9%87_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7%db%8c_%d8%af%d8%b3%d8%aa%d8%b1%d8%b3%db%8c_%d8%aa%d9%86%d8%b8%db%8c%d9%85_%da%a9%d9%86%db%8c%d8%af_%d9%88_%d8%a7%d8%b2_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%d9%87%d8%a7%db%8c_%d8%aa%d8%a7%d8%b2%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%b9%d8%a7%d9%82%d9%84%d8%a7%d9%86%d9%87_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%da%a9%d9%86%db%8c%d8%af\"><\/span>5 <strong>\u06cc\u06a9 \u0639\u0645\u0631 \u06a9\u0648\u062a\u0627\u0647 \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f \u0648 \u0627\u0632 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u0639\u0627\u0642\u0644\u0627\u0646\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f<\/strong><span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627 \u0627\u062c\u0627\u0632\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0645\u0646\u0627\u0628\u0639 \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0631\u0627 \u0627\u0639\u0637\u0627 \u0645\u06cc \u06a9\u0646\u062f. \u062f\u0631 \u0635\u0648\u0631\u062a \u0633\u0631\u0642\u062a \u060c \u0645\u06cc \u062a\u0648\u0627\u0646 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062a\u0627 \u0632\u0645\u0627\u0646 \u0627\u0646\u0642\u0636\u0627 \u062a\u0648\u0633\u0637 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f.<\/p>\n<h4 id=\"heading-best-practices-4\">\u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0648\u0634\u0647\u0627:<\/h4>\n<ul>\n<li>\n<p>\u0628\u0647 \u0633\u0631\u0639\u062a \u0645\u0646\u0642\u0636\u06cc \u0634\u062f\u0647 \u062a\u0627 \u0628\u0647 \u0633\u0631\u0639\u062a \u0645\u0646\u0642\u0636\u06cc \u0634\u0648\u06cc\u062f (5-15 \u062f\u0642\u06cc\u0642\u0647 \u0631\u0627\u06cc\u062c \u0627\u0633\u062a).<\/p>\n<\/li>\n<li>\n<p>\u0627\u0632 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc Refresh \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0628\u0647 \u0645\u0634\u062a\u0631\u06cc \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u062a\u0627 \u0628\u062f\u0648\u0646 \u0648\u0631\u0648\u062f \u0645\u062c\u062f\u062f \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u062c\u062f\u06cc\u062f \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647 \u0633\u0627\u0632\u06cc \u0631\u0627 \u0628\u0627 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f (\u06a9\u0648\u06a9\u06cc \u0647\u0627\u06cc \u0641\u0642\u0637 HTTP \u0631\u0627 \u062a\u0631\u062c\u06cc\u062d \u062f\u0647\u06cc\u062f).<\/p>\n<\/li>\n<li>\n<p>\u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647 \u06a9\u0631\u062f\u0646 \u0631\u0648\u06cc \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u060c \u0641\u0639\u0627\u0644\u06cc\u062a \u0645\u0634\u06a9\u0648\u06a9 \u06cc\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0633\u062a\u06af\u0627\u0647.<\/p>\n<\/li>\n<\/ul>\n<h2 id=\"heading-final-thoughts\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%81%da%a9%d8%a7%d8%b1_%d9%86%d9%87%d8%a7%db%8c%db%8c\"><\/span>\u0627\u0641\u06a9\u0627\u0631 \u0646\u0647\u0627\u06cc\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<ul>\n<li>\n<p><strong>\u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u0647\u0627<\/strong> \u0628\u0627\u06cc\u062f \u06a9\u0648\u062a\u0627\u0647 \u0645\u062f\u062a \u0648 \u0645\u062d\u062f\u0648\u062f \u0628\u0627\u0634\u062f.<\/p>\n<\/li>\n<li>\n<p><strong>\u0646\u0634\u0627\u0646\u0647 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647<\/strong> \u0628\u0627\u06cc\u062f \u0637\u0648\u0644\u0627\u0646\u06cc \u0645\u062f\u062a \u0628\u0627\u0634\u062f \u0627\u0645\u0627 \u0686\u0631\u062e\u0634\u06cc \u0648 \u0628\u0627 \u062f\u0642\u062a \u0627\u0628\u0637\u0627\u0644 \u0634\u0648\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0647\u0645\u06cc\u0634\u0647 \u0627\u0633\u0631\u0627\u0631 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u0627\u06cc\u0645\u0646 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f \u060c \u0627\u0632 \u0637\u0631\u06cc\u0642 HTTPS \u062e\u062f\u0645\u062a \u06a9\u0646\u06cc\u062f \u0648 \u0627\u0632 \u0627\u0639\u062a\u0645\u0627\u062f \u0628\u0647 \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u0645\u0646\u0637\u0642 \u06cc\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u062e\u0648\u062f\u062f\u0627\u0631\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<\/ul>\n<p>\u0622\u06cc\u0627 \u062f\u0648\u0633\u062a \u062f\u0627\u0631\u06cc\u062f \u0646\u0634\u0627\u0646 \u062f\u0647\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0627\u06cc\u0646 \u0647\u0645\u0647 \u062f\u0631 \u06cc\u06a9 \u0645\u062b\u0627\u0644 \u0628\u0647 \u0647\u0645 \u067e\u06cc\u0648\u0646\u062f \u0645\u06cc \u062e\u0648\u0631\u062f (\u0645\u0627\u0646\u0646\u062f \u0631\u0648\u0634 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u060c \u0635\u062f\u0648\u0631 \u062a\u0648\u06a9\u0646 \u0648 \u062a\u0627\u0632\u0647 \u06a9\u0631\u062f\u0646)\u061f<\/p>\n<p>JWT \u0647\u0627 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0631\u0627 \u0628\u0631\u0627\u06cc API \u0647\u0627 \u0622\u0633\u0627\u0646 \u062a\u0631 \u0648 \u0645\u0642\u06cc\u0627\u0633 \u067e\u0630\u06cc\u0631 \u062a\u0631 \u0645\u06cc \u06a9\u0646\u0646\u062f. \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 Django REST \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f\u06cc\u062f \u060c \u0641\u0642\u0637 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f &#8211; \u0648 \u0634\u0645\u0627 \u06cc\u06a9 \u0631\u0627\u0647 \u0645\u0637\u0645\u0626\u0646 \u0628\u0631\u0627\u06cc \u0627\u062c\u0627\u0632\u0647 \u062f\u0627\u062f\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0648 \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 \u062a\u0631\u0627\u0641\u06cc\u06a9 \u0646\u0627\u062e\u0648\u0627\u0633\u062a\u0647 \u062f\u0627\u0631\u06cc\u062f.<\/p>\n<p>\u0627\u06af\u0631 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 API \u0628\u0627 Django \u0647\u0633\u062a\u06cc\u062f \u060c \u0627\u06cc\u0646 \u06cc\u06a9 \u0686\u06cc\u0632 \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a.<\/p>\n<h3 id=\"heading-further-reading-and-resources\"><span class=\"ez-toc-section\" id=\"%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86_%d9%88_%d9%85%d9%86%d8%a7%d8%a8%d8%b9_%d8%a8%db%8c%d8%b4%d8%aa%d8%b1\"><\/span>\u062e\u0648\u0627\u0646\u062f\u0646 \u0648 \u0645\u0646\u0627\u0628\u0639 \u0628\u06cc\u0634\u062a\u0631<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<ul>\n<li>\n<p>\u0633\u0627\u062f\u0647 jwt Documentation<\/p>\n<\/li>\n<li>\n<p>\u0627\u0633\u0646\u0627\u062f \u0631\u0633\u0645\u06cc DRF<\/p>\n<\/li>\n<li>\n<p>JWT.IO &#8211; \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0627\u0634\u06a9\u0627\u0644 \u0632\u062f\u0627\u06cc\u06cc \u0648 \u06cc\u0627\u062f\u06af\u06cc\u0631\u06cc \u0631\u0648\u0634 \u06a9\u0627\u0631 JWT.<\/p>\n<\/li>\n<li>\n<p>\u0628\u0631\u06af\u0647 \u062a\u0642\u0644\u0628 OWASP \u0631\u0648\u06cc jwt<\/p>\n<\/li>\n<\/ul>\n<\/section>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1404-04-17 01:59:08<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;18917&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;\u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u062a\u0648\u06a9\u0646 \u0648\u0628 JSON \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 REST Django&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>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 API \u0647\u0633\u062a\u06cc\u062f \u060c \u0627\u0645\u0646\u06cc\u062a \u0628\u0627\u06cc\u062f \u062f\u0631 \u0635\u062f\u0631 \u0644\u06cc\u0633\u062a \u0634\u0645\u0627 \u0628\u0627\u0634\u062f. \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0641\u0642\u0637 \u0627\u0641\u0631\u0627\u062f \u0645\u0646\u0627\u0633\u0628 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0645\u0648\u0627\u0631\u062f \u0645\u0646\u0627\u0633\u0628 \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0646\u0646\u062f &#8211; \u0648 \u0627\u06cc\u0646\u062c\u0627\u0633\u062a \u06a9\u0647 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0648\u0627\u0631\u062f \u0645\u06cc \u0634\u0648\u062f. \u06cc\u06a9\u06cc \u0627\u0632 \u0645\u062a\u062f\u0627\u0648\u0644 \u062a\u0631\u06cc\u0646 \u0648 \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f \u062a\u0631\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062a\u0623\u06cc\u06cc\u062f [&hellip;]<\/p>\n","protected":false},"author":6,"featured_media":18918,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1743],"tags":[3064,3608,2719,1748,1747,1938,1926,1919,1936,2126,3653,2750,2123,1918,2829,1813],"class_list":["post-18917","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-python","tag-django","tag-rest","tag-json","tag-python-hosting","tag-python-vps","tag-1938","tag-1926","tag----python","tag-1936","tag-2126","tag-3653","tag-2750","tag-2123","tag-1918","tag-2829","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/18917","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=18917"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/18917\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/18918"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=18917"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=18917"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=18917"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}