{"id":16575,"date":"2024-12-28T09:53:22","date_gmt":"2024-12-28T06:23:22","guid":{"rendered":"https:\/\/www.itpiran.net\/blog\/?p=16575"},"modified":"2024-12-28T09:53:22","modified_gmt":"2024-12-28T06:23:22","slug":"use-these-nodejs-packages-to-prevent-common-security-vulnerabilities","status":"publish","type":"post","link":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/","title":{"rendered":"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc"},"content":{"rendered":"<h2 id=\"%d9%85%d9%82%d8%af%d9%85%d9%87\">\u0645\u0642\u062f\u0645\u0647<\/h2>\n<p>\u0627\u0645\u0646\u06cc\u062a API \u0628\u0647 \u0645\u0639\u0646\u0627\u06cc \u062d\u0641\u0627\u0638\u062a \u0627\u0632 \u06cc\u06a9\u067e\u0627\u0631\u0686\u06af\u06cc API\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06cc\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645. \u0627\u0645\u0631\u0648\u0632\u0647 \u0628\u06cc\u0634\u062a\u0631 \u0634\u0631\u06a9\u062a\u200c\u0647\u0627 \u0627\u0632 API \u0628\u0631\u0627\u06cc \u0627\u062a\u0635\u0627\u0644 \u062e\u062f\u0645\u0627\u062a \u0648 \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0627\u06af\u0631 API \u062f\u0686\u0627\u0631 \u0645\u0634\u06a9\u0644\u060c \u0627\u0641\u0634\u0627 \u06cc\u0627 \u0647\u06a9 \u0634\u0648\u062f\u060c \u0645\u0646\u062c\u0631 \u0628\u0647 \u0646\u0642\u0636 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f. \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0628\u0631 \u0627\u0633\u0627\u0633 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0646\u062a\u0642\u0627\u0644\u200c\u06cc\u0627\u0641\u062a\u0647\u060c \u0628\u0627\u06cc\u062f \u0633\u0637\u062d \u0627\u0645\u0646\u06cc\u062a API \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0628\u0631\u0627\u06cc \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u062f\u0631 \u0646\u0638\u0631 \u0628\u06af\u06cc\u0631\u06cc\u0645. \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0686\u0646\u062f \u067e\u06a9\u06cc\u062c \u0645\u0641\u06cc\u062f npm \u0631\u0627 \u06a9\u0647 \u0628\u0647 \u0645\u0627 \u06a9\u0645\u06a9 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u062a\u0627 \u0627\u0632 \u0645\u0634\u06a9\u0644\u0627\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0631\u0627\u06cc\u062c \u0627\u062c\u062a\u0646\u0627\u0628 \u06a9\u0646\u06cc\u0645\u060c \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc\u200c\u06a9\u0646\u0645.<\/p>\n<h2 id=\"%db%b1-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-helmet\">\u06f1. \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Helmet<\/h2>\n<p><strong>Helmet.js<\/strong> \u06cc\u06a9 \u0645\u0627\u0698\u0648\u0644 Node.js \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u062d\u0641\u0627\u0638\u062a \u0627\u0632 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f. \u0627\u06cc\u0646 \u0645\u0627\u0698\u0648\u0644 \u062f\u0631 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646\u200c\u0647\u0627\u06cc Express \u06a9\u0627\u0631\u0628\u0631\u062f \u062f\u0627\u0631\u062f \u0648 \u0628\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0647\u062f\u0631\u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 HTTP\u060c \u0627\u0632 \u062d\u0645\u0644\u0627\u062a\u06cc \u0646\u0638\u06cc\u0631 Cross-Site Scripting (XSS) \u0648 Clickjacking \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<h5 id=\"%da%86%d8%b1%d8%a7-%d8%ad%d9%81%d8%a7%d8%b8%d8%aa-%d8%a7%d8%b2-%d9%87%d8%af%d8%b1%d9%87%d8%a7%db%8c-http-%d9%85%d9%87%d9%85-%d8%a7%d8%b3%d8%aa%d8%9f\">\u0686\u0631\u0627 \u062d\u0641\u0627\u0638\u062a \u0627\u0632 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u0645\u0647\u0645 \u0627\u0633\u062a\u061f<\/h5>\n<p>\u0627\u063a\u0644\u0628 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0647 \u0647\u062f\u0631\u0647\u0627\u06cc HTTP \u0628\u06cc\u200c\u062a\u0648\u062c\u0647 \u0647\u0633\u062a\u0646\u062f. \u0627\u06cc\u0646 \u0647\u062f\u0631\u0647\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633\u06cc \u062f\u0631\u0628\u0627\u0631\u0647 \u0633\u0631\u0648\u0631\u060c \u0646\u0633\u062e\u0647 \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631 \u0648 \u062d\u062a\u06cc \u0633\u0627\u062e\u062a\u0627\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0627\u0641\u0634\u0627 \u06a9\u0646\u0646\u062f. \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f Helmet.js \u0627\u0647\u0645\u06cc\u062a \u0632\u06cc\u0627\u062f\u06cc \u062f\u0627\u0631\u062f.<\/p>\n<h5 id=\"%d9%85%d8%a7%da%98%d9%88%d9%84%d9%87%d8%a7%db%8c-%d9%85%d9%87%d9%85-helmet-js\">\u0645\u0627\u0698\u0648\u0644\u200c\u0647\u0627\u06cc \u0645\u0647\u0645 Helmet.js<\/h5>\n<ul>\n<li><strong>X-Frame-Options:<\/strong> \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 Clickjacking \u0628\u0627 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u0646\u0645\u0627\u06cc\u0634 \u0635\u0641\u062d\u0627\u062a \u062f\u0631 iFrame.<\/li>\n<li><strong>Content-Security-Policy:<\/strong> \u062a\u0646\u0638\u06cc\u0645 \u0633\u06cc\u0627\u0633\u062a \u0627\u0645\u0646\u06cc\u062a\u06cc \u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062a\u0632\u0631\u06cc\u0642 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u200c\u0647\u0627\u06cc \u063a\u06cc\u0631\u0645\u062c\u0627\u0632.<\/li>\n<li><strong>Cache-Control:<\/strong> \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u06a9\u0634 \u0633\u0645\u062a \u06a9\u0644\u0627\u06cc\u0646\u062a \u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633.<\/li>\n<li><strong>Expect-CT:<\/strong> \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0634\u0641\u0627\u0641\u06cc\u062a \u06af\u0648\u0627\u0647\u06cc SSL.<\/li>\n<li><strong>X-Powered-By:<\/strong> \u062d\u0630\u0641 \u0647\u062f\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0646\u0631\u0645\u200c\u0627\u0641\u0632\u0627\u0631 \u0633\u0631\u0648\u0631 \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc\u200c\u062f\u0647\u0646\u062f.<\/li>\n<li><strong>X-XSS-Protection:<\/strong> \u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0645\u062d\u0627\u0641\u0638\u062a \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062d\u0645\u0644\u0627\u062a XSS \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627.<\/li>\n<li><strong>Strict-Transport-Security:<\/strong> \u0645\u062c\u0628\u0648\u0631 \u06a9\u0631\u062f\u0646 \u0645\u0631\u0648\u0631\u06af\u0631 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 HTTPS.<\/li>\n<\/ul>\n<blockquote>\n<h5 id=\"%d8%a8%d8%b1%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-helmet-js-%da%a9%d8%a7%d9%81%db%8c%d8%b3%d8%aa-%d8%a7%db%8c%d9%86-%d9%85%d8%a7%da%98%d9%88%d9%84-%d8%b1%d8%a7-%d9%86\">\u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u06a9\u0627\u0631 \u0628\u0627 Helmet.js \u06a9\u0627\u0641\u06cc\u0633\u062a \u0627\u06cc\u0646 \u0645\u0627\u0698\u0648\u0644 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0631\u062f\u0647 \u0648 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 Express \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/h5>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>const helmet = require('helmet');\r\nconst express = require('express');\r\nconst app = express();\r\napp.use(helmet());<\/code><\/pre>\n<\/div>\n<\/blockquote>\n<h2 id=\"%db%b2-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%db%8c%d9%85%d9%86-%d8%a7%d8%b2-%da%a9%d9%88%da%a9%db%8c%d9%87%d8%a7\">\u06f2. \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u06cc\u0645\u0646 \u0627\u0632 \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627<\/h2>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627 \u0628\u0627\u0639\u062b \u0622\u0633\u06cc\u0628\u200c\u067e\u0630\u06cc\u0631\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0645\u06cc\u200c\u0634\u0648\u0646\u062f\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0646\u0627\u0645 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627\u06cc \u062c\u0644\u0633\u0647 \u0631\u0627 \u0645\u062a\u0648\u0642\u0641 \u06a9\u0646\u06cc\u062f \u0648 \u06af\u0632\u06cc\u0646\u0647\u200c\u0647\u0627\u06cc \u0627\u0645\u0646\u06cc\u062a\u06cc \u06a9\u0648\u06a9\u06cc \u0631\u0627 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f.<\/p>\n<h5 id=\"%d9%85%d8%b4%da%a9%d9%84%d8%a7%d8%aa-%d8%b1%d8%a7%db%8c%d8%ac-%da%a9%d9%88%da%a9%db%8c%d9%87%d8%a7\">\u0645\u0634\u06a9\u0644\u0627\u062a \u0631\u0627\u06cc\u062c \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627<\/h5>\n<p>\u0627\u06af\u0631 \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u062a\u0646\u0638\u06cc\u0645 \u0646\u0634\u0648\u0646\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0647\u062f\u0627\u0641\u06cc \u0633\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u062d\u0645\u0644\u0627\u062a Cross-Site Scripting \u06cc\u0627 \u0627\u0641\u0634\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0634\u0648\u0646\u062f. \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u062f\u0642\u06cc\u0642 \u0628\u0631\u0627\u06cc \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627 \u0627\u06cc\u0646 \u062e\u0637\u0631\u0627\u062a \u0631\u0627 \u06a9\u0627\u0647\u0634 \u0645\u06cc\u200c\u062f\u0647\u062f.<\/p>\n<h5 id=\"%d8%aa%d9%86%d8%b8%db%8c%d9%85%d8%a7%d8%aa-%d9%be%db%8c%d8%b4%d9%86%d9%87%d8%a7%d8%af%db%8c\">\u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc<\/h5>\n<ul>\n<li><strong>secure:<\/strong> \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627 \u0641\u0642\u0637 \u0627\u0632 \u0637\u0631\u06cc\u0642 HTTPS.<\/li>\n<li><strong>httpOnly:<\/strong> \u0645\u062d\u062f\u0648\u062f \u06a9\u0631\u062f\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627 \u0628\u0647 \u062c\u0627\u0648\u0627\u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0633\u0645\u062a \u06a9\u0644\u0627\u06cc\u0646\u062a.<\/li>\n<li><strong>domain:<\/strong> \u0645\u0634\u062e\u0635 \u06a9\u0631\u062f\u0646 \u062f\u0627\u0645\u0646\u0647 \u0645\u0639\u062a\u0628\u0631 \u0628\u0631\u0627\u06cc \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627.<\/li>\n<li><strong>path:<\/strong> \u0645\u062d\u062f\u0648\u062f \u06a9\u0631\u062f\u0646 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627 \u0645\u0639\u062a\u0628\u0631 \u0647\u0633\u062a\u0646\u062f.<\/li>\n<li><strong>expires:<\/strong> \u062a\u0639\u06cc\u06cc\u0646 \u062a\u0627\u0631\u06cc\u062e \u0627\u0646\u0642\u0636\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0648\u06a9\u06cc\u200c\u0647\u0627\u06cc \u067e\u0627\u06cc\u062f\u0627\u0631.<\/li>\n<\/ul>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>const session = require('cookie-session');\r\nconst express = require('express');\r\nconst app = express();\r\nconst expiryDate = new Date(Date.now() + 60 * 60 * 1000); \/\/ 1 \u0633\u0627\u0639\u062a\r\napp.use(session({\r\nname: 'session',\r\nkeys: ['key1', 'key2'],\r\ncookie: {\r\nsecure: true,\r\nhttpOnly: true,\r\ndomain: 'example.com',\r\npath: 'foo\/bar',\r\nexpires: expiryDate\r\n}\r\n}));<\/code><\/pre>\n<\/div>\n<h2 id=\"%db%b3-prevent-nosql-injections\">\u06f3. Prevent NoSQL injections<\/h2>\n<p>\u062a\u0632\u0631\u06cc\u0642 NoSQL \u06cc\u06a9\u06cc \u0627\u0632 \u062d\u0645\u0644\u0627\u062a \u0631\u0627\u06cc\u062c \u062f\u0631 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646\u200c\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0627\u0632 \u067e\u0627\u06cc\u06af\u0627\u0647\u200c\u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc NoSQL \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0627\u06cc\u0646 \u062d\u0645\u0644\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0647 \u0645\u0647\u0627\u062c\u0645 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u062f \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062d\u0633\u0627\u0633 \u0631\u0627 \u0627\u0633\u062a\u062e\u0631\u0627\u062c \u06a9\u0646\u062f.<\/p>\n<h5 id=\"%d8%b1%d8%a7%d9%87%d8%ad%d9%84\">\u0631\u0627\u0647\u200c\u062d\u0644<\/h5>\n<p>\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u06a9\u06cc\u062c <strong>express-mongo-sanitize<\/strong> \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0648\u0631\u0648\u062f\u06cc \u0631\u0627 \u067e\u0627\u06a9\u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0648 \u0627\u0632 \u0627\u06cc\u0646 \u0646\u0648\u0639 \u062d\u0645\u0644\u0627\u062a \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>$ npm install express-mongo-sanitize\r\nconst mongoSanitize = require('express-mongo-sanitize');\r\napp.use(mongoSanitize());<\/code><\/pre>\n<\/div>\n<h2 id=\"%db%b4-%d8%ac%d9%84%d9%88%da%af%db%8c%d8%b1%db%8c-%d8%a7%d8%b2-%d8%ad%d9%85%d9%84%d8%a7%d8%aa-redos\">\u06f4. \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062d\u0645\u0644\u0627\u062a ReDoS<\/h2>\n<p>\u062d\u0645\u0644\u0627\u062a ReDoS \u06cc\u0627 Denial of Service \u062f\u0631 Regular Expression \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0627\u0639\u062b \u06a9\u0627\u0647\u0634 \u0639\u0645\u0644\u06a9\u0631\u062f \u0633\u0631\u0648\u0631 \u0634\u0648\u0646\u062f. \u0627\u0632 \u0627\u0628\u0632\u0627\u0631 <strong>safe-regex<\/strong> \u0628\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0627\u06cc\u0645\u0646 \u0628\u0648\u062f\u0646 \u0639\u0628\u0627\u0631\u0627\u062a \u0645\u0646\u0638\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<h3 id=\"%d9%85%d8%ab%d8%a7%d9%84\">\u0645\u062b\u0627\u0644<\/h3>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>var safe = require('safe-regex');\r\nvar regex = process.argv.slice(2).join(' ');\r\nconsole.log(safe(regex));<\/code><\/pre>\n<\/div>\n<h2 id=\"%db%b5-%d8%ac%d9%84%d9%88%da%af%db%8c%d8%b1%db%8c-%d8%a7%d8%b2-%d8%ad%d9%85%d9%84%d8%a7%d8%aa-csrf\">\u06f5. \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u062d\u0645\u0644\u0627\u062a CSRF<\/h2>\n<p>\u0628\u0631\u0627\u06cc \u062d\u0641\u0627\u0638\u062a \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u0628\u0631\u0627\u0628\u0631 \u062d\u0645\u0644\u0627\u062a CSRF \u06a9\u0647 \u0628\u0647 \u0645\u0647\u0627\u062c\u0645\u0627\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0627\u0631\u0633\u0627\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0645\u062e\u0631\u0628 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627\u06cc \u0645\u0639\u062a\u0628\u0631 \u0631\u0627 \u0645\u06cc\u200c\u062f\u0647\u0646\u062f\u060c \u0627\u0632 \u0645\u0627\u0698\u0648\u0644 <strong>csurf<\/strong> \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>const csrf = require('csurf');\r\napp.use(csrf());<\/code><\/pre>\n<\/div>\n","protected":false},"excerpt":{"rendered":"\u0645\u0642\u062f\u0645\u0647 \u0627\u0645\u0646\u06cc\u062a API \u0628\u0647 \u0645\u0639\u0646\u0627\u06cc \u062d\u0641\u0627\u0638\u062a \u0627\u0632 \u06cc\u06a9\u067e\u0627\u0631\u0686\u06af\u06cc API\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06cc\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645. \u0627\u0645\u0631\u0648\u0632\u0647 \u0628\u06cc\u0634\u062a\u0631&hellip;\n","protected":false},"author":1,"featured_media":16577,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_yoast_wpseo_focuskw":"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc","_yoast_wpseo_title":"","_yoast_wpseo_metadesc":"","_yoast_wpseo_canonical":"","_yoast_wpseo_opengraph-description":"","_yoast_wpseo_opengraph-image":"","_yoast_wpseo_twitter-description":"","_yoast_wpseo_twitter-image":"","_yoast_wpseo_focuskeywords":"[]","_yoast_wpseo_primary_category":"193","footnotes":""},"categories":[193,324,363],"tags":[414,394,404],"class_list":{"0":"post-16575","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-tutorials","8":"category-security","9":"category-programming","10":"tag-api","11":"tag-nodejs","12":"tag-security"},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.3 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc - \u0628\u0644\u0627\u06af ITPiran<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/\" \/>\n<meta property=\"og:locale\" content=\"fa_IR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc - \u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"og:description\" content=\"\u0645\u0642\u062f\u0645\u0647 \u0627\u0645\u0646\u06cc\u062a API \u0628\u0647 \u0645\u0639\u0646\u0627\u06cc \u062d\u0641\u0627\u0638\u062a \u0627\u0632 \u06cc\u06a9\u067e\u0627\u0631\u0686\u06af\u06cc API\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06cc\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645. \u0627\u0645\u0631\u0648\u0632\u0647 \u0628\u06cc\u0634\u062a\u0631&hellip;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"article:published_time\" content=\"2024-12-28T06:23:22+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.itpiran.net\/2024\/12\/28095148\/API-security-packages.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1793\" \/>\n\t<meta property=\"og:image:height\" content=\"1110\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 \u062f\u0642\u06cc\u0642\u0647\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/\"},\"author\":{\"name\":\"admin\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\"},\"headline\":\"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc\",\"datePublished\":\"2024-12-28T06:23:22+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/\"},\"wordCount\":65,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/12\\\/28095148\\\/API-security-packages.jpg\",\"keywords\":[\"API\",\"Nodejs\",\"Security\"],\"articleSection\":[\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"\u0627\u0645\u0646\u06cc\u062a\",\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc\"],\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/\",\"name\":\"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc - \u0628\u0644\u0627\u06af ITPiran\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/12\\\/28095148\\\/API-security-packages.jpg\",\"datePublished\":\"2024-12-28T06:23:22+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#breadcrumb\"},\"inLanguage\":\"fa-IR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#primaryimage\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/12\\\/28095148\\\/API-security-packages.jpg\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/12\\\/28095148\\\/API-security-packages.jpg\",\"width\":1793,\"height\":1110},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/category\\\/tutorials\\\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"name\":\"\u0628\u0644\u0627\u06af ITPiran\",\"description\":\"\u0627\u062e\u0628\u0627\u0631 \u0648 \u0645\u0642\u0627\u0644\u0627\u062a \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"fa-IR\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\",\"name\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"alternateName\":\"ITPIran Blog\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"fa-IR\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"width\":512,\"height\":512,\"caption\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\",\"name\":\"admin\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/author\\\/admin\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc - \u0628\u0644\u0627\u06af ITPiran","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/","og_locale":"fa_IR","og_type":"article","og_title":"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc - \u0628\u0644\u0627\u06af ITPiran","og_description":"\u0645\u0642\u062f\u0645\u0647 \u0627\u0645\u0646\u06cc\u062a API \u0628\u0647 \u0645\u0639\u0646\u0627\u06cc \u062d\u0641\u0627\u0638\u062a \u0627\u0632 \u06cc\u06a9\u067e\u0627\u0631\u0686\u06af\u06cc API\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06cc\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645. \u0627\u0645\u0631\u0648\u0632\u0647 \u0628\u06cc\u0634\u062a\u0631&hellip;","og_url":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/","og_site_name":"\u0628\u0644\u0627\u06af ITPiran","article_published_time":"2024-12-28T06:23:22+00:00","og_image":[{"width":1793,"height":1110,"url":"https:\/\/cdn.itpiran.net\/2024\/12\/28095148\/API-security-packages.jpg","type":"image\/jpeg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u0646\u0648\u0634\u062a\u0647\u200c\u0634\u062f\u0647 \u0628\u062f\u0633\u062a":"admin","\u0632\u0645\u0627\u0646 \u062a\u0642\u0631\u06cc\u0628\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646":"4 \u062f\u0642\u06cc\u0642\u0647"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#article","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/"},"author":{"name":"admin","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81"},"headline":"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc","datePublished":"2024-12-28T06:23:22+00:00","mainEntityOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/"},"wordCount":65,"commentCount":0,"publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/12\/28095148\/API-security-packages.jpg","keywords":["API","Nodejs","Security"],"articleSection":["\u0622\u0645\u0648\u0632\u0634\u06cc","\u0627\u0645\u0646\u06cc\u062a","\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc"],"inLanguage":"fa-IR","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/","url":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/","name":"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc - \u0628\u0644\u0627\u06af ITPiran","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#primaryimage"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/12\/28095148\/API-security-packages.jpg","datePublished":"2024-12-28T06:23:22+00:00","breadcrumb":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#breadcrumb"},"inLanguage":"fa-IR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/"]}]},{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#primaryimage","url":"https:\/\/cdn.itpiran.net\/2024\/12\/28095148\/API-security-packages.jpg","contentUrl":"https:\/\/cdn.itpiran.net\/2024\/12\/28095148\/API-security-packages.jpg","width":1793,"height":1110},{"@type":"BreadcrumbList","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/use-these-nodejs-packages-to-prevent-common-security-vulnerabilities\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.itpiran.net\/blog\/"},{"@type":"ListItem","position":2,"name":"\u0622\u0645\u0648\u0632\u0634\u06cc","item":"https:\/\/www.itpiran.net\/blog\/category\/tutorials\/"},{"@type":"ListItem","position":3,"name":"\u0627\u0645\u0646\u06cc\u062a API \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634\u0646\u0647\u0627\u062f\u06cc"}]},{"@type":"WebSite","@id":"https:\/\/www.itpiran.net\/blog\/#website","url":"https:\/\/www.itpiran.net\/blog\/","name":"\u0628\u0644\u0627\u06af ITPiran","description":"\u0627\u062e\u0628\u0627\u0631 \u0648 \u0645\u0642\u0627\u0644\u0627\u062a \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646","publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.itpiran.net\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"fa-IR"},{"@type":"Organization","@id":"https:\/\/www.itpiran.net\/blog\/#organization","name":"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646","alternateName":"ITPIran Blog","url":"https:\/\/www.itpiran.net\/blog\/","logo":{"@type":"ImageObject","inLanguage":"fa-IR","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","contentUrl":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","width":512,"height":512,"caption":"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81","name":"admin","url":"https:\/\/www.itpiran.net\/blog\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts\/16575","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/comments?post=16575"}],"version-history":[{"count":1,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts\/16575\/revisions"}],"predecessor-version":[{"id":16578,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/posts\/16575\/revisions\/16578"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/media\/16577"}],"wp:attachment":[{"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/media?parent=16575"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/categories?post=16575"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/wp-json\/wp\/v2\/tags?post=16575"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}