{"id":17271,"date":"2024-04-18T05:07:13","date_gmt":"2024-04-18T01:37:13","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%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%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/"},"modified":"2024-04-18T05:07:13","modified_gmt":"2024-04-18T01:37:13","slug":"%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%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%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%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/","title":{"rendered":"\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc \u0648\u0628 JSON \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u0645\u0646 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0641\u0644\u0627\u0633\u06a9"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d8%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#%d9%be%db%8c%d8%b4_%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\" >\u067e\u06cc\u0634 \u0646\u06cc\u0627\u0632\u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d8%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#%d8%aa%d9%88%da%a9%d9%86_%d9%88%d8%a8_json_%da%86%db%8c%d8%b3%d8%aa%d8%9f\" >\u062a\u0648\u06a9\u0646 \u0648\u0628 JSON \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%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d8%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#jwt_%d9%87%d8%a7_%da%86%da%af%d9%88%d9%86%d9%87_%da%a9%d8%a7%d8%b1_%d9%85%db%8c_%da%a9%d9%86%d9%86%d8%af%d8%9f\" >JWT \u0647\u0627 \u0686\u06af\u0648\u0646\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u0646\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%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d8%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#%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%aa%d9%88%da%a9%d9%86_%d9%87%d8%a7%db%8c_%d9%88%d8%a8_json_%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_%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87_%d9%87%d8%a7%db%8c_flask\" >\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc \u0648\u0628 JSON \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc Flask<\/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%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d8%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#1_%d9%88%d8%a7%d8%a8%d8%b3%d8%aa%da%af%db%8c_%d9%87%d8%a7_%d8%b1%d8%a7_%d9%86%d8%b5%d8%a8_%da%a9%d9%86%db%8c%d8%af\" >1. \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \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%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d8%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#2_%db%8c%da%a9_%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87_%d8%af%d8%a7%d8%af%d9%87_%d9%88_user_model_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\" >2. \u06cc\u06a9 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0648 User Model \u0627\u06cc\u062c\u0627\u062f \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%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-%d8%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#3_%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87_%d8%b1%d8%a7_%d8%a8%d8%b1%d8%a7%db%8c_jwt_authentication_%d9%be%db%8c%da%a9%d8%b1%d8%a8%d9%86%d8%af%db%8c_%da%a9%d9%86%db%8c%d8%af\" >3. \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0631\u0627\u06cc JWT Authentication \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\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-8\" href=\"https:\/\/rasanegaar.com\/blog\/%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%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#4_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%85%d8%ad%d8%a7%d9%81%d8%b8%d8%aa_%d8%b4%d8%af%d9%87_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\" >4. \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \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-9\" href=\"https:\/\/rasanegaar.com\/blog\/%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%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%d9%87\/#5_%db%8c%da%a9_%d8%b5%d9%81%d8%ad%d9%87_%d9%88%d8%b1%d9%88%d8%af_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\" >5. \u06cc\u06a9 \u0635\u0641\u062d\u0647 \u0648\u0631\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \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-10\" href=\"https:\/\/rasanegaar.com\/blog\/%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%aa%d9%88%da%a9%d9%86-%d9%87%d8%a7%db%8c-%d9%88%d8%a8-json-%d8%a8%d8%b1%d8%a7%db%8c-%d8%a7%d8%ad%d8%b1%d8%a7%d8%b2-%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>\u06af\u0630\u0631\u0648\u0627\u0698\u0647\u200c\u0647\u0627\u060c \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u06a9\u0627\u0631\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u06cc\u060c \u0634\u0645\u0627\u0631\u0647\u200c\u0647\u0627\u06cc \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0634\u062e\u0635\u06cc (PIN) &#8211; \u0627\u06cc\u0646\u0647\u0627 \u0647\u0645\u0647 \u062f\u0627\u0631\u0627\u06cc\u06cc\u200c\u0647\u0627\u06cc \u062d\u06cc\u0627\u062a\u06cc \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0645\u062c\u0648\u0632 \u0648 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f.  \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0622\u0646\u0647\u0627 \u0628\u0627\u06cc\u062f \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u063a\u06cc\u0631\u0645\u062c\u0627\u0632 \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u0648\u0646\u062f.<\/p>\n<p>\u0645\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0648\u0638\u06cc\u0641\u0647 \u062f\u0627\u0631\u06cc\u0645 \u0627\u0632 \u0627\u06cc\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633 \u0645\u062d\u0627\u0641\u0638\u062a \u06a9\u0646\u06cc\u0645 \u0648 \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u06cc\u0645\u0646 \u0642\u0648\u06cc \u0631\u0627 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u062e\u0648\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645. <\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646\u060c \u0645\u06a9\u0627\u0646\u06cc\u0633\u0645\u200c\u0647\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0628\u0633\u06cc\u0627\u0631\u06cc \u0645\u0627\u0646\u0646\u062f OAuth\u060c OpenID Connect \u0648 JSON Web Tokens (JWT) \u0628\u0631\u0627\u06cc \u0627\u06cc\u0645\u0646 \u06a9\u0631\u062f\u0646 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0647\u0633\u062a\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 JWT \u0647\u0627 \u0631\u0627 \u0647\u0646\u06af\u0627\u0645 \u0627\u06cc\u0645\u0646 \u0633\u0627\u0632\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062f\u0631 API \u0628\u0627 \u0627\u062f\u063a\u0627\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 JWT \u062f\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u0628\u0647 \u0634\u0645\u0627 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f. <\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u067e\u0648\u0634\u0634 \u062e\u0648\u0627\u0647\u062f \u062f\u0627\u062f:<\/p>\n<ul>\n<li>\u062a\u0648\u06a9\u0646 \u0648\u0628 JSON \u0686\u06cc\u0633\u062a\u061f<\/li>\n<li>JWT \u0647\u0627 \u0686\u06af\u0648\u0646\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u0646\u062f\u061f<\/li>\n<li>\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc \u0648\u0628 JSON \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc Flask<br \/>1. \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<br \/>2. \u06cc\u06a9 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0648 \u0645\u062f\u0644 \u06a9\u0627\u0631\u0628\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<br \/>3. \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a JWT \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f<br \/>4. \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<br \/>5. \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u0648\u0631\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<\/li>\n<li>\u0646\u062a\u06cc\u062c\u0647<\/li>\n<\/ul>\n<h2 id=\"prerequisites\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%b4_%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\"><\/span>\u067e\u06cc\u0634 \u0646\u06cc\u0627\u0632\u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0631\u0627\u06cc \u062f\u0646\u0628\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0628\u0647 \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f:<\/p>\n<ul>\n<li>\u0622\u0634\u0646\u0627\u06cc\u06cc \u0628\u0627 \u0631\u0648\u0634 \u0647\u0627\u06cc HTTP<\/li>\n<li>\u062f\u0631\u06a9 \u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f API \u062f\u0631 Flask<\/li>\n<li>VS Code  \u0648\u06cc\u0631\u0627\u06cc\u0634\u06af\u0631 (\u06cc\u0627 \u0645\u0634\u0627\u0628\u0647 \u062f\u06cc\u06af\u0631).<\/li>\n<li>\u0622 terminal<\/li>\n<\/ul>\n<h2 id=\"what-is-a-json-web-token\"><span class=\"ez-toc-section\" id=\"%d8%aa%d9%88%da%a9%d9%86_%d9%88%d8%a8_json_%da%86%db%8c%d8%b3%d8%aa%d8%9f\"><\/span>\u062a\u0648\u06a9\u0646 \u0648\u0628 JSON \u0686\u06cc\u0633\u062a\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>JSON Web Tokens \u06cc\u0627 JWTs \u06cc\u06a9 \u0645\u06a9\u0627\u0646\u06cc\u0633\u0645 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0642\u0627\u0644 \u0627\u0645\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0646 \u06cc\u06a9 \u06a9\u0644\u0627\u06cc\u0646\u062a \u0648 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u062f\u0631 \u0642\u0627\u0644\u0628 JSON \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. <\/p>\n<p>\u0627\u06cc\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u062a\u0623\u06cc\u06cc\u062f \u0648 \u0627\u0639\u062a\u0645\u0627\u062f \u06a9\u0631\u062f \u0632\u06cc\u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u062f\u06cc\u062c\u06cc\u062a\u0627\u0644\u06cc \u0628\u0627 \u0627\u0644\u06af\u0648\u0631\u06cc\u062a\u0645 HMAC \u06cc\u0627 \u06cc\u06a9 \u062c\u0641\u062a \u06a9\u0644\u06cc\u062f \u0639\u0645\u0648\u0645\u06cc\/\u062e\u0635\u0648\u0635\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 RSA \u06cc\u0627 ECDSA \u0627\u0645\u0636\u0627 \u0634\u062f\u0647 \u0627\u0633\u062a. <\/p>\n<p>\u062a\u0648\u06a9\u0646 \u0647\u0627 \u0628\u0647 \u0633\u0647 \u0642\u0633\u0645\u062a \u06a9\u062f\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f \u06a9\u0647 \u0647\u0631 \u06a9\u062f\u0627\u0645 \u0628\u0627 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u062a\u0642\u0633\u06cc\u0645 \u0645\u06cc \u0634\u0648\u0646\u062f\u060c \u0645\u0627\u0646\u0646\u062f \u0632\u06cc\u0631:<\/p>\n<pre><code>Header.Payload.Signature\n<\/code><\/pre>\n<ul>\n<li><strong>\u0633\u0631\u062a\u06cc\u062a\u0631:<\/strong> \u0627\u06cc\u0646 \u0646\u0648\u0639 \u062a\u0648\u06a9\u0646 (JWT) \u0648 \u0627\u0644\u06af\u0648\u0631\u06cc\u062a\u0645 \u0627\u0645\u0636\u0627\u06cc \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0631\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li><strong>\u0638\u0631\u0641\u06cc\u062a \u062a\u0631\u0627\u0628\u0631\u06cc:<\/strong> \u0627\u06cc\u0646 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u062e\u0627\u0635 \u06a9\u0627\u0631\u0628\u0631 \u0645\u0627\u0646\u0646\u062f \u0634\u0646\u0627\u0633\u0647 \u06a9\u0627\u0631\u0628\u0631\u060c \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc\u060c \u0646\u0642\u0634\u200c\u0647\u0627\u060c \u0648 \u0647\u0631\u06af\u0648\u0646\u0647 \u0627\u062f\u0639\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u0631\u0627 \u06a9\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0631\u062c \u06a9\u0646\u06cc\u062f\u060c \u062d\u0645\u0644 \u0645\u06cc\u200c\u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u0645\u062d\u0645\u0648\u0644\u0647 \u0628\u0631\u0627\u06cc \u062d\u062f\u0627\u06a9\u062b\u0631 \u0627\u0645\u0646\u06cc\u062a \u062f\u0631 Base64 \u06a9\u062f\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.<\/li>\n<li><strong>\u0627\u0645\u0636\u0627:<\/strong> \u0627\u06cc\u0646 \u06cc\u06a9 \u062a\u0631\u06a9\u06cc\u0628 \u0647\u0634 \u0634\u062f\u0647 \u0627\u0632 \u0647\u062f\u0631\u060c \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0648 \u06a9\u0644\u06cc\u062f \u0645\u062e\u0641\u06cc \u0633\u0631\u0648\u0631 \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u06cc\u06a9\u067e\u0627\u0631\u0686\u06af\u06cc \u062a\u0648\u06a9\u0646 \u0631\u0627 \u062a\u0636\u0645\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0647\u0631 \u06af\u0648\u0646\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0631 \u062a\u0648\u06a9\u0646 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u062e\u0648\u0627\u0647\u062f \u0634\u062f.<\/li>\n<\/ul>\n<h2 id=\"how-do-jwts-work\"><span class=\"ez-toc-section\" id=\"jwt_%d9%87%d8%a7_%da%86%da%af%d9%88%d9%86%d9%87_%da%a9%d8%a7%d8%b1_%d9%85%db%8c_%da%a9%d9%86%d9%86%d8%af%d8%9f\"><\/span>JWT \u0647\u0627 \u0686\u06af\u0648\u0646\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u0646\u062f\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0641\u0647\u0645\u06cc\u062f JWT \u0686\u06af\u0648\u0646\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0628\u0627\u06cc\u062f \u0628\u062f\u0627\u0646\u06cc\u062f \u06a9\u0647 \u062a\u0648\u06a9\u0646 \u0647\u0627 \u0642\u0631\u0627\u0631 \u0627\u0633\u062a \u0686\u0647 \u06a9\u0627\u0631\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0646\u062f.  JWT \u0647\u0627 \u0628\u0631\u0627\u06cc \u0645\u062e\u0641\u06cc \u06a9\u0631\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u06cc\u062c\u0627\u062f \u0646\u0645\u06cc \u0634\u0648\u0646\u062f\u060c \u0628\u0644\u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u062a\u0623\u06cc\u06cc\u062f \u0627\u0639\u062a\u0628\u0627\u0631 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u0634\u0648\u0646\u062f.  \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a \u06a9\u0647 JWT \u0627\u0645\u0636\u0627 \u0648 \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0646\u0647 \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647.<\/p>\n<p>JWT \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0648\u0633\u06cc\u0644\u0647 \u0627\u06cc \u0628\u062f\u0648\u0646 \u062d\u0627\u0644\u062a \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u0645\u0634\u062a\u0631\u06cc \u0628\u0647 \u0633\u0631\u0648\u0631 \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0647\u06cc\u0686 \u0634\u06cc \u062c\u0644\u0633\u0647 \u0627\u06cc \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0630\u062e\u06cc\u0631\u0647 \u0646\u0645\u06cc \u06a9\u0646\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0631\u0648\u0631\u06af\u0631 \u0648\u0636\u0639\u06cc\u062a \u062c\u0644\u0633\u0647 \u0631\u0627 \u0628\u06cc\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627 \u062d\u0641\u0638 \u0646\u0645\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u062f\u0631 \u0639\u0648\u0636\u060c JWT \u0647\u0627 \u0627\u0632 \u0646\u0634\u0627\u0646\u0647 \u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f \u06a9\u0647 \u0647\u0631 \u0628\u0627\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u062f\u0631 \u0633\u0631\u0622\u06cc\u0646\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f.  \u0627\u06cc\u0646 \u062a\u0648\u06a9\u0646 \u062a\u0623\u06cc\u06cc\u062f \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062a\u0648\u06a9\u0646 \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u0633\u062a \u0648 \u0627\u062c\u0627\u0632\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0622\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0631\u0627 \u062f\u0627\u0631\u062f.  <\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0628\u06cc\u0646\u06cc\u0645 \u0686\u06af\u0648\u0646\u0647 \u0627\u06cc\u0646 \u0627\u062a\u0641\u0627\u0642 \u0645\u06cc \u0627\u0641\u062a\u062f:<\/p>\n<ol>\n<li>\u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0633\u0639\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0648\u0627\u0631\u062f \u0634\u0648\u062f \u0648 \u06cc\u06a9 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u062a\u0623\u06cc\u06cc\u062f \u0634\u0648\u062f.<\/li>\n<li>\u062a\u0627\u0628\u0639 \u062a\u0623\u06cc\u06cc\u062f \u06cc\u06a9 \u0628\u0631\u0631\u0633\u06cc \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0628\u0628\u06cc\u0646\u062f \u0622\u06cc\u0627 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06cc\u0627 \u062e\u06cc\u0631.<\/li>\n<li>\u067e\u0633 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0627 \u0645\u0648\u0641\u0642\u06cc\u062a \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0634\u062f (\u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645) \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062e\u0648\u062f (\u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0628\u0627\u0631)\u060c \u0645\u0627\u0646\u0646\u062f \u0634\u0646\u0627\u0633\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u06cc\u0627 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc\u060c \u06cc\u06a9 JWT \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc\u200c\u0634\u0648\u062f \u0648 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u06a9\u0644\u06cc\u062f \u0645\u062e\u0641\u06cc \u0622\u0646 \u0631\u0627 \u0627\u0645\u0636\u0627 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/li>\n<li>JWT \u062a\u0648\u0644\u06cc\u062f \u0634\u062f\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u062a\u0648\u06a9\u0646 \u062d\u0627\u0645\u0644 \u0647\u0645\u0631\u0627\u0647 \u0628\u0627 \u0647\u0631 \u0647\u062f\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f \u062a\u0627 \u0628\u0631\u0631\u0633\u06cc \u0634\u0648\u062f \u0622\u06cc\u0627 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0622\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0634\u062f\u0647 \u0627\u0633\u062a \u06cc\u0627 \u062e\u06cc\u0631.<\/li>\n<\/ol>\n<h2 id=\"how-to-use-json-web-tokens-to-authenticate-flask-applications\"><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%aa%d9%88%da%a9%d9%86_%d9%87%d8%a7%db%8c_%d9%88%d8%a8_json_%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_%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87_%d9%87%d8%a7%db%8c_flask\"><\/span>\u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc \u0648\u0628 JSON \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc Flask<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0646 \u0627\u06cc\u0646\u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a JWT \u0631\u0627 \u062f\u0631 Flask \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f\u060c \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0633\u0627\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u0632 JWT \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0648\u0631\u0648\u062f \u0648 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<h3 id=\"1-install-the-dependencies\"><span class=\"ez-toc-section\" id=\"1_%d9%88%d8%a7%d8%a8%d8%b3%d8%aa%da%af%db%8c_%d9%87%d8%a7_%d8%b1%d8%a7_%d9%86%d8%b5%d8%a8_%da%a9%d9%86%db%8c%d8%af\"><\/span>1. \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06cc\u0646 \u062f\u0633\u062a\u0648\u0631 \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645<\/p>\n<pre><code>pip install flask flask-bcrypt Flask-JWT-Extended\n<\/code><\/pre>\n<p>\u0628\u0639\u062f\u060c \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f import \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u0627\u06cc\u0646 \u06a9\u062f \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"language-python\">from flask import Flask, jsonify, session, request, redirect, url_for\nfrom flask_jwt_extended import JWTManager, create_access_token, jwt_required, get_jwt_identity, get_jwt\n\n\napp = Flask(__name__)\n\n\/\/\/\/WRITE MAIN CODE HERE\n\n\nif __name__ == \"__main__\":\n    with app.app_context():\n        app.run(debug=True)\n<\/code><\/pre>\n<h3 id=\"2-create-a-database-and-user-model\"><span class=\"ez-toc-section\" id=\"2_%db%8c%da%a9_%d9%be%d8%a7%db%8c%da%af%d8%a7%d9%87_%d8%af%d8%a7%d8%af%d9%87_%d9%88_user_model_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\"><\/span>2. \u06cc\u06a9 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0648 User Model \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0627\u0632 SQL-Alchemy \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645\u060c \u06a9\u0647 \u06cc\u06a9 \u062c\u0639\u0628\u0647 \u0627\u0628\u0632\u0627\u0631 Python SQL \u0627\u0633\u062a \u06a9\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 SQL \u0631\u0627 \u062f\u0631 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0647\u0627\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u067e\u06cc\u0686\u06cc\u062f\u0647 \u062a\u0631 \u0645\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc SQL Alchemy \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f\u060c \u0645\u0631\u0627\u062d\u0644 \u0632\u06cc\u0631 \u0631\u0627 \u062f\u0646\u0628\u0627\u0644 \u06a9\u0646\u06cc\u062f:<\/p>\n<p>\u0627\u0628\u062a\u062f\u0627 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f terminal \u06cc\u0627 \u062e\u0637 \u0641\u0631\u0645\u0627\u0646 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f \u0648 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code>pip install sqlalchemy\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u062f\u0633\u062a\u0648\u0631 SQLAlchemy \u0631\u0627 \u062f\u0631 \u0645\u062d\u06cc\u0637 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0634\u0645\u0627 \u0646\u0635\u0628 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0641\u0647\u0631\u0633\u062a \u067e\u0631\u0648\u0698\u0647 \u0634\u0645\u0627 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0642\u0631\u0627\u0631 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0637\u0648\u0631\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0627\u0632 \u0633\u06cc\u0633\u062a\u0645 \u0645\u062f\u06cc\u0631\u06cc\u062a \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 (DBMS) \u062a\u0631\u062c\u06cc\u062d\u06cc \u0634\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0627\u0632 SQlite3 DBMS \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0632\u06cc\u0631\u0627 \u0628\u0647 \u0633\u0631\u0648\u0631 \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u0646\u06cc\u0627\u0632 \u0646\u062f\u0627\u0631\u062f:<\/p>\n<pre><code>app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:\/\/\/site.db'\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0642\u0637\u0639\u0647 \u06a9\u062f \u0628\u0647 Flask-SQLAlchemy \u062f\u0633\u062a\u0648\u0631 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0622\u0646 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f <code>site.db<\/code> \u0641\u0627\u06cc\u0644 \u0631\u0627 \u062f\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 SQLite \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc.<\/p>\n<p>\u0633\u067e\u0633 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0631\u0627 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code>db = SQLAlchemy(app)\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0646\u0645\u0648\u0646\u0647 \u0627\u0632 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0644\u06cc \u0628\u06cc\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646 User Model \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u062c\u0632\u0626\u06cc\u0627\u062a \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code>class User(db.Model, UserMixin):\n    id = db.Column(db.Integer, primary_key=True)\n    username = db.Column(db.String(20), unique=True, nullable=False)\n    password = db.Column(db.String(80), nullable=False)\n    is_active = db.Column(db.Boolean(), default=True)\n    cart = db.Column(JSON, nullable=True, default=list)  # Make cart nullable\n\n    # Define the relationship between User and CartProducts\n    cart_products = relationship('CartProducts', backref=\"user\", lazy=\"dynamic\")\n    # Define the relationship between User and Wishlists\n    wishlists = db.relationship('Wishlists', backref=\"user\", lazy=True)\n\n    def __repr__(self):\n        return f'&lt;User {self.username}&gt;'\n<\/code><\/pre>\n<p><strong>  \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0645\u062f\u0644 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0647\u0645\u0627\u0646 \u0646\u062d\u0648 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0645\u0648\u062c\u0648\u062f\u06cc\u062a \u0647\u0627\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0631\u0627 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0646\u0634\u0627\u0646 \u062f\u0647\u06cc\u062f.<\/p>\n<h3 id=\"3-configure-the-application-for-jwt-authentication\"><span class=\"ez-toc-section\" id=\"3_%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87_%d8%b1%d8%a7_%d8%a8%d8%b1%d8%a7%db%8c_jwt_authentication_%d9%be%db%8c%da%a9%d8%b1%d8%a8%d9%86%d8%af%db%8c_%da%a9%d9%86%db%8c%d8%af\"><\/span>3. \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0631\u0627\u06cc JWT Authentication \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a JWT \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u062e\u0648\u062f\u060c import \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0648 \u062a\u0646\u0638\u06cc\u0645 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0645\u0646\u0627\u0633\u0628 \u0628\u0627 \u0627\u06cc\u0646 \u06a9\u062f:<\/p>\n<pre><code class=\"language-python\">from flask import Flask, jsonify, request\nfrom flask_sqlalchemy import SQLAlchemy\nfrom flask_jwt_extended import JWTManager, create_access_token, jwt_required\n\napp = Flask(__name__)\n\n# Configuration\napp.config['SECRET_KEY'] = 'your_strong_secret_key'\napp.config[\"JWT_SECRET_KEY\"] = 'your_jwt_secret_key'\napp.config['JWT_TOKEN_LOCATION'] = ['headers']\n\n# Database Initialization\ndb = SQLAlchemy(app)\n\n# JWT Initialization\njwt = JWTManager(app)\n\n# Rest of the application code (routes, etc.)\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0642\u0637\u0639\u0647 \u06a9\u062f \u0627\u062c\u0632\u0627\u06cc \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0648\u0627\u0631\u062f \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<ul>\n<li><strong>app.config[&#8216;SECRET_KEY&#8217;]<\/strong>  \u06a9\u0644\u06cc\u062f \u0645\u062e\u0641\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u0645\u0636\u0627\u06cc \u0627\u06cc\u0645\u0646 \u06a9\u0648\u06a9\u06cc \u0647\u0627\u06cc \u062c\u0644\u0633\u0647 \u0648 \u0633\u0627\u06cc\u0631 \u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637 \u0628\u0627 \u0627\u0645\u0646\u06cc\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<li><strong>app.config[&#8216;JWT_SECRET_KEY&#8217;]<\/strong>  \u06a9\u0644\u06cc\u062f \u0645\u062e\u0641\u06cc \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0631\u0645\u0632\u06af\u0630\u0627\u0631\u06cc \u0648 \u0631\u0645\u0632\u06af\u0634\u0627\u06cc\u06cc JWT \u0647\u0627 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0639\u0645\u0644\u06cc\u0627\u062a Flask-JWT \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li><strong>app.config[&#8216;JWT_TOKEN_LOCATION&#8217;]<\/strong>  \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0627\u06cc\u062f \u06a9\u062c\u0627 \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 JWT \u0628\u0627\u0634\u062f.  \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u0646\u06af\u0627\u0647 \u0634\u0648\u062f.<\/li>\n<\/ul>\n<p>\u0648\u0642\u062a\u06cc \u0627\u06cc\u0646 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f\u06cc\u0645\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0642\u0635\u062f \u0645\u062d\u0627\u0641\u0638\u062a \u0627\u0632 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0627\u0631\u06cc\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.<\/p>\n<h3 id=\"4-create-protected-routes\"><span class=\"ez-toc-section\" id=\"4_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%85%d8%ad%d8%a7%d9%81%d8%b8%d8%aa_%d8%b4%d8%af%d9%87_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\"><\/span>4. \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0635\u0641\u062d\u0627\u062a\u06cc \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u0645\u0627 \u0642\u0635\u062f \u062f\u0627\u0631\u06cc\u0645 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0627\u0632 \u062f\u06cc\u062f \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u063a\u06cc\u0631\u0645\u062c\u0627\u0632 \u0645\u062e\u0641\u06cc \u0646\u06af\u0647 \u062f\u0627\u0631\u06cc\u0645. <\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0641\u0631\u0636 \u06a9\u0646\u06cc\u0645 \u0633\u0639\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648\u0627\u0631\u062f \u0645\u06a9\u0627\u0646\u06cc \u0634\u0648\u06cc\u0645 \u06a9\u0647 \u0645\u062e\u062a\u0635 \u0627\u0639\u0636\u0627\u06cc \u06cc\u06a9 \u062c\u0627\u0645\u0639\u0647 \u0627\u0633\u062a.  \u0627\u0645\u0627 \u06cc\u06a9 \u0646\u06af\u0647\u0628\u0627\u0646 \u0645\u062d\u0644 \u0628\u0631\u06af\u0632\u0627\u0631\u06cc \u0631\u0627 \u0627\u0632 \u062f\u0633\u062a &#8220;\u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u063a\u06cc\u0631\u0645\u062c\u0627\u0632&#8221; \u0645\u0627\u0646\u0646\u062f \u0645\u0627 \u0627\u06cc\u0645\u0646 \u0645\u06cc \u06a9\u0646\u062f.  \u062f\u0631 \u0627\u06cc\u0646 \u0634\u0631\u0627\u06cc\u0637\u060c \u0645\u0627 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0633\u062a\u06cc\u0645\u060c \u0645\u062d\u0644 \u0628\u0631\u06af\u0632\u0627\u0631\u06cc\u060c \u0646\u0634\u0627\u0646\u06cc \u0627\u06cc\u0646\u062a\u0631\u0646\u062a\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0627\u0632 \u0622\u0646 \u0645\u062d\u0627\u0641\u0638\u062a \u0645\u06cc \u06a9\u0646\u06cc\u0645\u060c \u0648 \u0646\u06af\u0647\u0628\u0627\u0646\u06cc \u06a9\u0647 \u0627\u0632 \u0645\u06a9\u0627\u0646 \u0645\u062d\u0627\u0641\u0638\u062a \u0645\u06cc \u06a9\u0646\u062f\u060c \u06cc\u06a9 <strong><code>@jwt_required<\/code> <\/strong>\u062f\u06a9\u0648\u0631\u0627\u062a\u0648\u0631<\/p>\n<p>\u0631\u0627 <strong><code>@jwt_required<\/code><\/strong>  \u062f\u06a9\u0648\u0631\u0627\u062a\u0648\u0631 \u0628\u0631\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0627\u0632 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u062e\u0627\u0635\u06cc \u06a9\u0647 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u062f\u0627\u0631\u0646\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0627\u06cc\u0646 \u062f\u06a9\u0648\u0631\u0627\u062a\u0648\u0631 \u0642\u0628\u0644 \u0627\u0632 \u0627\u062c\u0627\u0632\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 page:<\/p>\n<pre><code class=\"language-python\">@app.route('\/get_name', methods=['GET'])\n@jwt_required()\ndef get_name():\n    # Extract the user ID from the JWT\n    user_id = get_jwt_identity()\n    user = User.query.filter_by(id=user_id).first()\n\n    # Check if user exists\n    if user:\n        return jsonify({'message': 'User found', 'name': user.name})\n    else:\n        return jsonify({'message': 'User not found'}), 404\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0642\u0637\u0639\u0647 \u06a9\u062f\u060c \u062a\u0627\u0628\u0639\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u067e\u0633 \u0627\u0632 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f.  \u0627\u06af\u0631 \u062a\u0648\u06a9\u0646 \u0645\u0641\u0642\u0648\u062f\u060c \u0646\u0627\u0645\u0639\u062a\u0628\u0631 \u06cc\u0627 \u0645\u0646\u0642\u0636\u06cc \u0634\u062f\u0647 \u0628\u0627\u0634\u062f\u060c \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0631\u062f \u0645\u06cc \u0634\u0648\u062f \u0648 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0633\u0631\u0648\u0631 \u06cc\u06a9 HTTP \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f. <strong>401<\/strong> \u0648\u0636\u0639\u06cc\u062a \u063a\u06cc\u0631 \u0645\u062c\u0627\u0632<\/p>\n<h3 id=\"5-create-a-login-page\"><span class=\"ez-toc-section\" id=\"5_%db%8c%da%a9_%d8%b5%d9%81%d8%ad%d9%87_%d9%88%d8%b1%d9%88%d8%af_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\"><\/span>5. \u06cc\u06a9 \u0635\u0641\u062d\u0647 \u0648\u0631\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc\u060c \u0645\u0627 \u062a\u0627\u0628\u0639\u06cc \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f \u06a9\u0647 \u0627\u0639\u062a\u0628\u0627\u0631 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0631\u0627 \u0627\u0632 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0645\u0634\u062a\u0631\u06cc (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0641\u0631\u0645) \u0645\u06cc\u200c\u067e\u0630\u06cc\u0631\u062f \u0648 \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a\u200c\u0634\u062f\u0647 \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0627 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u0642\u0627\u06cc\u0633\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f.  \u0627\u06af\u0631 \u0645\u0637\u0627\u0628\u0642\u062a \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u06cc\u06a9 \u0646\u0634\u0627\u0646\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc JWT \u062d\u0627\u0648\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u06a9\u0627\u0631\u0628\u0631 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<pre><code class=\"language-python\">@app.route('\/login', methods=['POST'])\ndef login():\n    data = request.get_json()\n    username = data['username']\n    password = data['password']\n    print('Received data:', username , password)\n\n    user = User.query.filter_by(username=username).first()\n\n    if user and bcrypt.check_password_hash(user.password, password):\n        access_token = create_access_token(identity=user.id)\n        return jsonify({'message': 'Login Success', 'access_token': access_token})\n    else:\n        return jsonify({'message': 'Login Failed'}), 401\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u062b\u0627\u0644\u060c \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u0627\u0639\u062a\u0628\u0627\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 bcrypt \u0628\u0631\u0627\u06cc \u062a\u0623\u06cc\u06cc\u062f \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0627\u06cc\u0645\u0646 \u0647\u0646\u06af\u0627\u0645 \u062f\u0631\u06cc\u0627\u0641\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a POST \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06af\u0631 \u0627\u0639\u062a\u0628\u0627\u0631\u0646\u0627\u0645\u0647 \u0647\u0627 \u0645\u0639\u062a\u0628\u0631 \u0628\u0627\u0634\u0646\u062f\u060c \u0633\u0631\u0648\u0631 \u06cc\u06a9 JWT \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0647 \u0622\u0646\u0647\u0627 \u0627\u0645\u06a9\u0627\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u062f\u0647 \u0631\u0627 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0646\u0645\u0648\u0646\u0647 \u0627\u06cc \u0627\u0632 \u0641\u0631\u0645 React \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a POST \u0631\u0627 \u0628\u0647 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648\u0631\u0648\u062f \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<pre><code class=\"language-jsx\">import React from \"react\";\nimport axios from \"axios\";\nimport { useState } from \"react\";\nimport Footer from \".\/Footer\";\n\/\/ import \".\/Login.css\";\n\nfunction Login() {\n  const [password, setPassword] = useState(\"\");\n  const [username, setUsername] = useState(\"\");\n\n  const handleLogin = async (event) =&gt; {\n    event.preventDefault();\n    const data = {\n      username: username,\n      Password: password,\n    };\n\n    try {\n      const response = await axios.post(\"http:\/\/localhost:5000\/login\", {\n        username,\n        password,\n      });\n      localStorage.setItem(\"access_token\", response.data.access_token);\n      \/\/ Redirect to protected route\n      alert(\"Login successful\");\n    } catch (error) {\n      console.error(error);\n      \/\/ Display error message to user\n    }\n  };\n\n  const handleUsernameChange = (event) =&gt; {\n    setUsername(event.target.value);\n  };\n\n  const handlePasswordChange = (event) =&gt; {\n    setPassword(event.target.value);\n  };\n\n  return (\n    &lt;div &gt;\n      \n          &lt;form method=\"post\" &gt;\n              &lt;input\n                type=\"text\"\n                id=\"\"\n                placeholder=\"Username\"\n                name=\"username\"\n                required\n                value={username}\n                onChange={handleUsernameChange}\n              \/&gt;\n              &lt;input\n                type=\"text\"\n                id=\"\"\n                placeholder=\"Your email\"\n              \/&gt;\n              &lt;input\n                type=\"password\"\n                required\n                placeholder=\"Your Password\"\n                name=\"password\"\n                value={password}\n                onChange={handlePasswordChange}\n              \/&gt;\n          &lt;\/form&gt;\n          &lt;button type=\"submit\" onClick={handleLogin}&gt;\n            Log In\n          &lt;\/button&gt;\n       \n    &lt;\/div&gt;\n  );\n\n}\n\nexport default Login;\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a React\u060c \u06cc\u06a9 \u0641\u0631\u0645 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0627\u0631\u0627\u0626\u0647 \u06a9\u0631\u062f\u06cc\u0645 \u06a9\u0647 \u0627\u0632 Axios \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a POST \u0628\u0647 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648\u0631\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f.  \u0648\u0631\u0648\u062f\u06cc \u0647\u0627\u06cc \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 React \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f <code>useState<\/code> hook  \u0648 \u0627\u06cc\u0646 \u0645\u0642\u0627\u062f\u06cc\u0631 \u0631\u0627 \u067e\u0633 \u0627\u0632 \u0627\u0631\u0633\u0627\u0644 \u0641\u0631\u0645 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f. <\/p>\n<p>\u0627\u06af\u0631 \u0648\u0631\u0648\u062f \u0645\u0648\u0641\u0642\u06cc\u062a \u0622\u0645\u06cc\u0632 \u0628\u0627\u0634\u062f\u060c \u06cc\u06a9 JWT \u0631\u0627 \u062f\u0631 \u062d\u0627\u0641\u0638\u0647 \u0645\u062d\u0644\u06cc \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0633\u0645\u062a \u0633\u0631\u0648\u06cc\u0633 \u06af\u06cc\u0631\u0646\u062f\u0647 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0647\u0646\u06af\u0627\u0645 \u0627\u0631\u0633\u0627\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0634\u062f\u0647 \u0628\u0647 \u0633\u0631\u0648\u0631\u060c \u062a\u0648\u06a9\u0646 \u0631\u0627 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u06a9\u0646\u062f.<\/p>\n<figure class=\"kg-card kg-image-card kg-width-wide\"><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/04\/jwtDemo-1.gif\" class=\"kg-image\" alt=\"jwtDemo-1\" width=\"1586\" height=\"768\" loading=\"lazy\" title=\"\"><\/figure>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0631\u0648\u0634 \u0627\u06cc\u0645\u0646 \u0633\u0627\u0632\u06cc API \u0647\u0627 \u0628\u0627 JSON Web Tokens \u062f\u0631 Flask \u0631\u0627 \u06cc\u0627\u062f \u06af\u0631\u0641\u062a\u06cc\u0645.  \u0645\u0627 \u0627\u0635\u0648\u0644 \u0627\u0648\u0644\u06cc\u0647 JWT \u0647\u0627\u060c \u0631\u0648\u0634 \u06a9\u0627\u0631 \u0622\u0646\u0647\u0627 \u0631\u0627 \u067e\u0648\u0634\u0634 \u062f\u0627\u062f\u06cc\u0645 \u0648 \u06af\u0627\u0645 \u0628\u0647 \u06af\u0627\u0645 \u0627\u0631\u0627\u0626\u0647 \u06a9\u0631\u062f\u06cc\u0645 process \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a  \u0627\u06cc\u0646 \u0634\u0627\u0645\u0644 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0627\u0632 \u0646\u0635\u0628 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc \u0636\u0631\u0648\u0631\u06cc \u06af\u0631\u0641\u062a\u0647 \u062a\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0648 \u0645\u062d\u0627\u0641\u0638\u062a \u0627\u0632 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0628\u0648\u062f. <\/p>\n<p>\u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631 \u0627\u06cc\u0646 \u067e\u0627\u06cc\u0647 \u0628\u0646\u0627 \u06a9\u0646\u06cc\u062f\u060c \u0645\u0627\u0646\u0646\u062f \u0627\u0641\u0632\u0648\u062f\u0646 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc \u062a\u0627\u0632\u0647\u060c \u0627\u062f\u063a\u0627\u0645 \u0628\u0627 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 OAuth \u0634\u062e\u0635 \u062b\u0627\u0644\u062b\u060c \u06cc\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u062c\u0648\u0632\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u067e\u06cc\u0686\u06cc\u062f\u0647 \u062a\u0631.<\/p>\n<\/section>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-04-18 05:07:06<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;17271&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\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0648\u06a9\u0646 \u0647\u0627\u06cc \u0648\u0628 JSON \u0628\u0631\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u0645\u0646 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0641\u0644\u0627\u0633\u06a9&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 7<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u06af\u0630\u0631\u0648\u0627\u0698\u0647\u200c\u0647\u0627\u060c \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u06a9\u0627\u0631\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u06cc\u060c \u0634\u0645\u0627\u0631\u0647\u200c\u0647\u0627\u06cc \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0634\u062e\u0635\u06cc (PIN) &#8211; \u0627\u06cc\u0646\u0647\u0627 \u0647\u0645\u0647 \u062f\u0627\u0631\u0627\u06cc\u06cc\u200c\u0647\u0627\u06cc \u062d\u06cc\u0627\u062a\u06cc \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0645\u062c\u0648\u0632 \u0648 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f. \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0622\u0646\u0647\u0627 \u0628\u0627\u06cc\u062f \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u063a\u06cc\u0631\u0645\u062c\u0627\u0632 \u0645\u062d\u0627\u0641\u0638\u062a \u0634\u0648\u0646\u062f. \u0645\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0648\u0638\u06cc\u0641\u0647 \u062f\u0627\u0631\u06cc\u0645 \u0627\u0632 \u0627\u06cc\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633 \u0645\u062d\u0627\u0641\u0638\u062a \u06a9\u0646\u06cc\u0645 \u0648 \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0627\u06cc\u0645\u0646 \u0642\u0648\u06cc \u0631\u0627 \u062f\u0631 [&hellip;]<\/p>\n","protected":false},"author":6,"featured_media":17272,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1743],"tags":[2046,2719,1844,1938,1920,2047,1776,1786,3852,1916,1814,1909,2126,2750,2123,2002,5008,1939,1745,1785,2048,2829],"class_list":["post-17271","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-python","tag-2046","tag-json","tag-1844","tag-1938","tag-1920","tag-2047","tag-1776","tag-1786","tag-3852","tag-1916","tag-1814","tag-1909","tag-2126","tag-2750","tag-2123","tag-python","tag-5008","tag-1939","tag-1745","tag-1785","tag-2048","tag-2829"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/17271","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=17271"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/17271\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/17272"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=17271"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=17271"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=17271"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}