{"id":18367,"date":"2024-12-12T23:44:20","date_gmt":"2024-12-12T20:14:20","guid":{"rendered":"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/"},"modified":"2024-12-12T23:44:20","modified_gmt":"2024-12-12T20:14:20","slug":"%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/","title":{"rendered":"\u0633\u0627\u062e\u062a \u06cc\u06a9 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0633\u0627\u062f\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0628\u0627 \u067e\u0627\u06cc\u062a\u0648\u0646: \u0631\u0627\u0647\u0646\u0645\u0627\u06cc \u0645\u0628\u062a\u062f\u06cc\u0627\u0646"},"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%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d8%a2%d8%b3%db%8c%d8%a8_%d9%be%d8%b0%db%8c%d8%b1%db%8c_%d9%87%d8%a7\" >\u0627\u0646\u0648\u0627\u0639 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0647\u0627<\/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%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%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><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%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%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-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%85%d8%ad%db%8c%d8%b7_%d8%aa%d9%88%d8%b3%d8%b9%d9%87_%d9%85%d8%a7\" >\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u062d\u06cc\u0637 \u062a\u0648\u0633\u0639\u0647 \u0645\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d8%b3%d8%a7%d8%ae%d8%aa%d9%86_%da%a9%d9%84%d8%a7%d8%b3_%d8%a7%d8%b3%da%a9%d9%86%d8%b1_%d9%87%d8%b3%d8%aa%d9%87_%d9%85%d8%a7\" >\u0633\u0627\u062e\u062a\u0646 \u06a9\u0644\u0627\u0633 \u0627\u0633\u06a9\u0646\u0631 \u0647\u0633\u062a\u0647 \u0645\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%ae%d8%b2%d9%86%d8%af%d9%87\" >\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u062e\u0632\u0646\u062f\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d8%b7%d8%b1%d8%a7%d8%ad%db%8c_%d9%88_%d8%a7%d8%ac%d8%b1%d8%a7%db%8c_%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%d9%87%d8%a7%db%8c_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c\" >\u0637\u0631\u0627\u062d\u06cc \u0648 \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%d8%aa%d8%b4%d8%ae%db%8c%d8%b5_%d8%aa%d8%b2%d8%b1%db%8c%d9%82_sql\" >\u0628\u0631\u0631\u0633\u06cc \u062a\u0634\u062e\u06cc\u0635 \u062a\u0632\u0631\u06cc\u0642 SQL<\/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%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#xss_cross-site_scripting_%d8%b1%d8%a7_%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%da%a9%d9%86%db%8c%d8%af\" >XSS (Cross-Site Scripting) \u0631\u0627 \u0628\u0631\u0631\u0633\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-10\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%d9%82%d8%b1%d8%a7%d8%b1_%da%af%d8%b1%d9%81%d8%aa%d9%86_%d8%af%d8%b1_%d9%85%d8%b9%d8%b1%d8%b6_%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa_%d8%ad%d8%b3%d8%a7%d8%b3\" >\u0628\u0631\u0631\u0633\u06cc \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0646 \u062f\u0631 \u0645\u0639\u0631\u0636 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%85%d9%86%d8%b7%d9%82_%d8%a7%d8%b5%d9%84%db%8c_%d8%a7%d8%b3%da%a9%d9%86\" >\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0645\u0646\u0637\u0642 \u0627\u0635\u0644\u06cc \u0627\u0633\u06a9\u0646<\/a><\/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%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%da%af%d8%b3%d8%aa%d8%b1%d8%b4_%d8%a7%d8%b3%da%a9%d9%86%d8%b1_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c\" >\u06af\u0633\u062a\u0631\u0634 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa-%db%8c%da%a9-%d8%a7%d8%b3%da%a9%d9%86%d8%b1-%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c-%d8%b3%d8%a7%d8%af%d9%87-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%88%d8%a8-%d8%a8%d8%a7-%d9%be\/#%d8%a8%d8%b3%d8%aa%d9%87_%d8%a8%d9%86%d8%af%db%8c\" >\u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc<\/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>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u06cc\u062f \u06a9\u0647 \u06cc\u06a9 \u0627\u0628\u0632\u0627\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0633\u0627\u0633\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062f\u0631 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0647\u0627\u06cc \u0631\u0627\u06cc\u062c \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0645\u0641\u06cc\u062f \u0628\u0627\u0634\u062f.<\/p>\n<p>\u0645\u0646 \u0627\u06cc\u0646\u062c\u0627 \u062f\u0648 \u0647\u062f\u0641 \u062f\u0627\u0631\u0645. \u0627\u0648\u0644\u06cc\u0646 \u0645\u0648\u0631\u062f \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0628\u0627 \u0645\u0647\u0627\u0631\u062a \u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0628\u0647\u0628\u0648\u062f \u0648\u0636\u0639\u06cc\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0644\u06cc \u0648\u0628 \u0633\u0627\u06cc\u062a \u0634\u0645\u0627 \u06a9\u0645\u06a9 \u06a9\u0646\u0646\u062f\u060c \u062a\u0648\u0627\u0646\u0645\u0646\u062f \u06a9\u0646\u06cc\u0645. \u062f\u0648\u0645 \u06a9\u0645\u06a9 \u0628\u0647 \u062a\u0645\u0631\u06cc\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0634\u0645\u0627 \u06cc\u06a9 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u067e\u0627\u06cc\u062a\u0648\u0646 \u062e\u0648\u0627\u0647\u06cc\u062f \u0633\u0627\u062e\u062a \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f XSS\u060c \u062a\u0632\u0631\u06cc\u0642 SQL \u0648 PII \u062d\u0633\u0627\u0633 (\u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0634\u062e\u0635\u06cc) \u0631\u0627 \u062a\u0634\u062e\u06cc\u0635 \u062f\u0647\u062f.<\/p>\n<h3 id=\"heading-types-of-vulnerabilities\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d8%a2%d8%b3%db%8c%d8%a8_%d9%be%d8%b0%db%8c%d8%b1%db%8c_%d9%87%d8%a7\"><\/span>\u0627\u0646\u0648\u0627\u0639 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u06a9\u0644\u06cc\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0633\u06cc\u0628\u200c\u067e\u0630\u06cc\u0631\u06cc\u200c\u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0648\u0628 \u0631\u0627 \u062f\u0631 \u0633\u0637\u0644\u200c\u0647\u0627\u06cc \u0632\u06cc\u0631 \u062f\u0633\u062a\u0647\u200c\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u0645 (\u0628\u0631\u0627\u06cc \u0633\u0637\u0644\u200c\u0647\u0627\u06cc \u0628\u06cc\u0634\u062a\u0631\u060c \u06f1\u06f0 OWASP \u0628\u0631\u062a\u0631 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f):<\/p>\n<ul>\n<li>\n<p><strong>\u062a\u0632\u0631\u06cc\u0642 SQL<\/strong>: \u062a\u06a9\u0646\u06cc\u06a9\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u06a9\u062f SQL \u0645\u062e\u0631\u0628 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0648\u0631\u0648\u062f\u06cc\u200c\u0647\u0627\u06cc \u0646\u0627\u0645\u0639\u062a\u0628\u0631 \u062f\u0631 \u062c\u0633\u062a\u200c\u0648\u062c\u0648\u0647\u0627\u06cc SQL \u0648\u0627\u0631\u062f \u06a9\u0646\u0646\u062f \u0648 \u0628\u0647 \u0622\u0646\u200c\u0647\u0627 \u0627\u062c\u0627\u0632\u0647 \u062a\u063a\u06cc\u06cc\u0631\/\u062e\u0648\u0627\u0646\u062f\u0646 \u0645\u062d\u062a\u0648\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0645\u06cc\u200c\u062f\u0647\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p><strong>\u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u06cc\u0646 \u0633\u0627\u06cc\u062a\u06cc (XSS)<\/strong>: \u062a\u06a9\u0646\u06cc\u06a9\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u062e\u0631\u0628 \u0631\u0627 \u062f\u0631 \u0648\u0628 \u0633\u0627\u06cc\u062a \u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f \u062a\u0632\u0631\u06cc\u0642 \u0645\u06cc \u06a9\u0646\u0646\u062f. \u0627\u06cc\u0646 \u0628\u0647 \u0622\u0646\u0647\u0627 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u06a9\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0631\u0627 \u062f\u0631 \u0632\u0645\u06cc\u0646\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u0627\u062c\u0631\u0627 \u06a9\u0646\u0646\u062f \u0648 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633 \u0631\u0627 \u0628\u062f\u0632\u062f\u0646\u062f \u06cc\u0627 \u0639\u0645\u0644\u06cc\u0627\u062a \u063a\u06cc\u0631\u0645\u062c\u0627\u0632 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0646\u062f.<\/p>\n<\/li>\n<li>\n<p><strong>\u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0646 \u062f\u0631 \u0645\u0639\u0631\u0636 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633<\/strong>: \u06cc\u06a9 \u0645\u0634\u06a9\u0644 \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0647 \u0637\u0648\u0631 \u0646\u0627\u062e\u0648\u0627\u0633\u062a\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633\u06cc \u0645\u0627\u0646\u0646\u062f \u0631\u0645\u0632\u0647\u0627\u06cc \u0639\u0628\u0648\u0631\u060c \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc API \u0648 \u063a\u06cc\u0631\u0647 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0631\u0648\u06cc \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06af\u0632\u0627\u0631\u0634\u200c\u0647\u0627\u060c \u0630\u062e\u06cc\u0631\u0647\u200c\u0633\u0627\u0632\u06cc \u0646\u0627\u0627\u0645\u0646 \u0648 \u0633\u0627\u06cc\u0631 \u0622\u0633\u06cc\u0628\u200c\u067e\u0630\u06cc\u0631\u06cc\u200c\u0647\u0627.<\/p>\n<\/li>\n<li>\n<p><strong>\u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0627\u0634\u062a\u0628\u0627\u0647 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0631\u0627\u06cc\u062c<\/strong>: \u0645\u0634\u06a9\u0644\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0647 \u0628\u0647 \u062f\u0644\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0646\u0627\u062f\u0631\u0633\u062a \u0633\u0631\u0648\u0631\u0647\u0627\u06cc \u0648\u0628 \u0631\u062e \u0645\u06cc \u062f\u0647\u062f &#8211; \u0645\u0627\u0646\u0646\u062f \u0627\u0639\u062a\u0628\u0627\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0628\u0631\u0627\u06cc \u062d\u0633\u0627\u0628 \u0647\u0627\u06cc \u0633\u0631\u067e\u0631\u0633\u062a\u060c \u062d\u0627\u0644\u062a \u0627\u0634\u06a9\u0627\u0644 \u0632\u062f\u0627\u06cc\u06cc \u0641\u0639\u0627\u0644\u060c \u062f\u0627\u0634\u0628\u0648\u0631\u062f\u0647\u0627\u06cc \u0633\u0631\u067e\u0631\u0633\u062a \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0639\u0645\u0648\u0645 \u0628\u0627 \u0627\u0639\u062a\u0628\u0627\u0631 \u0636\u0639\u06cc\u0641 \u0648 \u063a\u06cc\u0631\u0647 \u0631\u0648\u06cc.<\/p>\n<\/li>\n<li>\n<p><strong>\u0636\u0639\u0641 \u0647\u0627\u06cc \u0627\u0633\u0627\u0633\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a<\/strong>: \u0645\u0634\u06a9\u0644\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0647 \u0628\u0647 \u062f\u0644\u06cc\u0644 \u0646\u0642\u0635 \u062f\u0631 \u0633\u06cc\u0627\u0633\u062a \u0647\u0627\u06cc \u0631\u0645\u0632 \u0639\u0628\u0648\u0631\u060c \u0641\u0631\u0622\u06cc\u0646\u062f\u0647\u0627\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u06a9\u0627\u0631\u0628\u0631\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u0646\u0627\u062f\u0631\u0633\u062a \u062c\u0644\u0633\u0647 \u0648 \u063a\u06cc\u0631\u0647 \u0631\u062e \u0645\u06cc \u062f\u0647\u062f. \u0631\u0648\u06cc.<\/p>\n<\/li>\n<\/ul>\n<h2 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><\/h2>\n<ul>\n<li>\n<p>\u067e\u06cc\u0634 \u0646\u06cc\u0627\u0632\u0647\u0627<\/p>\n<\/li>\n<li>\n<p>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u062d\u06cc\u0637 \u062a\u0648\u0633\u0639\u0647 \u0645\u0627<\/p>\n<\/li>\n<li>\n<p>\u0633\u0627\u062e\u062a\u0646 \u06a9\u0644\u0627\u0633 \u0627\u0633\u06a9\u0646\u0631 \u0647\u0633\u062a\u0647 \u0645\u0627<\/p>\n<\/li>\n<li>\n<p>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u062e\u0632\u0646\u062f\u0647<\/p>\n<\/li>\n<li>\n<p>\u0637\u0631\u0627\u062d\u06cc \u0648 \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc<\/p>\n<ul>\n<li>\n<p>\u0628\u0631\u0631\u0633\u06cc \u062a\u0634\u062e\u06cc\u0635 \u062a\u0632\u0631\u06cc\u0642 SQL<\/p>\n<\/li>\n<li>\n<p>XSS (Cross-Site Scripting) \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f<\/p>\n<\/li>\n<li>\n<p>\u0628\u0631\u0631\u0633\u06cc \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0646 \u062f\u0631 \u0645\u0639\u0631\u0636 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0645\u0646\u0637\u0642 \u0627\u0635\u0644\u06cc \u0627\u0633\u06a9\u0646<\/p>\n<\/li>\n<li>\n<p>\u06af\u0633\u062a\u0631\u0634 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc<\/p>\n<\/li>\n<li>\n<p>\u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc<\/p>\n<\/li>\n<\/ul>\n<h2 id=\"heading-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\u060c \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f:<\/p>\n<ul>\n<li>\n<p>\u067e\u0627\u06cc\u062a\u0648\u0646 3.x<\/p>\n<\/li>\n<li>\n<p>\u062f\u0631\u06a9 \u0627\u0648\u0644\u06cc\u0647 \u067e\u0631\u0648\u062a\u06a9\u0644 \u0647\u0627\u06cc HTTP<\/p>\n<\/li>\n<li>\n<p>\u062f\u0631\u06a9 \u0627\u0648\u0644\u06cc\u0647 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628<\/p>\n<\/li>\n<li>\n<p>\u062f\u0631\u06a9 \u0627\u0648\u0644\u06cc\u0647 \u0627\u0632 \u0631\u0648\u0634 \u0639\u0645\u0644\u06a9\u0631\u062f XSS\u060c \u062a\u0632\u0631\u06cc\u0642 SQL \u0648 \u062d\u0645\u0644\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0633\u0627\u0633\u06cc<\/p>\n<\/li>\n<\/ul>\n<h2 id=\"heading-setting-up-our-development-environment\"><span class=\"ez-toc-section\" id=\"%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%85%d8%ad%db%8c%d8%b7_%d8%aa%d9%88%d8%b3%d8%b9%d9%87_%d9%85%d8%a7\"><\/span>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0645\u062d\u06cc\u0637 \u062a\u0648\u0633\u0639\u0647 \u0645\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"lang-bash\">pip install requests beautifulsoup4 urllib3 colorama\n<\/code><\/pre>\n<p>\u0645\u0627 \u0627\u0632 \u0627\u06cc\u0646 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 \u06a9\u062f \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f:<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-comment\"># Required packages<\/span>\n<span class=\"hljs-keyword\">import<\/span> requests\n<span class=\"hljs-keyword\">from<\/span> bs4 <span class=\"hljs-keyword\">import<\/span> BeautifulSoup\n<span class=\"hljs-keyword\">import<\/span> urllib.parse\n<span class=\"hljs-keyword\">import<\/span> colorama\n<span class=\"hljs-keyword\">import<\/span> re\n<span class=\"hljs-keyword\">from<\/span> concurrent.futures <span class=\"hljs-keyword\">import<\/span> ThreadPoolExecutor\n<span class=\"hljs-keyword\">import<\/span> sys\n<span class=\"hljs-keyword\">from<\/span> typing <span class=\"hljs-keyword\">import<\/span> List, Dict, Set\n<\/code><\/pre>\n<h2 id=\"heading-building-our-core-scanner-class\"><span class=\"ez-toc-section\" id=\"%d8%b3%d8%a7%d8%ae%d8%aa%d9%86_%da%a9%d9%84%d8%a7%d8%b3_%d8%a7%d8%b3%da%a9%d9%86%d8%b1_%d9%87%d8%b3%d8%aa%d9%87_%d9%85%d8%a7\"><\/span>\u0633\u0627\u062e\u062a\u0646 \u06a9\u0644\u0627\u0633 \u0627\u0633\u06a9\u0646\u0631 \u0647\u0633\u062a\u0647 \u0645\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627 \u0631\u0627 \u062f\u0627\u0631\u06cc\u062f\u060c \u0646\u0648\u0628\u062a \u0628\u0647 \u0646\u0648\u0634\u062a\u0646 \u06a9\u0644\u0627\u0633 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0635\u0644\u06cc \u0645\u06cc \u0631\u0633\u062f.<\/p>\n<p>\u0627\u06cc\u0646 \u06a9\u0644\u0627\u0633 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06a9\u0644\u0627\u0633 \u0627\u0635\u0644\u06cc \u0645\u0627 \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0633\u06a9\u0646 \u0627\u0645\u0646\u06cc\u062a \u0648\u0628 \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f. \u0635\u0641\u062d\u0627\u062a \u0628\u0627\u0632\u062f\u06cc\u062f \u0634\u062f\u0647 \u0645\u0627 \u0631\u0627 \u0631\u062f\u06cc\u0627\u0628\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0648 \u06cc\u0627\u0641\u062a\u0647 \u0647\u0627\u06cc \u0645\u0627 \u0631\u0627 \u0646\u06cc\u0632 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0645\u0627 \u062f\u0627\u0631\u06cc\u0645 <code>normalize_url<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f\u06cc \u06a9\u0647 \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0639\u062f\u0645 \u0627\u0633\u06a9\u0646 \u0645\u062c\u062f\u062f URL \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u062f\u06cc\u062f\u0647 \u0634\u062f\u0647 \u0627\u0646\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u0627\u0633\u0627\u0633\u0627\u064b \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u0647\u0627\u06cc HTTP GET \u0631\u0627 \u0627\u0632 URL \u062d\u0630\u0641 \u0645\u06cc \u06a9\u0646\u062f. \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c <code>https:\/\/example.com\/page\u061fid=1<\/code> \u062a\u0628\u062f\u06cc\u0644 \u062e\u0648\u0627\u0647\u062f \u0634\u062f <code>https:\/\/example.com\/page<\/code> \u067e\u0633 \u0627\u0632 \u0639\u0627\u062f\u06cc \u0633\u0627\u0632\u06cc \u0622\u0646<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-class\"><span class=\"hljs-keyword\">class<\/span> <span class=\"hljs-title\">WebSecurityScanner<\/span>:<\/span>\n    <span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">__init__<\/span>(<span class=\"hljs-params\">self, target_url: str, max_depth: int = <span class=\"hljs-number\">3<\/span><\/span>):<\/span>\n        <span class=\"hljs-string\">\"\"\"\n        Initialize the security scanner with a target URL and maximum crawl depth.\n\n        Args:\n            target_url: The base URL to scan\n            max_depth: Maximum depth for crawling links (default: 3)\n        \"\"\"<\/span>\n        self.target_url = target_url\n        self.max_depth = max_depth\n        self.visited_urls: Set[str] = set()\n        self.vulnerabilities: List[Dict] = []\n        self.session = requests.Session()\n\n        <span class=\"hljs-comment\"># Initialize colorama for cross-platform colored output<\/span>\n        colorama.init()\n\n    <span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">normalize_url<\/span>(<span class=\"hljs-params\">self, url: str<\/span>) -&gt; str:<\/span>\n        <span class=\"hljs-string\">\"\"\"Normalize the URL to prevent duplicate checks\"\"\"<\/span>\n        parsed = urllib.parse.urlparse(url)\n        <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-string\">f\"<span class=\"hljs-subst\">{parsed.scheme}<\/span>:\/\/<span class=\"hljs-subst\">{parsed.netloc}<\/span><span class=\"hljs-subst\">{parsed.path}<\/span>\"<\/span>\n<\/code><\/pre>\n<h2 id=\"heading-implementing-the-crawler\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%ae%d8%b2%d9%86%d8%af%d9%87\"><\/span>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u062e\u0632\u0646\u062f\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0648\u0644\u06cc\u0646 \u0642\u062f\u0645 \u062f\u0631 \u0627\u0633\u06a9\u0646\u0631 \u0645\u0627 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u062e\u0632\u0646\u062f\u0647 \u0648\u0628 \u0627\u0633\u062a \u06a9\u0647 \u0635\u0641\u062d\u0627\u062a \u0648 URL \u0647\u0627 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u062f\u0641 \u0645\u0634\u062e\u0635 \u06a9\u0634\u0641 \u0645\u06cc \u06a9\u0646\u062f. \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0627\u06cc\u0646 \u062a\u0648\u0627\u0628\u0639 \u0631\u0627 \u062f\u0631 \u0645\u0627 \u0645\u06cc \u0646\u0648\u06cc\u0633\u06cc\u062f <code>WebSecurityScanner<\/code> \u06a9\u0644\u0627\u0633<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">crawl<\/span>(<span class=\"hljs-params\">self, url: str, depth: int = <span class=\"hljs-number\">0<\/span><\/span>) -&gt; <span class=\"hljs-keyword\">None<\/span>:<\/span>\n    <span class=\"hljs-string\">\"\"\"\n    Crawl the website to discover pages and endpoints.\n\n    Args:\n        url: Current URL to crawl\n        depth: Current depth in the crawl tree\n    \"\"\"<\/span>\n    <span class=\"hljs-keyword\">if<\/span> depth &gt; self.max_depth <span class=\"hljs-keyword\">or<\/span> url <span class=\"hljs-keyword\">in<\/span> self.visited_urls:\n        <span class=\"hljs-keyword\">return<\/span>\n\n    <span class=\"hljs-keyword\">try<\/span>:\n        self.visited_urls.add(url)\n        response = self.session.get(url, verify=<span class=\"hljs-literal\">False<\/span>)\n        soup = BeautifulSoup(response.text, <span class=\"hljs-string\">'html.parser'<\/span>)\n\n        <span class=\"hljs-comment\"># Find all links in the page<\/span>\n        links = soup.find_all(<span class=\"hljs-string\">'a'<\/span>, href=<span class=\"hljs-literal\">True<\/span>)\n        <span class=\"hljs-keyword\">for<\/span> link <span class=\"hljs-keyword\">in<\/span> links:\n            next_url = urllib.parse.urljoin(url, link[<span class=\"hljs-string\">'href'<\/span>])\n            <span class=\"hljs-keyword\">if<\/span> next_url.startswith(self.target_url):\n                self.crawl(next_url, depth + <span class=\"hljs-number\">1<\/span>)\n\n    <span class=\"hljs-keyword\">except<\/span> Exception <span class=\"hljs-keyword\">as<\/span> e:\n        print(<span class=\"hljs-string\">f\"Error crawling <span class=\"hljs-subst\">{url}<\/span>: <span class=\"hljs-subst\">{str(e)}<\/span>\"<\/span>)\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 <code>crawl<\/code> \u062a\u0627\u0628\u0639 \u0628\u0647 \u0645\u0627 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u06cc\u06a9 \u062e\u0632\u06cc\u062f\u0646 \u062f\u0631 \u0639\u0645\u0642 \u06cc\u06a9 \u0648\u0628 \u0633\u0627\u06cc\u062a \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645. \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u062f\u0631 \u062f\u0627\u0645\u0646\u0647 \u0645\u0634\u062e\u0635 \u0634\u062f\u0647 \u0628\u0627\u0642\u06cc \u0645\u06cc \u0645\u0627\u0646\u062f\u060c \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0627\u062a \u06cc\u06a9 \u0648\u0628 \u0633\u0627\u06cc\u062a \u0631\u0627 \u06a9\u0627\u0648\u0634 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644\u060c \u0627\u06af\u0631 \u0642\u0635\u062f \u062f\u0627\u0631\u06cc\u062f \u0627\u0632 \u0627\u06cc\u0646 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc <code>https:\/\/google.com<\/code>\u060c \u0627\u0628\u062a\u062f\u0627 \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u0647\u0645\u0647 URL \u0647\u0627 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0633\u067e\u0633 \u06cc\u06a9 \u0628\u0647 \u06cc\u06a9 \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u0622\u0646\u0647\u0627 \u0628\u0647 \u062f\u0627\u0645\u0646\u0647 \u0645\u0634\u062e\u0635 \u0634\u062f\u0647 \u062a\u0639\u0644\u0642 \u062f\u0627\u0631\u0646\u062f (\u06cc\u0639\u0646\u06cc <code>google.com<\/code>). \u0627\u06af\u0631 \u0686\u0646\u06cc\u0646 \u0627\u0633\u062a\u060c \u0628\u0647 \u0635\u0648\u0631\u062a \u0628\u0627\u0632\u06af\u0634\u062a\u06cc \u0628\u0647 \u0627\u0633\u06a9\u0646 URL \u062f\u06cc\u062f\u0647 \u0634\u062f\u0647 \u062a\u0627 \u0639\u0645\u0642 \u0645\u0634\u062e\u0635\u06cc \u06a9\u0647 \u0628\u0627 <code>depth<\/code> \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u062a\u0627\u0628\u0639. \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u062e\u0637\u0627\u0647\u0627 \u0648 \u06af\u0632\u0627\u0631\u0634 \u0647\u0631 \u06af\u0648\u0646\u0647 \u062e\u0637\u0627 \u062f\u0631 \u062d\u06cc\u0646 \u062e\u0632\u06cc\u062f\u0646\u060c \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0633\u062a\u062b\u0646\u0627 \u062f\u0627\u0631\u06cc\u0645.<\/p>\n<h2 id=\"heading-designing-and-implementing-the-security-checks\"><span class=\"ez-toc-section\" id=\"%d8%b7%d8%b1%d8%a7%d8%ad%db%8c_%d9%88_%d8%a7%d8%ac%d8%b1%d8%a7%db%8c_%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%d9%87%d8%a7%db%8c_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c\"><\/span>\u0637\u0631\u0627\u062d\u06cc \u0648 \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a \u0628\u0647 \u0642\u0633\u0645\u062a \u0622\u0628\u062f\u0627\u0631 \u0628\u0631\u0633\u06cc\u0645 \u0648 \u0628\u0631\u0631\u0633\u06cc \u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u062e\u0648\u062f \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645. \u0627\u0628\u062a\u062f\u0627 \u0628\u0627 SQL Injection \u0634\u0631\u0648\u0639 \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<h3 id=\"heading-sql-injection-detection-check\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%d8%aa%d8%b4%d8%ae%db%8c%d8%b5_%d8%aa%d8%b2%d8%b1%db%8c%d9%82_sql\"><\/span>\u0628\u0631\u0631\u0633\u06cc \u062a\u0634\u062e\u06cc\u0635 \u062a\u0632\u0631\u06cc\u0642 SQL<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<pre><code class=\"lang-python\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">check_sql_injection<\/span>(<span class=\"hljs-params\">self, url: str<\/span>) -&gt; <span class=\"hljs-keyword\">None<\/span>:<\/span>\n    <span class=\"hljs-string\">\"\"\"Test for potential SQL injection vulnerabilities\"\"\"<\/span>\n    sql_payloads = [<span class=\"hljs-string\">\"'\"<\/span>, <span class=\"hljs-string\">\"1' OR '1'='1\"<\/span>, <span class=\"hljs-string\">\"' OR 1=1--\"<\/span>, <span class=\"hljs-string\">\"' UNION SELECT NULL--\"<\/span>]\n\n    <span class=\"hljs-keyword\">for<\/span> payload <span class=\"hljs-keyword\">in<\/span> sql_payloads:\n        <span class=\"hljs-keyword\">try<\/span>:\n            <span class=\"hljs-comment\"># Test GET parameters<\/span>\n            parsed = urllib.parse.urlparse(url)\n            params = urllib.parse.parse_qs(parsed.query)\n\n            <span class=\"hljs-keyword\">for<\/span> param <span class=\"hljs-keyword\">in<\/span> params:\n                test_url = url.replace(<span class=\"hljs-string\">f\"<span class=\"hljs-subst\">{param}<\/span>=<span class=\"hljs-subst\">{params[param][<span class=\"hljs-number\">0<\/span>]}<\/span>\"<\/span>, \n                                     <span class=\"hljs-string\">f\"<span class=\"hljs-subst\">{param}<\/span>=<span class=\"hljs-subst\">{payload}<\/span>\"<\/span>)\n                response = self.session.get(test_url)\n\n                <span class=\"hljs-comment\"># Look for SQL error messages<\/span>\n                <span class=\"hljs-keyword\">if<\/span> any(error <span class=\"hljs-keyword\">in<\/span> response.text.lower() <span class=\"hljs-keyword\">for<\/span> error <span class=\"hljs-keyword\">in<\/span> \n                    [<span class=\"hljs-string\">'sql'<\/span>, <span class=\"hljs-string\">'mysql'<\/span>, <span class=\"hljs-string\">'sqlite'<\/span>, <span class=\"hljs-string\">'postgresql'<\/span>, <span class=\"hljs-string\">'oracle'<\/span>]):\n                    self.report_vulnerability({\n                        <span class=\"hljs-string\">'type'<\/span>: <span class=\"hljs-string\">'SQL Injection'<\/span>,\n                        <span class=\"hljs-string\">'url'<\/span>: url,\n                        <span class=\"hljs-string\">'parameter'<\/span>: param,\n                        <span class=\"hljs-string\">'payload'<\/span>: payload\n                    })\n\n        <span class=\"hljs-keyword\">except<\/span> Exception <span class=\"hljs-keyword\">as<\/span> e:\n            print(<span class=\"hljs-string\">f\"Error testing SQL injection \u0631\u0648\u06cc <span class=\"hljs-subst\">{url}<\/span>: <span class=\"hljs-subst\">{str(e)}<\/span>\"<\/span>)\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u0627\u0633\u0627\u0633\u0627\u064b \u0628\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 URL \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u0628\u0627\u0631\u0647\u0627\u06cc \u0645\u062a\u062f\u0627\u0648\u0644 \u062a\u0632\u0631\u06cc\u0642 SQL \u0648 \u062c\u0633\u062a\u062c\u0648\u06cc \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062e\u0637\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0647 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0634\u0627\u0631\u0647 \u06a9\u0646\u062f\u060c \u0628\u0631\u0631\u0633\u06cc \u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647 \u062a\u0632\u0631\u06cc\u0642 SQL \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0628\u0631 \u0627\u0633\u0627\u0633 \u0631\u0648\u06cc \u067e\u06cc\u0627\u0645 \u062e\u0637\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0634\u062f\u0647 \u067e\u0633 \u0627\u0632 \u0627\u0646\u062c\u0627\u0645 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0633\u0627\u062f\u0647 GET \u0631\u0648\u06cc URL\u060c \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0622\u06cc\u0627 \u0622\u0646 \u067e\u06cc\u0627\u0645 \u06cc\u06a9 \u062e\u0637\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0627\u0633\u062a \u06cc\u0627 \u062e\u06cc\u0631. \u0627\u06af\u0631 \u0627\u06cc\u0646\u0637\u0648\u0631 \u0627\u0633\u062a\u060c \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>report_vulnerability<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f\u06cc \u0628\u0631\u0627\u06cc \u06af\u0632\u0627\u0631\u0634 \u0622\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0645\u0634\u06a9\u0644 \u0627\u0645\u0646\u06cc\u062a\u06cc \u062f\u0631 \u06af\u0632\u0627\u0631\u0634 \u0646\u0647\u0627\u06cc\u06cc \u0645\u0627 \u06a9\u0647 \u0627\u06cc\u0646 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u062f \u06a9\u0631\u062f. \u0628\u0647 \u062e\u0627\u0637\u0631 \u0627\u06cc\u0646 \u0645\u062b\u0627\u0644\u060c \u0645\u0627 \u0686\u0646\u062f \u0628\u0627\u0631 \u062a\u0632\u0631\u06cc\u0642 SQL \u0631\u0627 \u06a9\u0647 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645\u060c \u0627\u0645\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u06cc\u0646 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 \u0628\u06cc\u0634\u062a\u0631 \u06af\u0633\u062a\u0631\u0634 \u062f\u0647\u06cc\u062f.<\/p>\n<h3 id=\"heading-xss-cross-site-scripting-check\"><span class=\"ez-toc-section\" id=\"xss_cross-site_scripting_%d8%b1%d8%a7_%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%da%a9%d9%86%db%8c%d8%af\"><\/span>XSS (Cross-Site Scripting) \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u062f\u0648\u0645\u06cc\u0646 \u0628\u0631\u0631\u0633\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0627\u0631\u0647\u0627\u06cc XSS \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">check_xss<\/span>(<span class=\"hljs-params\">self, url: str<\/span>) -&gt; <span class=\"hljs-keyword\">None<\/span>:<\/span>\n    <span class=\"hljs-string\">\"\"\"Test for potential Cross-Site Scripting vulnerabilities\"\"\"<\/span>\n    xss_payloads = [\n        <span class=\"hljs-string\">\"&lt;script&gt;alert('XSS')&lt;\/script&gt;\"<\/span>,\n        <span class=\"hljs-string\">\"&lt;img src=x onerror=alert('XSS')&gt;\"<\/span>,\n        <span class=\"hljs-string\">\"javascript:alert('XSS')\"<\/span>\n    ]\n\n    <span class=\"hljs-keyword\">for<\/span> payload <span class=\"hljs-keyword\">in<\/span> xss_payloads:\n        <span class=\"hljs-keyword\">try<\/span>:\n            <span class=\"hljs-comment\"># Test GET parameters<\/span>\n            parsed = urllib.parse.urlparse(url)\n            params = urllib.parse.parse_qs(parsed.query)\n\n            <span class=\"hljs-keyword\">for<\/span> param <span class=\"hljs-keyword\">in<\/span> params:\n                test_url = url.replace(<span class=\"hljs-string\">f\"<span class=\"hljs-subst\">{param}<\/span>=<span class=\"hljs-subst\">{params[param][<span class=\"hljs-number\">0<\/span>]}<\/span>\"<\/span>, \n                                     <span class=\"hljs-string\">f\"<span class=\"hljs-subst\">{param}<\/span>=<span class=\"hljs-subst\">{urllib.parse.quote(payload)}<\/span>\"<\/span>)\n                response = self.session.get(test_url)\n\n                <span class=\"hljs-keyword\">if<\/span> payload <span class=\"hljs-keyword\">in<\/span> response.text:\n                    self.report_vulnerability({\n                        <span class=\"hljs-string\">'type'<\/span>: <span class=\"hljs-string\">'Cross-Site Scripting (XSS)'<\/span>,\n                        <span class=\"hljs-string\">'url'<\/span>: url,\n                        <span class=\"hljs-string\">'parameter'<\/span>: param,\n                        <span class=\"hljs-string\">'payload'<\/span>: payload\n                    })\n\n        <span class=\"hljs-keyword\">except<\/span> Exception <span class=\"hljs-keyword\">as<\/span> e:\n            print(<span class=\"hljs-string\">f\"Error testing XSS \u0631\u0648\u06cc <span class=\"hljs-subst\">{url}<\/span>: <span class=\"hljs-subst\">{str(e)}<\/span>\"<\/span>)\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u062a\u0627\u0628\u0639\u060c \u062f\u0631\u0633\u062a \u0645\u0627\u0646\u0646\u062f \u062a\u0633\u062a\u0631 \u062a\u0632\u0631\u06cc\u0642 SQL\u060c \u0627\u0632 \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u0628\u0627\u0631\u0647\u0627\u06cc \u0645\u062a\u062f\u0627\u0648\u0644 XSS \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0647\u0645\u0627\u0646 \u0627\u06cc\u062f\u0647 \u0631\u0627 \u0627\u0639\u0645\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f. \u0627\u0645\u0627 \u062a\u0641\u0627\u0648\u062a \u0627\u0635\u0644\u06cc \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0628\u0647\u200c\u062c\u0627\u06cc \u062c\u0633\u062a\u062c\u0648\u06cc \u067e\u06cc\u063a\u0627\u0645 \u062e\u0637\u0627 \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u0627\u06cc\u0646 \u0647\u0633\u062a\u06cc\u0645 \u06a9\u0647 \u0628\u0627\u0631 \u062a\u0632\u0631\u06cc\u0642\u06cc\u200c\u0645\u0627\u0646 \u062f\u0631 \u067e\u0627\u0633\u062e \u0645\u0627 \u0628\u062f\u0648\u0646 \u062a\u063a\u06cc\u06cc\u0631 \u0638\u0627\u0647\u0631 \u0634\u0648\u062f.<\/p>\n<p>\u0627\u06af\u0631 \u0628\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627\u0631 \u062a\u0632\u0631\u06cc\u0642 \u0634\u062f\u0647 \u0645\u0627 \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f\u060c \u0628\u0647 \u0627\u062d\u062a\u0645\u0627\u0644 \u0632\u06cc\u0627\u062f \u062f\u0631 \u0632\u0645\u06cc\u0646\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u0642\u0631\u0628\u0627\u0646\u06cc \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u062d\u0645\u0644\u0647 XSS \u0645\u0646\u0639\u06a9\u0633 \u0634\u062f\u0647 \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<h3 id=\"heading-sensitive-information-exposure-check\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%d9%82%d8%b1%d8%a7%d8%b1_%da%af%d8%b1%d9%81%d8%aa%d9%86_%d8%af%d8%b1_%d9%85%d8%b9%d8%b1%d8%b6_%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa_%d8%ad%d8%b3%d8%a7%d8%b3\"><\/span>\u0628\u0631\u0631\u0633\u06cc \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0646 \u062f\u0631 \u0645\u0639\u0631\u0636 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u0646\u0647\u0627\u06cc\u06cc \u062e\u0648\u062f \u0631\u0627 \u0628\u0631\u0627\u06cc PII \u062d\u0633\u0627\u0633 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645.<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">check_sensitive_info<\/span>(<span class=\"hljs-params\">self, url: str<\/span>) -&gt; <span class=\"hljs-keyword\">None<\/span>:<\/span>\n    <span class=\"hljs-string\">\"\"\"Check for exposed sensitive information\"\"\"<\/span>\n    sensitive_patterns = {\n        <span class=\"hljs-string\">'email'<\/span>: <span class=\"hljs-string\">r'[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}'<\/span>,\n        <span class=\"hljs-string\">'phone'<\/span>: <span class=\"hljs-string\">r'\\b\\d{3}[-.]?\\d{3}[-.]?\\d{4}\\b'<\/span>,\n        <span class=\"hljs-string\">'ssn'<\/span>: <span class=\"hljs-string\">r'\\b\\d{3}-\\d{2}-\\d{4}\\b'<\/span>,\n        <span class=\"hljs-string\">'api_key'<\/span>: <span class=\"hljs-string\">r'api[_-]?key[_-]?([\\'\"|`])([a-zA-Z0-9]{32,45})\\1'<\/span>\n    }\n\n    <span class=\"hljs-keyword\">try<\/span>:\n        response = self.session.get(url)\n\n        <span class=\"hljs-keyword\">for<\/span> info_type, pattern <span class=\"hljs-keyword\">in<\/span> sensitive_patterns.items():\n            matches = re.finditer(pattern, response.text)\n            <span class=\"hljs-keyword\">for<\/span> match <span class=\"hljs-keyword\">in<\/span> matches:\n                self.report_vulnerability({\n                    <span class=\"hljs-string\">'type'<\/span>: <span class=\"hljs-string\">'Sensitive Information Exposure'<\/span>,\n                    <span class=\"hljs-string\">'url'<\/span>: url,\n                    <span class=\"hljs-string\">'info_type'<\/span>: info_type,\n                    <span class=\"hljs-string\">'pattern'<\/span>: pattern\n                })\n\n    <span class=\"hljs-keyword\">except<\/span> Exception <span class=\"hljs-keyword\">as<\/span> e:\n        print(<span class=\"hljs-string\">f\"Error checking sensitive information \u0631\u0648\u06cc <span class=\"hljs-subst\">{url}<\/span>: <span class=\"hljs-subst\">{str(e)}<\/span>\"<\/span>)\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u0627\u0632 \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u0627\u0644\u06af\u0648\u0647\u0627\u06cc Regex \u0627\u0632 \u067e\u06cc\u0634 \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0628\u0631\u0627\u06cc \u062c\u0633\u062a\u062c\u0648\u06cc PII \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0645\u06cc\u0644\u060c \u0634\u0645\u0627\u0631\u0647 \u062a\u0644\u0641\u0646\u060c SSN \u0648 \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc API (\u06a9\u0647 \u0628\u0627 api-key-<number> \u067e\u06cc\u0634\u0648\u0646\u062f \u0647\u0633\u062a\u0646\u062f) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631\u0633\u062a \u0645\u0627\u0646\u0646\u062f \u062f\u0648 \u062a\u0627\u0628\u0639 \u0642\u0628\u0644\u06cc\u060c \u0645\u0627 \u0627\u0632 \u0645\u062a\u0646 \u067e\u0627\u0633\u062e \u0628\u0631\u0627\u06cc URL \u0648 \u0627\u0644\u06af\u0648\u0647\u0627\u06cc Regex \u062e\u0648\u062f \u0628\u0631\u0627\u06cc \u06cc\u0627\u0641\u062a\u0646 \u0627\u06cc\u0646 PII \u0647\u0627 \u062f\u0631 \u0645\u062a\u0646 \u067e\u0627\u0633\u062e \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0627\u06af\u0631 \u0645\u0648\u0631\u062f\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0631\u062f\u06cc\u0645\u060c \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0627 <code>report_vulnerability<\/code> \u062a\u0627\u0628\u0639 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0647\u0645\u0647 \u0627\u06cc\u0646 \u062a\u0648\u0627\u0628\u0639 \u062f\u0631 \u0622\u0646 \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0627\u0646\u062f <code>WebSecurityScanner<\/code> \u06a9\u0644\u0627\u0633<\/p>\n<h2 id=\"heading-implementing-the-main-scanning-logic\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%85%d9%86%d8%b7%d9%82_%d8%a7%d8%b5%d9%84%db%8c_%d8%a7%d8%b3%da%a9%d9%86\"><\/span>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0645\u0646\u0637\u0642 \u0627\u0635\u0644\u06cc \u0627\u0633\u06a9\u0646<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0631\u0627 \u0628\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0631\u062f\u0646 \u0628\u0647 \u0647\u0645 \u0628\u0686\u0633\u0628\u0627\u0646\u06cc\u0645 <code>scan<\/code> \u0648 <code>report_vulnerability<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f \u062f\u0631 <code>WebSecurityScanner<\/code> \u06a9\u0644\u0627\u0633:<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">scan<\/span>(<span class=\"hljs-params\">self<\/span>) -&gt; List[Dict]:<\/span>\n    <span class=\"hljs-string\">\"\"\"\n    Main scanning method that coordinates the security checks\n\n    Returns:\n        List of discovered vulnerabilities\n    \"\"\"<\/span>\n    print(<span class=\"hljs-string\">f\"\\n<span class=\"hljs-subst\">{colorama.Fore.BLUE}<\/span>Starting security scan of <span class=\"hljs-subst\">{self.target_url}<\/span><span class=\"hljs-subst\">{colorama.Style.RESET_ALL}<\/span>\\n\"<\/span>)\n\n    <span class=\"hljs-comment\"># First, crawl the website<\/span>\n    self.crawl(self.target_url)\n\n    <span class=\"hljs-comment\"># Then run security checks \u0631\u0648\u06cc all discovered URLs<\/span>\n    <span class=\"hljs-keyword\">with<\/span> ThreadPoolExecutor(max_workers=<span class=\"hljs-number\">5<\/span>) <span class=\"hljs-keyword\">as<\/span> executor:\n        <span class=\"hljs-keyword\">for<\/span> url <span class=\"hljs-keyword\">in<\/span> self.visited_urls:\n            executor.submit(self.check_sql_injection, url)\n            executor.submit(self.check_xss, url)\n            executor.submit(self.check_sensitive_info, url)\n\n    <span class=\"hljs-keyword\">return<\/span> self.vulnerabilities\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">def<\/span> <span class=\"hljs-title\">report_vulnerability<\/span>(<span class=\"hljs-params\">self, vulnerability: Dict<\/span>) -&gt; <span class=\"hljs-keyword\">None<\/span>:<\/span>\n    <span class=\"hljs-string\">\"\"\"Record and display found vulnerabilities\"\"\"<\/span>\n    self.vulnerabilities.append(vulnerability)\n    print(<span class=\"hljs-string\">f\"<span class=\"hljs-subst\">{colorama.Fore.RED}<\/span>[VULNERABILITY FOUND]<span class=\"hljs-subst\">{colorama.Style.RESET_ALL}<\/span>\"<\/span>)\n    <span class=\"hljs-keyword\">for<\/span> key, value <span class=\"hljs-keyword\">in<\/span> vulnerability.items():\n        print(<span class=\"hljs-string\">f\"<span class=\"hljs-subst\">{key}<\/span>: <span class=\"hljs-subst\">{value}<\/span>\"<\/span>)\n    print()\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u06a9\u062f \u0645\u0627 \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u062f <code>scan<\/code> \u062a\u0627\u0628\u0639\u06cc \u06a9\u0647 \u0627\u0633\u0627\u0633\u0627\u064b \u0622\u0646 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f <code>crawl<\/code> \u06a9\u0627\u0631 \u06a9\u0631\u062f\u0647 \u0648 \u0628\u0647 \u0635\u0648\u0631\u062a \u0628\u0627\u0632\u06af\u0634\u062a\u06cc \u0634\u0631\u0648\u0639 \u0628\u0647 \u062e\u0632\u06cc\u062f\u0646 \u062f\u0631 \u0648\u0628 \u0633\u0627\u06cc\u062a \u06a9\u0646\u06cc\u062f. \u0628\u0627 multithreading\u060c \u0647\u0631 \u0633\u0647 \u0628\u0631\u0631\u0633\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0631\u0627 \u0627\u0639\u0645\u0627\u0644 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f \u0631\u0648\u06cc URL \u0647\u0627\u06cc \u0628\u0627\u0632\u062f\u06cc\u062f \u0634\u062f\u0647<\/p>\n<p>\u0645\u0627 \u0646\u06cc\u0632 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <code>report_vulnerability<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f\u06cc \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u0645\u0648\u062b\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f print \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0645\u0627 \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 console \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u0645\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f <code>vulnerabilities<\/code> \u0622\u0631\u0627\u06cc\u0647<\/p>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a \u0627\u0632 \u0627\u0633\u06a9\u0646\u0631 \u062e\u0648\u062f \u0628\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0622\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>scanner.py<\/code>:<\/p>\n<pre><code class=\"lang-python\"><span class=\"hljs-keyword\">if<\/span> __name__ == <span class=\"hljs-string\">\"__main__\"<\/span>:\n    <span class=\"hljs-keyword\">if<\/span> len(sys.argv) != <span class=\"hljs-number\">2<\/span>:\n        print(<span class=\"hljs-string\">\"Usage: python scanner.py &lt;target_url&gt;\"<\/span>)\n        sys.exit(<span class=\"hljs-number\">1<\/span>)\n\n    target_url = sys.argv[<span class=\"hljs-number\">1<\/span>]\n    scanner = WebSecurityScanner(target_url)\n    vulnerabilities = scanner.scan()\n\n    <span class=\"hljs-comment\"># Print summary<\/span>\n    print(<span class=\"hljs-string\">f\"\\n<span class=\"hljs-subst\">{colorama.Fore.GREEN}<\/span>Scan Complete!<span class=\"hljs-subst\">{colorama.Style.RESET_ALL}<\/span>\"<\/span>)\n    print(<span class=\"hljs-string\">f\"Total URLs scanned: <span class=\"hljs-subst\">{len(scanner.visited_urls)}<\/span>\"<\/span>)\n    print(<span class=\"hljs-string\">f\"Vulnerabilities found: <span class=\"hljs-subst\">{len(vulnerabilities)}<\/span>\"<\/span>)\n<\/code><\/pre>\n<p>URL \u0647\u062f\u0641 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u0633\u06cc\u0633\u062a\u0645 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0645\u0627 \u062e\u0644\u0627\u0635\u0647 \u0627\u06cc \u0627\u0632 URL \u0647\u0627\u06cc \u0627\u0633\u06a9\u0646 \u0634\u062f\u0647 \u0648 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0647\u0627\u06cc \u06cc\u0627\u0641\u062a \u0634\u062f\u0647 \u0631\u0627 \u062f\u0631 \u067e\u0627\u06cc\u0627\u0646 \u0627\u0633\u06a9\u0646 \u062e\u0648\u062f \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0627\u06a9\u0646\u0648\u0646 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u062f\u0631 \u0645\u0648\u0631\u062f \u0686\u06af\u0648\u0646\u06af\u06cc \u06af\u0633\u062a\u0631\u0634 \u0627\u0633\u06a9\u0646\u0631 \u0648 \u0627\u0641\u0632\u0648\u062f\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0628\u06cc\u0634\u062a\u0631 \u0628\u062d\u062b \u06a9\u0646\u06cc\u0645.<\/p>\n<h2 id=\"heading-extending-the-security-scanner\"><span class=\"ez-toc-section\" id=\"%da%af%d8%b3%d8%aa%d8%b1%d8%b4_%d8%a7%d8%b3%da%a9%d9%86%d8%b1_%d8%a7%d9%85%d9%86%db%8c%d8%aa%db%8c\"><\/span>\u06af\u0633\u062a\u0631\u0634 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0686\u0646\u062f \u0627\u06cc\u062f\u0647 \u0628\u0631\u0627\u06cc \u06af\u0633\u062a\u0631\u0634 \u0627\u06cc\u0646 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0633\u0627\u0633\u06cc \u0628\u0647 \u0686\u06cc\u0632\u06cc \u062d\u062a\u06cc \u067e\u06cc\u0634\u0631\u0641\u062a\u0647 \u062a\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f:<\/p>\n<ol>\n<li>\n<p>\u0628\u0631\u0631\u0633\u06cc\u200c\u0647\u0627\u06cc \u0622\u0633\u06cc\u0628\u200c\u067e\u0630\u06cc\u0631\u06cc \u0628\u06cc\u0634\u062a\u0631\u06cc \u0645\u0627\u0646\u0646\u062f \u062a\u0634\u062e\u06cc\u0635 CSRF\u060c \u067e\u06cc\u0645\u0627\u06cc\u0634 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0648 \u063a\u06cc\u0631\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc.<\/p>\n<\/li>\n<li>\n<p>\u0628\u0647\u0628\u0648\u062f \u06af\u0632\u0627\u0631\u0634 \u0628\u0627 \u062e\u0631\u0648\u062c\u06cc HTML \u06cc\u0627 PDF.<\/p>\n<\/li>\n<li>\n<p>\u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0634\u062f\u062a \u0627\u0633\u06a9\u0646 \u0648 \u062f\u0627\u0645\u0646\u0647 \u062c\u0633\u062a\u062c\u0648 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f (\u062a\u0639\u06cc\u06cc\u0646 \u0639\u0645\u0642 \u0627\u0633\u06a9\u0646 \u0647\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 CLI).<\/p>\n<\/li>\n<li>\n<p>\u0627\u062c\u0631\u0627\u06cc \u0645\u062d\u062f\u0648\u062f \u06a9\u0631\u062f\u0646 \u0646\u0631\u062e \u0645\u0646\u0627\u0633\u0628<\/p>\n<\/li>\n<li>\n<p>\u0627\u0641\u0632\u0648\u062f\u0646 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0628\u0631\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634 URL \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062c\u0644\u0633\u0647 \u062f\u0627\u0631\u0646\u062f.<\/p>\n<\/li>\n<\/ol>\n<h2 id=\"heading-wrapping-up\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%b3%d8%aa%d9%87_%d8%a8%d9%86%d8%af%db%8c\"><\/span>\u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062f\u0627\u0646\u06cc\u062f \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0628\u0633\u0627\u0632\u06cc\u062f! \u0627\u06cc\u0646 \u0627\u0633\u06a9\u0646\u0631 \u0686\u0646\u062f \u0645\u0641\u0647\u0648\u0645 \u0627\u0635\u0644\u06cc \u0627\u0645\u0646\u06cc\u062a \u0648\u0628 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0628\u0647 \u062e\u0627\u0637\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0641\u0642\u0637 \u0628\u0627\u06cc\u062f \u0628\u0631\u0627\u06cc \u0627\u0647\u062f\u0627\u0641 \u0622\u0645\u0648\u0632\u0634\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f. \u0686\u0646\u062f\u06cc\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u062d\u0631\u0641\u0647 \u0627\u06cc \u062f\u0631 \u0633\u0637\u062d \u0633\u0627\u0632\u0645\u0627\u0646\u06cc \u0645\u0627\u0646\u0646\u062f Burp Suite \u0648 OWASP Zap \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0635\u062f\u0647\u0627 \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u0631\u0627 \u062f\u0631 \u0645\u0642\u06cc\u0627\u0633\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0628\u0632\u0631\u06af\u062a\u0631 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0627\u0645\u06cc\u062f\u0648\u0627\u0631\u0645 \u0627\u0635\u0648\u0644 \u0627\u0648\u0644\u06cc\u0647 \u0627\u0645\u0646\u06cc\u062a \u0648\u0628 \u0648 \u06a9\u0645\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u0631\u0627 \u0646\u06cc\u0632 \u06cc\u0627\u062f \u06af\u0631\u0641\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f.<\/p>\n<\/section>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-12-12 23:44:14<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;18367&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;\u0633\u0627\u062e\u062a \u06cc\u06a9 \u0627\u0633\u06a9\u0646\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0633\u0627\u062f\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0628\u0627 \u067e\u0627\u06cc\u062a\u0648\u0646: \u0631\u0627\u0647\u0646\u0645\u0627\u06cc \u0645\u0628\u062a\u062f\u06cc\u0627\u0646&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>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u06cc\u0627\u062f \u0628\u06af\u06cc\u0631\u06cc\u062f \u06a9\u0647 \u06cc\u06a9 \u0627\u0628\u0632\u0627\u0631 \u0627\u0645\u0646\u06cc\u062a\u06cc \u0627\u0633\u0627\u0633\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062f\u0631 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0622\u0633\u06cc\u0628 \u067e\u0630\u06cc\u0631\u06cc \u0647\u0627\u06cc \u0631\u0627\u06cc\u062c \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0645\u0641\u06cc\u062f \u0628\u0627\u0634\u062f. \u0645\u0646 \u0627\u06cc\u0646\u062c\u0627 \u062f\u0648 \u0647\u062f\u0641 \u062f\u0627\u0631\u0645. \u0627\u0648\u0644\u06cc\u0646 \u0645\u0648\u0631\u062f \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0634\u0645\u0627 \u0631\u0627 \u0628\u0627 \u0645\u0647\u0627\u0631\u062a \u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0628\u0647\u0628\u0648\u062f \u0648\u0636\u0639\u06cc\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc [&hellip;]<\/p>\n","protected":false},"author":6,"featured_media":18368,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1743],"tags":[1748,1958,1925,1938,1920,1926,5721,531,1779,1909,1744,1759,2134,2007,1755,1957,2829,1813],"class_list":["post-18367","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-python","tag-python-hosting","tag-1958","tag----django","tag-1938","tag-1920","tag-1926","tag-5721","tag-531","tag-1779","tag-1909","tag-1744","tag-1759","tag-2134","tag-2007","tag-1755","tag-1957","tag-2829","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/18367","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=18367"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/18367\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/18368"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=18367"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=18367"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=18367"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}