{"id":5082,"date":"2024-04-05T02:15:31","date_gmt":"2024-04-04T18:15:31","guid":{"rendered":"https:\/\/tenten.co\/blog\/?p=5082"},"modified":"2024-04-05T02:23:05","modified_gmt":"2024-04-04T18:23:05","slug":"top-malicious-package-scanners","status":"publish","type":"post","link":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/","title":{"rendered":"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01"},"content":{"rendered":"<h1>\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01<\/h1>\n<p>\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168<\/p>\n<p>\u7531\u65bc\u60e1\u610f\u884c\u70ba\uff08\u4f8b\u5982\u62fc\u5b57\u932f\u8aa4\u3001\u4f9d\u8cf4\u95dc\u4fc2\u6df7\u6dc6\u548c\u5f15\u5165\u60e1\u610f\u8edf\u9ad4\uff09\uff0c\u958b\u6e90\u516c\u5171\u5132\u5b58\u5eab\u53ef\u80fd\u6703\u5c0d\u7d44\u7e54\u69cb\u6210\u8a31\u591a\u5a01\u8105\u3002 <\/p>\n<p>\u7136\u800c\uff0c\u7531\u65bc\u8edf\u9ad4\u7684\u8907\u96dc\u6027\u4ee5\u53ca\u5728\u7af6\u722d\u6fc0\u70c8\u7684\u5e02\u5834\u4e2d\u4ea4\u4ed8\u8edf\u9ad4\u7684\u901f\u5ea6\uff0c\u5de5\u7a0b\u5e2b\u5225\u7121\u9078\u64c7\uff0c\u53ea\u80fd\u4f9d\u9760\u7b2c\u4e09\u65b9\u5916\u90e8\u7a0b\u5f0f\u5eab\u4f86\u66f4\u5feb\u5730\u5275\u5efa\u5275\u65b0\u61c9\u7528\u7a0b\u5f0f\u3002\u5118\u7ba1\u958b\u6e90\u4f9d\u8cf4\u9805\u88ab\u5ee3\u6cdb\u4f7f\u7528\u3001\u7d93\u904e\u5fb9\u5e95\u6e2c\u8a66\uff0c\u4e26\u4e14\u7d93\u5e38\u51fa\u73fe\u6f0f\u6d1e\u4e26\u6bd4\u5c08\u6709\u7a0b\u5f0f\u78bc\u66f4\u5feb\u5f97\u5230\u89e3\u6c7a\uff0c\u4f46\u4f7f\u7528\u958b\u6e90\u7a0b\u5f0f\u78bc\u9032\u884c\u7de8\u78bc\u4e26\u975e\u6c92\u6709\u98a8\u96aa\u3002<\/p>\n<p>\u672c\u6587\u63a2\u8a0e\u4e86\u5728\u8edf\u9ad4\u958b\u767c\u4e2d\u4f7f\u7528\u5916\u90e8\u76f8\u4f9d\u6027\u7684\u4e00\u4e9b\u98a8\u96aa\uff0c\u4ee5\u53ca\u53ef\u4ee5\u9632\u6b62\u60e1\u610f\u8edf\u9ad4\u610f\u5916\u5305\u542b\u5728\u60a8\u7684\u7522\u54c1\u4e2d\u7684\u5341\u7a2e\u6d41\u884c\u5de5\u5177\uff0c\u7121\u8ad6\u5176\u5a92\u4ecb\u70ba\u4f55\u3002\u5177\u9ad4\u4f86\u8aaa\uff0c\u6211\u5011\u5c07\u7814\u7a76\u5982\u4f55\u907f\u514d\u8207\u62fc\u5b57\u932f\u8aa4\u7684\u8edf\u9ad4\u5305\u3001\u4f9d\u8cf4\u9805\u6df7\u6dc6\u548c\u60e1\u610f\u8edf\u9ad4\u76f8\u95dc\u7684\u5371\u96aa\uff0c\u7136\u5f8c\u6aa2\u67e5\u53ef\u7528\u65bc\u6e1b\u8f15\u9019\u4e9b\u5a01\u8105\u7684\u4e0d\u540c\u5de5\u5177\u548c\u670d\u52d9\u3002 <\/p>\n<h2><strong>\u958b\u6e90\u5a01\u8105\uff1a\u4e86\u89e3\u4f60\u7684\u6575\u4eba<\/strong><\/h2>\n<p>\u8edf\u9ad4\u5de5\u7a0b\u5e2b\u9700\u8981\u4e86\u89e3\u5728\u5176\u7a0b\u5f0f\u78bc\u904b\u884c\u7684\u57f7\u884c\u6642\u9593\u74b0\u5883\u4e2d\u65b0\u589e\u4f9d\u8cf4\u9805\u6216\u66f4\u65b0\u73fe\u6709\u4f9d\u8cf4\u9805\u6642\u53ef\u80fd\u9047\u5230\u7684\u6f5b\u5728\u554f\u984c\u3002\u4e00\u4e9b\u6700\u5e38\u898b\u7684\u5a01\u8105\u5305\u62ec\uff1a<\/p>\n<ul>\n<li><strong>\u8aa4\u690d<\/strong>\u2013 \u4e5f\u7a31\u70baURL \u52ab\u6301\uff0c\u7576\u60e1\u610f\u884c\u70ba\u8005\u5275\u5efa\u53d7\u611f\u67d3\u7684\u8edf\u9ad4\u5305\u6642\uff0c\u5c31\u6703\u767c\u751f\u8aa4\u690d\uff0c\u9019\u4e9b\u8edf\u9ad4\u5305\u5728\u7279\u6027\/\u529f\u80fd\u4e0a\u8207\u5e38\u7528\u4f9d\u8cf4\u9805\u5e7e\u4e4e\u76f8\u540c\uff0c\u4f46\u547d\u540d\u7565\u6709\u4e0d\u540c\uff0c\u5e0c\u671b\u958b\u767c\u4eba\u54e1\u80fd\u5920\u932f\u8aa4\u8f38\u5165\u5b89\u88dd\u6307\u4ee4\u3002\u7576\u5d4c\u5165\u7684\u60e1\u610f\u8edf\u9ad4\u6216\u60e1\u610f\u7a0b\u5f0f\u78bc\u57f7\u884c\u5176\u6f0f\u6d1e\u6642\uff0c\u9019\u4e9b\u8edf\u9ad4\u5305\u901a\u5e38\u6703\u5982\u9810\u671f\u904b\u4f5c\u3002<\/li>\n<li><strong>\u4f9d\u8cf4\u95dc\u4fc2\u6df7\u4e82<\/strong>\u2013 \u8a31\u591a\u8a9e\u8a00\u90fd\u5305\u542b\u65b9\u4fbf\u7684\u5957\u4ef6\u7ba1\u7406\u5de5\u5177\uff08\u4f8b\u5982\u7528\u65bc JavaScript \u7684 npm \u6216\u7528\u65bc Python \u7684 pip\uff09\uff0c\u53ef\u4ee5\u8f15\u9b06\u5730\u5c07\u7b2c\u4e09\u65b9\u76f8\u4f9d\u6027\u65b0\u589e\u81f3\u5c08\u6848\u3002\u4f46\u662f\uff0c\u5982\u679c\u7b2c\u4e09\u65b9\u516c\u5171\u4f9d\u8cf4\u9805\u8207\u5167\u90e8\u958b\u767c\u7684\u79c1\u4eba\u4f9d\u8cf4\u9805\u547d\u540d\u76f8\u540c\uff0c\u5247\u5957\u4ef6\u7ba1\u7406\u5668\u53ef\u80fd\u6703\u5b89\u88dd\u53d7\u640d\u7684\u516c\u5171\u4f9d\u8cf4\u9805\u800c\u4e0d\u662f\u79c1\u4eba\u4f9d\u8cf4\u9805\u3002 <\/li>\n<li>\u300c<a href=\"https:\/\/cointelegraph.com\/news\/github-faces-widespread-malware-attacks-affecting-projects-including-crypto\"><strong>\u60e1\u610f\u8edf\u9ad4<\/strong><\/a>\u300d\u662f\u300c\u60e1\u610f\u8edf\u9ad4\u300d\u7684\u7e2e\u5beb\u3002\u60e1\u610f\u8edf\u9ad4\u5305\u62ec\u75c5\u6bd2\u3001\u6728\u99ac\u3001\u52d2\u7d22\u8edf\u9ad4\u3001\u9593\u8adc\u8edf\u9ad4\u548c\u5176\u4ed6\u53ef\u80fd\u5c0d\u60a8\u7684\u8edf\u9ad4\u3001\u96fb\u8166\u7cfb\u7d71\u3001\u5ba2\u6236\u548c\u4f7f\u7528\u8005\u9020\u6210\u56b4\u91cd\u7834\u58de\u7684\u6f0f\u6d1e\u3002 <\/li>\n<\/ul>\n<p>\u5de5\u7a0b\u5e2b\u5e38\u5e38\u8a8d\u70ba\u4ed6\u5011\u7684\u7d44\u7e54\u4f7f\u7528\u7684\u958b\u6e90\u8edf\u9ad4\u5305\u662f\u5b89\u5168\u7684\u4e26\u4e14\u7dad\u8b77\u826f\u597d\uff0c\u4f46\u60c5\u6cc1\u4e26\u975e\u7e3d\u662f\u5982\u6b64\u3002\u4e8b\u5be6\u4e0a\uff0c\u7121\u6cd5\u4fdd\u8b49\u60a8\u65b0\u589e\u5230\u57f7\u884c\u6642\u9593\u74b0\u5883\u4e2d\u7684\u5957\u4ef6\u6c92\u6709\u60e1\u610f\u8edf\u9ad4\u3002\u8207\u5176\u76f2\u76ee\u5730\u4fe1\u4efb\u516c\u5171\u5132\u5b58\u5eab\uff0c\u4e0d\u5982\u5c0d\u5c0e\u5165\u5230\u7d44\u7e54\u4e2d\u7684\u5167\u5bb9\u9032\u884c\u81f3\u5c11\u6709\u9650\u7684\u6aa2\u67e5\u59cb\u7d42\u662f\u4e00\u500b\u5f88\u597d\u7684\u9810\u9632\u63aa\u65bd\u3002 <\/p>\n<h2><strong>\u958b\u6e90\u5a01\u8105\u5de5\u5177<\/strong><\/h2>\n<p>\u672c\u7bc0\u4ecb\u7d39\u4e86\u4e00\u4e9b\u53ef\u4ee5\u8207\u5e38\u898b\u8edf\u9ad4\u958b\u767c\u6d41\u7a0b\u6574\u5408\u7684\u9802\u7d1a\u5de5\u5177\uff0c\u4ee5\u4fbf\u91dd\u5c0d\u958b\u6e90\u4f9d\u8cf4\u5a01\u8105\u63d0\u4f9b\u4e00\u5c64\u4fdd\u8b77\u3002\u9019\u4e9b\u89e3\u6c7a\u65b9\u6848\u6db5\u84cb\u5f9e\u958b\u6e90\u5de5\u5177\u5230\u5546\u696d\u92b7\u552e\u8edf\u9ad4\u7684\u5404\u7a2e\u7bc4\u570d\u3002\u540c\u6a23\uff0c\u8a72\u8edf\u9ad4\u7684\u7bc4\u570d\u5f9e\u91dd\u5c0d\u7279\u5b9a\u5a01\u8105\u7684\u55ae\u9ede\u89e3\u6c7a\u65b9\u6848\u5230\u958b\u6e90\u5b89\u5168\u5e73\u53f0\u3002\u7e3d\u7684\u4f86\u8aaa\uff0c\u5b83\u5011\u53ef\u4ee5\u5e6b\u52a9\u60a8\u5efa\u7acb\u5f37\u5927\u3001\u6df1\u5165\u7684\u9632\u79a6\uff0c\u4f46\u5373\u4f7f\u55ae\u7368\u4f7f\u7528\uff0c\u5b83\u5011\u4e5f\u53ef\u4ee5\u6839\u64da\u60a8\u7684\u9700\u6c42\u63d0\u4f9b\u6709\u6548\u7684\u89e3\u6c7a\u65b9\u6848\u3002<\/p>\n<h3>upguard<\/h3>\n<p><a href=\"https:\/\/www.upguard.com\/\">UpGuard<\/a>\u662f\u7b2c\u4e09\u65b9\u98a8\u96aa\u548c\u653b\u64ca\u9762\u7ba1\u7406\u5e73\u53f0\u3002\u5b83\u662f\u4e00\u7a2e\u4ed8\u8cbb\u89e3\u6c7a\u65b9\u6848\uff0c\u53ef\u4ee5\u4fdd\u8b77\u60a8\u7684\u7d44\u7e54\u514d\u53d7\u5404\u7a2e\u653b\u64ca\u548c\u6f0f\u6d1e\u7684\u4fb5\u5bb3\uff0c\u4e26\u5305\u542b\u4e00\u500b<a href=\"https:\/\/www.upguard.com\/blog\/typosquatting\">\u62fc\u5b57\u932f\u8aa4\u6a21\u7d44<\/a>\u3002\u4f5c\u70ba\u5e73\u53f0\u63d0\u4f9b\u8005\uff0c\u4ed6\u5011\u5c08\u6ce8\u65bc\u767c\u5c55\u548c\u6539\u9032\u4ed6\u5011\u7684\u7522\u54c1\uff0c\u4ee5\u53ca\u652f\u6301\u4ed6\u5011\u7684\u7528\u6236\u3002 <\/p>\n<p>UpGuard \u662f\u4e00\u9805\u4ed8\u8cbb\u670d\u52d9\uff0c\u5177\u6709\u591a\u7a2e\u5b9a\u50f9\u6a21\u5f0f\u4ee5\u6eff\u8db3\u60a8\u7684\u9700\u6c42\u3002\u4ed6\u5011\u5728\u5165\u8077\u96fb\u8a71\u6703\u8b70\u5f8c\u63d0\u4f9b<a href=\"https:\/\/www.upguard.com\/demo\">7 \u5929\u514d\u8cbb\u8a66\u7528<\/a>\uff08\u5305\u62ec\u6f14\u793a\uff09\u3002\u4ed6\u5011\u70ba\u7d10\u7d04\u8b49\u5238\u4ea4\u6613\u6240\u7b49\u5404\u7a2e\u5177\u6709\u5b89\u5168\u610f\u8b58\u7684\u7d44\u7e54\u63d0\u4f9b\u670d\u52d9\u3002 <\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u9032\u5165\u9580\u6abb\u4f4e\uff1b\u4f7f\u7528\u65b9\u4fbf<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u983b\u7e41\u8aa4\u5831\uff1b\u5f88\u96e3\u53ca\u6642\u806f\u7e6b\u5230\u652f\u63f4\u5718\u968a<\/li>\n<\/ul>\n<h3>Pypi-\u6383\u63cf<\/h3>\n<p><a href=\"https:\/\/pypi.org\/\">Python \u5957\u4ef6\u7d22\u5f15<\/a>( PyPI) \u662f\u4e00\u500b\u7dda\u4e0a\u5132\u5b58\u5eab\uff0c\u5176\u4e2d\u5305\u542b\u5404\u7a2e\u5f62\u72c0\u548c\u5f62\u5f0f\u7684 Python \u5957\u4ef6\u3002\u5b83\u7684\u53ef\u8a2a\u554f\u6027\u65e2\u662f\u798f\u4e5f\u662f\u798d\uff0c\u5b83\u4f7f\u5f97\u4e0b\u8f09\u53ef\u4ee5\u52a0\u901f Python \u958b\u767c\u7684\u5957\u4ef6\u8b8a\u5f97\u7c21\u55ae\uff0c\u4f46\u4e5f\u8b93\u90aa\u60e1\u7684\u7a0b\u5f0f\u8a2d\u8a08\u5e2b\u5f88\u5bb9\u6613\u4e0a\u50b3\u60e1\u610f\u8edf\u9ad4\u3002 PyPI \u4e5f\u5145\u65a5\u8457\u62fc\u5b57\u932f\u8aa4\u548c\u4f9d\u8cf4\u6df7\u6dc6\u5019\u9078\u8005\u7684\u7bc4\u4f8b\u3002<\/p>\n<p><a href=\"https:\/\/www.iqt.org\/pypi-scan\/\">Pypi-scan<\/a>\u662f\u4e00\u500b\u547d\u4ee4\u5217\u5be6\u7528\u7a0b\u5e8f\uff0c\u53ef\u5e6b\u52a9\u5b89\u5168\u5de5\u7a0b\u5e2b\u8b58\u5225\u6f5b\u5728\u7684\u62fc\u5b57\u932f\u8aa4\u5957\u4ef6\u3002\u5b83\u9084\u53ef\u4ee5\u5e6b\u52a9\u8edf\u9ad4\u5de5\u7a0b\u5e2b\u78ba\u4fdd\u4ed6\u5011\u6240\u5305\u542b\u7684\u8edf\u9ad4\u5305\u7b26\u5408\u4ed6\u5011\u7684\u9810\u671f\u3002 Pypi-scan \u7279\u5225\u64c5\u9577\u5c0b\u627e\u53ef\u80fd\u7684\u8aa4\u690d\u8edf\u9ad4\u5305\uff0c\u4f46\u5b83\u7f3a\u4e4f\u8b58\u5225\u5305\u542b\u60e1\u610f\u8edf\u9ad4\u7684\u667a\u6167\u548c\u5206\u6790\u80fd\u529b\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a<a href=\"https:\/\/github.com\/IQTLabs\/pypi-scan\">\u514d\u8cbb\u63d0\u4f9b<\/a>\u958b\u6e90\u8edf\u9ad4<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u7bc4\u570d\u50c5\u9650\u65bc PyPI\uff1b\u9700\u8981\u8207\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5668\u914d\u5408\u4f7f\u7528\u624d\u80fd\u767c\u63ee\u6700\u5927\u529f\u6548<\/li>\n<\/ul>\n<h3>Tidelift \u76ee\u9304<\/h3>\n<p><a href=\"https:\/\/tidelift.com\/catalogs\/team\/tidelift\/tidelift\">Tidelift \u76ee\u9304<\/a>\u63a1\u7528\u4e0d\u540c\u7684\u65b9\u6cd5\u4f86\u4fdd\u8b77\u7d44\u7e54\u514d\u53d7\u6f5b\u5728\u5371\u96aa\uff0c\u5145\u7576\u514d\u8cbb\u63d0\u4f9b\u7684\u7dda\u4e0a\u53c3\u8003\uff0c\u5176\u4e2d\u5305\u62ec\u4f86\u81ea\u591a\u500b\u751f\u614b\u7cfb\u7d71\u7684\u6578\u5343\u500b\u6d41\u884c\u958b\u6e90\u8edf\u9ad4\u5305\uff08\u5728\u64b0\u5beb\u672c\u6587\u6642\u8d85\u904e7,000 \u500b\u8edf\u9ad4\u5305\uff09\uff0c\u4e26\u63d0\u4f9b\u6709\u95dc\u54ea\u4e9b\u8edf\u9ad4\u5305\/\u7248\u672c\u88ab\u8a8d\u70ba\u53ef\u4ee5\u5b89\u5168\u4f7f\u7528\u3002 <\/p>\n<p>\u5982\u679c\u60a8\u8a02\u95b1 Tidelift \u76ee\u9304\uff0c\u60a8\u53ef\u4ee5\u7372\u5f97\u6709\u95dc\u6bcf\u500b\u8edf\u9ad4\u5305\u7684\u66f4\u591a\u4fe1\u606f\uff0c\u5305\u62ec\u958b\u6e90\u8a31\u53ef\u4ee5\u53ca\u751f\u547d\u9031\u671f\u7d50\u675f\u548c\u68c4\u7528\u6642\u9593\u8868\u3002\u5982\u679c\u8edf\u9ad4\u5305\u4e2d\u5b58\u5728\u6f0f\u6d1e\uff0c\u8a72\u670d\u52d9\u9084\u63d0\u4f9b\u7d93\u904e\u9a57\u8b49\u7684\u89e3\u6c7a\u65b9\u6cd5\u3002\u5b9a\u50f9\u53d6\u6c7a\u65bc\u60a8\u7684\u958b\u767c\u5718\u968a\u7684\u898f\u6a21\u3002\u9664\u4e86\u76ee\u9304\u4e4b\u5916\uff0c\u652f\u63f4\u5718\u968a\u9084\u53ef\u4ee5\u5354\u52a9\u89e3\u6c7a\u554f\u984c\uff0c\u4e26\u8003\u616e\u76ee\u9304\u65b0\u589e\u548c\u589e\u5f37\u8acb\u6c42\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1aTidelift \u7dad\u8b77\u5408\u4f5c\u5925\u4f34\u53ef\u4ee5\u63d0\u4f9b\u984d\u5916\u7684\u6a5f\u5bc6\u4fe1\u606f<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u76ee\u9304\u5927\u5c0f\u6709\u9650 <\/li>\n<\/ul>\n<h3>\u6d1b\u57fa<\/h3>\n<p>\u5982\u679c\u60a8\u7684\u6280\u8853\u5806\u758a\u662f NodeJS \u4e26\u4e14\u60a8\u64d4\u5fc3\u4f9d\u8cf4\u95dc\u4fc2\u6df7\u4e82\uff0c\u90a3\u9ebc<a href=\"https:\/\/github.com\/Xh4H\/Loki\">Loki<\/a>\u662f\u4e00\u500b\u53ef\u4ee5\u5e6b\u52a9\u60a8\u589e\u5f37\u8edf\u9ad4\u4f9b\u61c9\u93c8\u5b89\u5168\u6027\u4e26\u9632\u6b62\u653b\u64ca\u7684\u5de5\u5177\u3002\u4f7f\u7528 Loki\uff0c\u5de5\u7a0b\u5e2b\u53ef\u4ee5\u6383\u63cf\u4ed6\u5011\u7684\u5c08\u6848\u4e26\u8b58\u5225\u6f5b\u5728\u7684\u6f0f\u6d1e\u3002\u9664\u4e86\u6383\u63cf\u4e4b\u5916\uff0cLoki \u9084\u5177\u6709\u201c\u653b\u64ca\u6a21\u5f0f\u201d\uff0c\u53ef\u4ee5\u8b93\u5de5\u7a0b\u5e2b\u5728\u4e0d\u640d\u5bb3\u57fa\u790e\u5c08\u6848\u5b8c\u6574\u6027\u7684\u60c5\u6cc1\u4e0b\u63a2\u7d22\u6f5b\u5728\u7684\u6f0f\u6d1e\u3002<\/p>\n<p>Loki \u662f\u4e00\u500b\u958b\u6e90\u9805\u76ee\uff0c\u5b83\u53ef\u4ee5\u6d88\u9664\u8a31\u591a\u969c\u7919\uff0c\u5c07\u5176\u7d0d\u5165\u65e8\u5728\u4fdd\u8b77\u4f01\u696d\u514d\u53d7\u958b\u6e90\u5a01\u8105\u7684\u89e3\u6c7a\u65b9\u6848\u4e2d\u3002\u4e8b\u5be6\u8b49\u660e\uff0c\u5b83\u662f NodeJS \u958b\u767c\u4eba\u54e1\u4e2d\u6d41\u884c\u7684\u5de5\u5177\uff0c\u53ef\u4ee5\u9632\u6b62\u7a0b\u5f0f\u78bc\u4e2d\u5f15\u5165\u6f0f\u6d1e\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u958b\u6e90\u89e3\u6c7a\u65b9\u6848\uff1b\u50c5\u6709\u7684\u5e7e\u500b\u4f9d\u8cf4\u6027\u6df7\u6dc6\u5de5\u5177\u4e4b\u4e00<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u4e0d\u662f\u771f\u6b63\u7684\u6383\u63cf\u5100\uff0c\u800c\u662f\u300c\u5047\u8a2d\u300d\u653b\u64ca\u5834\u666f\u7684\u63a8\u52d5\u8005<\/li>\n<\/ul>\n<h3>Sonatype \u7684 Nexus \u9632\u706b\u7246<\/h3>\n<p><a href=\"https:\/\/www.sonatype.com\/products\/firewall\">Nexus Firewall<\/a>\u63a1\u7528\u7565\u6709\u4e0d\u540c\u7684\u65b9\u6cd5\u4f86\u4fdd\u8b77\u60a8\u7684\u8edf\u9ad4\u5c08\u6848\u514d\u53d7\u5c0e\u5165\u4f9d\u8cf4\u9805\u9020\u6210\u7684\u5be6\u969b\u548c\u6f5b\u5728\u5a01\u8105\u3002\u9632\u706b\u7246\u5230\u4f4d\u5f8c\uff0c\u6240\u6709\u532f\u5165\u7684\u4f9d\u8cf4\u9805\u90fd\u6703\u901a\u904e\u5b83\u4e26\u88ab\u5206\u985e\u70ba\u5b89\u5168\u3001\u53ef\u7591\u6216\u60e1\u610f\u3002\u5141\u8a31\u5b89\u5168\u7d44\u4ef6\u901a\u904e\uff0c\u800c\u53ef\u7591\u548c\u60e1\u610f\u6a94\u6848\u548c\u5957\u4ef6\u5247\u9032\u5165\u9694\u96e2\u5340\u57df\u3002<\/p>\n<p>Sonatype \u5b89\u5168\u5718\u968a\u6703\u5be9\u67e5\u6bcf\u500b\u88ab\u8b58\u5225\u70ba\u53ef\u7591\u7684\u5143\u4ef6\/\u4f9d\u8cf4\u9805\uff0c\u4ee5\u4fbf\u5c07\u5b83\u5011\u91cd\u65b0\u5206\u985e\u70ba\u5b89\u5168\u6027\uff08\u5728\u9019\u7a2e\u60c5\u6cc1\u4e0b\u5141\u8a31\u5b83\u5011\u7e7c\u7e8c\uff09\u6216\u60e1\u610f\uff08\u5728\u9019\u7a2e\u60c5\u6cc1\u4e0b\u5b83\u5011\u4ecd\u7136\u7121\u6cd5\u4f7f\u7528\uff09\u3002 Nexus Firewall \u662f\u4e00\u500b\u5e73\u53f0\uff0c\u5229\u7528 Nexus \u5728\u60e1\u610f\u8edf\u9ad4\u9818\u57df\u7684\u7d93\u9a57\uff0c\u4e26\u5c07\u5176\u8207\u6a5f\u5668\u5b78\u7fd2\u7684\u529b\u91cf\u76f8\u7d50\u5408\uff0c\u4ee5\u505a\u51fa\u660e\u667a\u7684\u6c7a\u7b56\u3002\u5b9a\u50f9\u662f\u6839\u64da\u5176\u652f\u63f4\u7684\u5de5\u7a0b\u5e2b\u6578\u91cf\u78ba\u5b9a\u7684\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u81ea\u52d5\u5316\u7684\u958b\u7bb1\u5373\u7528\u898f\u5247\uff0c\u4f46\u53ef\u6839\u64da\u60a8\u7684\u9700\u6c42\u9032\u884c\u5ba2\u88fd\u5316<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u4f5c\u70ba\u66f4\u5927\u7684 Nexus Lifecycle \u5e73\u53f0\u7684\u4e00\u90e8\u5206\u8cfc\u8cb7\uff0c\u800c\u4e0d\u662f\u55ae\u9ede\u89e3\u6c7a\u65b9\u6848<\/li>\n<\/ul>\n<h3>BluSapphire \u7684 BlueEye<\/h3>\n<p><a href=\"https:\/\/www.blusapphire.com\/blusapphire-advanced#BluEye\">BluEye<\/a>\u662f\u4e00\u7a2e\u60e1\u610f\u8edf\u9ad4\u5075\u6e2c\u89e3\u6c7a\u65b9\u6848\uff0c\u53ef\u4e3b\u52d5\u6383\u63cf\u50b3\u5165\u7684\u6a94\u6848\u548c\u5957\u4ef6\uff0c\u4ee5\u5c0b\u627e\u5ee3\u6cdb\u4e14\u4e0d\u65b7\u589e\u9577\u7684\u60e1\u610f\u8edf\u9ad4\u6a23\u672c\u96c6\u5408\u3002\u9019\u7a2e\u65b9\u6cd5\u5ffd\u7565\u4e86\u5305\u88f9\u662f\u4ec0\u9ebc\uff0c\u800c\u662f\u95dc\u6ce8\u5176\u4e2d\u7684\u5167\u5bb9\u662f\u5426\u69cb\u6210\u6f5b\u5728\u5a01\u8105\u3002<\/p>\n<p><a href=\"https:\/\/www.blusapphire.com\/blusapphire-advanced\">BluSapphire \u5e73\u53f0<\/a>\u63d0\u4f9b\u4e86\u5ee3\u6cdb\u7684\u6a21\u7d44\uff0c\u60a8\u53ef\u4ee5\u4f7f\u7528\u5b83\u5011\u4f86\u4fdd\u8b77\u60a8\u7684\u7d44\u7e54\u514d\u53d7\u6f5b\u5728\u5a01\u8105\uff0c\u5176\u4e2d\u5305\u62ec BluEye Sandbox\uff0c\u5b83\u53ef\u4ee5\u81ea\u52d5\u57f7\u884c\u975c\u614b\u548c\u4e8c\u9032\u4f4d\u5206\u6790\u4ee5\u8b58\u5225\u7a0b\u5f0f\u78bc\u5305\u4e2d\u7684\u60e1\u610f\u8edf\u9ad4\u5167\u5bb9\u3002\u4f46\u8a72\u5e73\u53f0\u4e5f\u63d0\u4f9b\u5ee3\u6cdb\u7684\u5b89\u5168\u529f\u80fd\uff0c\u5f9e\u9ad8\u968e\u5a01\u8105\u7ba1\u7406\u5230\u5a01\u8105\u5075\u6e2c\u670d\u52d9\uff0c\u518d\u5230\u53ef\u5354\u52a9\u8abf\u67e5\u91dd\u5c0d\u7cfb\u7d71\u7684\u653b\u64ca\u548c\u6f0f\u6d1e\u5229\u7528\u7684\u4e8b\u5f8c\u5206\u6790\u5de5\u5177\u3002<\/p>\n<p>\u8207\u6b64\u6e05\u55ae\u4e2d\u5305\u542b\u7684\u5176\u4ed6\u5546\u696d\u92b7\u552e\u7684\u5b89\u5168\u5e73\u53f0\u4e00\u6a23\uff0cBluSapphire \u5e73\u53f0\u9700\u8981\u5927\u91cf\u7684\u8ca1\u52d9\u6295\u8cc7\u3002\u4f5c\u70ba\u4ea4\u63db\uff0cBluSapphire \u63d0\u4f9b\u4e00\u6d41\u7684\u5de5\u5177\u548c\u652f\u63f4\u670d\u52d9\uff0c\u65e8\u5728\u9650\u5236\u60a8\u7d44\u7e54\u4e2d\u7684\u5b89\u5168\u6f0f\u6d1e\u548c\u653b\u64ca\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u4e00\u6d41\u7684\u89e3\u6c7a\u65b9\u6848<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u4f5c\u70ba\u66f4\u5927\u5b89\u5168\u5e73\u53f0\u7684\u4e00\u90e8\u5206\u8cfc\u8cb7\uff0c\u800c\u4e0d\u662f\u55ae\u9ede\u89e3\u6c7a\u65b9\u6848<\/li>\n<\/ul>\n<h3>GitLab \u4f9d\u8cf4\u95dc\u4fc2\u6383\u63cf<\/h3>\n<p>\u4f5c\u70ba\u7a0b\u5f0f\u78bc\u5132\u5b58\u5eab\u89e3\u6c7a\u65b9\u6848\u63d0\u4f9b\u5546\uff0cGitLab \u548c\u985e\u4f3c\u63d0\u4f9b\u8005\uff08\u4f8b\u5982 GitHub\uff09\u5c07\u4f9d\u8cf4\u9805\u6383\u63cf\u4f5c\u70ba\u5176\u9ad8\u7d1a\u7522\u54c1\u7684\u4e00\u90e8\u5206\u3002 GitLab \u4f4d\u65bc\u8edf\u9ad4\u751f\u547d\u9031\u671f\u7684\u6838\u5fc3\uff0c\u662f\u958b\u767c\u548c\u90e8\u7f72\u904e\u7a0b\u4e2d\u4e0d\u53ef\u6216\u7f3a\u7684\u4e00\u90e8\u5206\uff0c\u56e0\u6b64\u662f\u57f7\u884c\u4f9d\u8cf4\u9805\u548c\u6f0f\u6d1e\u6383\u63cf\u7684\u7d55\u4f73\u5834\u6240\u3002 <\/p>\n<p>\u60a8\u53ef\u4ee5\u5c07<a href=\"https:\/\/docs.gitlab.com\/ee\/user\/application_security\/dependency_scanning\/\">GitLab \u4f9d\u8cf4\u9805\u6383\u63cf<\/a>\u914d\u7f6e\u70ba\u5b9a\u671f\u6383\u63cf\u6240\u6709\u5132\u5b58\u5eab\uff0c\u6216\u6839\u64da\u67d0\u4e9b\u689d\u4ef6\uff08\u4f8b\u5982\u65b0\u589e\u7684\u6216\u4fee\u6539\u7684\u7a0b\u5f0f\u78bc\u6642\uff09\u9032\u884c\u6383\u63cf\u3002\u652f\u63f4\u591a\u7a2e\u8a9e\u8a00\u7684\u6383\u63cf\uff0c\u5f9e Ruby \u5230 .NET\uff0c\u518d\u5230 Python \u548c Java\u3002\u96a8\u8457 Docker \u548c Kubernetes \u7b49\u6280\u8853\u7684\u65e5\u76ca\u666e\u53ca\uff0c\u503c\u5f97\u6ce8\u610f\u7684\u662f\uff0cGitLab \u4f9d\u8cf4\u9805\u6383\u63cf\u9084\u53ef\u4ee5\u6383\u63cf\u5bb9\u5668\u6620\u50cf\u4ee5\u67e5\u627e\u4f4d\u65bc\u5bb9\u5668\u4f5c\u696d\u7cfb\u7d71\u548c\u7279\u5b9a\u65bc\u8a9e\u8a00\u7684\u4e8c\u9032\u4f4d\u6a94\u6848\u4e2d\u7684\u6f0f\u6d1e\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u6383\u63cf\u7a0b\u5f0f\u78bc\u5132\u5b58\u5eab\u548c\u5bb9\u5668\u5167\u5bb9<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u50c5\u9069\u7528\u65bc\u9032\u968e\u652f\u63f4<\/li>\n<\/ul>\n<h3>Synopsys \u7684\u9ed1\u9d28\u5b50<\/h3>\n<p><a href=\"https:\/\/www.synopsys.com\/software-integrity\/security-testing\/software-composition-analysis.html\">Black Duck \u8edf\u9ad4\u7d44\u5408\u5206\u6790<\/a>\u662f\u5e38\u7528\u7684 SCA \u5de5\u5177\uff0c\u53ef\u5354\u52a9\u7d44\u7e54\u8fa8\u8b58\uff1a<\/p>\n<ul>\n<li>\u7a0b\u5f0f\u78bc\u5eab\u4e2d\u7684\u958b\u6e90\u4f9d\u8cf4\u9805<\/li>\n<li>\u7a0b\u5f0f\u78bc\u5eab\u7684\u5b89\u5168\u6027\uff0c\u5305\u62ec\u5b58\u5728\u7684\u4efb\u4f55\u6f0f\u6d1e<\/li>\n<li>\u958b\u6e90\u8a31\u53ef\u8a0a\u606f<\/li>\n<li>\u7a0b\u5f0f\u78bc\u5eab\u7684\u7a0b\u5f0f\u78bc\u8cea\u91cf<\/li>\n<\/ul>\n<p>\u900f\u904e\u9019\u7a2e\u65b9\u5f0f\uff0cBlack Duck \u53ef\u4ee5\u5e6b\u52a9\u6e1b\u8f15\u60e1\u610f\u8edf\u9ad4\u548c\u5305\u542b\u53ef\u5229\u7528\u7a0b\u5f0f\u78bc\u7684\u4f9d\u8cf4\u9805\u6240\u5e36\u4f86\u7684\u5a01\u8105\u3002<\/p>\n<p>Black Duck \u7d50\u5408\u4e86\u591a\u7a2e\u98a8\u96aa\u5075\u6e2c\u548c\u7de9\u89e3\u670d\u52d9\uff0c\u5168\u9762\u6db5\u84cb\u60a8\u7684\u8edf\u9ad4\u7d44\u6210\u3002\u8a72\u670d\u52d9\u5206\u6790\u5df2\u77e5\u6f0f\u6d1e\u7684\u6a94\u6848\u548c\u4f9d\u8cf4\u9805\uff0c\u4f46\u5b83\u9084\u57f7\u884c\u66f4\u6df1\u5165\u7684\u4e8c\u9032\u4f4d\u5206\u6790\u4ee5\u8b58\u5225\u65b0\u51fa\u73fe\u7684\u5a01\u8105\u3002\u6b64\u5916\uff0c\u5b83\u9084\u53ef\u4ee5\u5728\u904b\u884c\u6642\u8b58\u5225\u7de8\u8b6f\u5eab\u548c\u61c9\u7528\u7a0b\u5f0f\u4e2d\u5305\u542b\u7684\u958b\u6e90\u7a0b\u5f0f\u78bc\u3002<\/p>\n<p>\u6700\u5f8c\uff0c\u8a72\u670d\u52d9\u53ef\u4ee5\u6383\u63cf\u60a8\u7684\u5c08\u6709\u539f\u59cb\u7a0b\u5f0f\u78bc\uff0c\u4ee5\u67e5\u627e\u53ef\u80fd\u5f9e\u958b\u6e90\u7a0b\u5f0f\u5eab\u6536\u96c6\u7684\u7a0b\u5f0f\u78bc\u7247\u6bb5\u3002\u9019\u5f88\u91cd\u8981\uff0c\u56e0\u70ba\u5b83\u53ef\u80fd\u4f7f\u60a8\u7684\u7d44\u7e54\u9762\u81e8\u8a31\u53ef\u548c\u7248\u6b0a\u4fb5\u72af\u7684\u6cd5\u5f8b\u98a8\u96aa\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u8b58\u5225\u932f\u8aa4\u5305\u542b\u5728\u5c08\u6709\u7a0b\u5f0f\u78bc\u4e2d\u7684\u958b\u6e90\u7a0b\u5f0f\u78bc<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u8aa4\u5831\u7387\u9ad8<\/li>\n<\/ul>\n<h3>\u9000\u4f11JS<\/h3>\n<p>\u8edf\u9ad4\u4e0d\u65b7\u767c\u5c55\u548c\u6539\u9032\uff0c\u4f46\u5de5\u7a0b\u5e2b\u5e38\u5e38\u7fd2\u6163\u4f7f\u7528\u6a19\u6e96\u7248\u672c\u7684\u51fd\u5f0f\u5eab\uff0c\u800c\u4e0d\u8003\u616e\u5f8c\u7e8c\u7248\u672c\u4e2d\u6240\u505a\u7684\u6539\u9032\u3002\u7d50\u679c\u662f\u65b0\u8edf\u9ad4\u4f9d\u8cf4\u904e\u6642\u4e14\u53ef\u80fd\u6613\u53d7\u653b\u64ca\u7684\u4f9d\u8cf4\u9805\u3002<a href=\"https:\/\/github.com\/retirejs\/retire.js\/\">RetireJS<\/a>\u662f\u4e00\u500b\u57fa\u65bc NodeJS \u7684\u5be6\u7528\u7a0b\u5e8f\uff0c\u65e8\u5728\u900f\u904e\u8b58\u5225\u61c9\u66f4\u65b0\u6216\u505c\u6b62\u4f7f\u7528\u7684\u820a\u7684\u548c\u5df2\u68c4\u7528\u7684\u4f9d\u8cf4\u9805\u4f86\u89e3\u6c7a\u6b64\u554f\u984c\u3002<\/p>\n<p>RetireJS \u53ef\u4ee5\u7528\u4f5c\u547d\u4ee4\u5217\u5be6\u7528\u7a0b\u5e8f\uff0c\u4e5f\u53ef\u4ee5\u6574\u5408\u5230\u5404\u7a2e\u958b\u767c\u6d41\u7a0b\uff08\u4f8b\u5982_gulp_\u6216_burp\uff09_\u4e2d\uff0c\u4ee5\u8b58\u5225\u548c\u5831\u544a\u61c9\u505c\u7528\u7684\u5957\u4ef6\u3002\u8207 Loki \u548c pypi-scan \u4e00\u6a23\uff0c\u9019\u500b\u958b\u6e90\u5de5\u5177\u4f9d\u8cf4\u65bc\u6350\u8d08\u548c\u793e\u5340\u53c3\u8207\u3002\u7136\u800c\uff0c\u5b83\u662f\u4e00\u500b\u6975\u597d\u7684\u7b2c\u4e00\u9053\u9632\u7dda\uff0c\u60a8\u53ef\u4ee5\u5c07\u5176\u878d\u5165\u65e5\u5e38\u958b\u767c\u6d3b\u52d5\u4e2d\u3002<\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u7c21\u55ae\u3001\u6613\u65bc\u6574\u5408\u7684\u958b\u6e90\u5de5\u5177<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u50c5\u9650\u65bc NodeJS<\/li>\n<\/ul>\n<h3>\u8072\u7d0dQube<\/h3>\n<p>\u6700\u5f8c\u4f46\u4e26\u975e\u6700\u4e0d\u91cd\u8981\u7684\u4e00\u9ede\u662f\uff0c<a href=\"https:\/\/www.sonarqube.org\/features\/security\/\">SonarQube<\/a>\u662f\u4e00\u7a2e\u975c\u614b\u61c9\u7528\u7a0b\u5f0f\u5b89\u5168\u6e2c\u8a66(SAST) \u5de5\u5177\uff0c\u53ef\u4ee5\u6574\u5408\u5230\u958b\u767c\u74b0\u5883\u4e2d\uff0c\u4ee5\u5728\u7a0b\u5f0f\u78bc\u5be9\u67e5\u671f\u9593\u8b58\u5225\u5b89\u5168\u554f\u984c\uff0c\u6216\u7528\u4f5cCI\/CD \u7ba1\u9053\u4e2d\u7684\u8cea\u91cf\u63a7\u5236\u6a5f\u5236\u3002\u5b83\u6703\u81ea\u52d5\u8b58\u5225\u932f\u8aa4\u3001\u5b89\u5168\u6027\u554f\u984c\u3001\u6f0f\u6d1e\u7b49\uff0c\u4e26\u5728\u7d9c\u5408\u5831\u544a\u4e2d\u986f\u793a\u6bcf\u500b\u554f\u984c\u3002 <\/p>\n<p>SonarQube \u53ef\u900f\u904e\u5206\u5c64\u5b9a\u50f9\u6a21\u5f0f\u53d6\u5f97\uff0c\u5f9e\u514d\u8cbb\u793e\u7fa4\u7248\u5230\u57fa\u65bc\u7a0b\u5f0f\u78bc\u5eab\u4e2d\u7a0b\u5f0f\u78bc\u884c\u6578 (LOC) \u7684\u8a02\u95b1\uff0c\u4ee5\u53ca\u4e00\u4e9b\u4e0d\u540c\u7684\u5546\u696d\u652f\u63f4\u9078\u9805\u3002\u8a72\u5de5\u5177\u53d7\u5230\u8a31\u591a\u4e16\u754c\u4e0a\u6700\u5927\u7684\u79d1\u6280\u4f01\u696d\u7684\u4f7f\u7528\u548c\u4fe1\u4efb\uff0c\u56e0\u6b64\uff0c\u5de5\u7a0b\u5e2b\u5728\u5c65\u6b77\u4e2d\u5f15\u7528\u4ed6\u5011\u4f7f\u7528\u8a72\u5de5\u5177\u7684\u7d93\u9a57\u4e26\u4e0d\u7f55\u898b\u3002 <\/p>\n<ul>\n<li><strong>\u512a\u9ede<\/strong>\uff1a\u81ea\u52d5\u5316\u3001\u4e00\u6d41\u7684 SAST \u5de5\u5177<\/li>\n<li><strong>\u7f3a\u9ede<\/strong>\uff1a\u7d93\u5e38\u8fa8\u8b58\u8aa4\u5831 <\/li>\n<\/ul>\n<h2><strong>\u7d50\u8ad6<\/strong><\/h2>\n<p>\u4f5c\u70ba\u5177\u6709\u5b89\u5168\u610f\u8b58\u7684 IT \u5c08\u696d\u4eba\u54e1\uff0c\u6211\u5011\u90fd\u61c9\u8a72\u610f\u8b58\u5230\u5728\u7a0b\u5f0f\u78bc\u4e2d\u4f7f\u7528\u5916\u90e8\u7a0b\u5f0f\u5eab\u548c\u4f9d\u8cf4\u9805\u6240\u6d89\u53ca\u7684\u98a8\u96aa\u3002\u96a8\u8457\u4ea4\u4ed8\u6642\u9593\u7684\u7e2e\u77ed\u548c\u61c9\u7528\u7a0b\u5f0f\u8907\u96dc\u6027\u7684\u589e\u52a0\uff0c\u5c07\u9019\u4e9b\u5916\u90e8\u8cc7\u6e90\u5408\u4f75\u5230\u6211\u5011\u7684\u7a0b\u5f0f\u78bc\u5eab\u4e2d\u662f\u4e0d\u53ef\u907f\u514d\u7684\uff0c\u4f46\u6211\u5011\u958b\u767c\u5b89\u5168\u4e14\u5b9a\u7fa9\u660e\u78ba\u7684\u6d41\u7a0b\u4f86\u964d\u4f4e\u98a8\u96aa\u81f3\u95dc\u91cd\u8981\u3002<\/p>\n<p>\u7576\u60a8\u67e5\u770b\u60a8\u7684\u9078\u9805\u6642\uff0c\u60a8\u6703\u767c\u73fe\u5b89\u5168\u89e3\u6c7a\u65b9\u6848\u9060\u591a\u65bc\u50cf\u9019\u6a23\u7684\u90e8\u843d\u683c\u6587\u7ae0\u6240\u80fd\u5305\u542b\u7684\u5167\u5bb9\uff0c\u56e0\u70ba\u5b58\u5728\u5ee3\u6cdb\u7684\u8edf\u9ad4\u4f9b\u61c9\u93c8\u5a01\u8105\u3002\u96d6\u7136\u60a8\u53ef\u80fd\u6703\u8003\u616e\u7d44\u88dd\u591a\u500b\u89e3\u6c7a\u65b9\u6848\u4f86\u89e3\u6c7a\u76e1\u53ef\u80fd\u5ee3\u6cdb\u7684\u6f0f\u6d1e\u554f\u984c\uff0c\u4f46\u5c07\u591a\u500b\u89e3\u6c7a\u65b9\u6848\u62fc\u6e4a\u5728\u4e00\u8d77\u65e2\u8cbb\u6642\u53c8\u8cbb\u8cc7\u6e90\uff08\u66f4\u4e0d\u7528\u8aaa\u50f9\u683c\u6602\u8cb4\uff09\u3002 <\/p>\n<p>\u76f8\u53cd\uff0c\u8acb\u8003\u616e\u4f7f\u7528\u5168\u9762\u7684\u3001\u958b\u7bb1\u5373\u7528\u7684\u89e3\u6c7a\u65b9\u6848\uff0c\u4f8b\u5982 ActiveState Platform\uff0c\u5b83\u53ef\u4ee5\u5e6b\u52a9\u78ba\u4fdd\u60a8\u7684\u958b\u767c\u4eba\u54e1\u59cb\u7d42\u4f7f\u7528\u5b89\u5168\u6027\u548c\u5b8c\u6574\u6027\u4f86\u4fdd\u8b49\u7684\u958b\u6e90\u5957\u4ef6\u3002\u5f97\u5230\u826f\u597d\u652f\u63f4\u7684\u5168\u9762\u5b89\u5168\u89e3\u6c7a\u65b9\u6848\u53ef\u4ee5\u9650\u5236\u98a8\u96aa\u548c\u66b4\u9732\uff0c\u540c\u6642\u78ba\u4fdd\u60a8\u76e1\u6700\u5927\u52aa\u529b\u78ba\u4fdd\u6bcf\u500b\u4eba\u7684\u5b89\u5168\uff0c\u4e26\u5e6b\u52a9\u7d44\u7e54\u4fdd\u6301\u5728\u9810\u7b97\u9650\u5236\u4e4b\u5167\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168","protected":false},"author":1,"featured_media":5049,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"inline_featured_image":false,"csco_display_header_overlay":false,"csco_singular_sidebar":"","csco_page_header_type":"","footnotes":""},"categories":[526],"tags":[],"ppma_author":[533],"class_list":{"0":"post-5082","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-dev","8":"cs-entry"},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v23.4 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01 - Tenten Blog<\/title>\n<meta name=\"description\" content=\"\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/\" \/>\n<meta property=\"og:locale\" content=\"zh_TW\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01 - Tenten Blog\" \/>\n<meta property=\"og:description\" content=\"\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168\" \/>\n<meta property=\"og:url\" content=\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/\" \/>\n<meta property=\"og:site_name\" content=\"Tenten Blog\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/tentencreative\/\" \/>\n<meta property=\"article:published_time\" content=\"2024-04-04T18:15:31+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-04T18:23:05+00:00\" \/>\n<meta name=\"author\" content=\"Nancy P\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@https:\/\/twitter.com\/tentencreative\" \/>\n<meta name=\"twitter:site\" content=\"@tentencreative\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005:\" \/>\n\t<meta name=\"twitter:data1\" content=\"Nancy P\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9810\u4f30\u95b1\u8b80\u6642\u9593\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 \u5206\u9418\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/\"},\"author\":{\"name\":\"Nancy P\",\"@id\":\"https:\/\/tenten.co\/blog\/#\/schema\/person\/b8f2cfaa5cdbcc9a9be32ad46da81aba\"},\"headline\":\"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01\",\"datePublished\":\"2024-04-04T18:15:31+00:00\",\"dateModified\":\"2024-04-04T18:23:05+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/\"},\"wordCount\":85,\"publisher\":{\"@id\":\"https:\/\/tenten.co\/blog\/#organization\"},\"image\":{\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg\",\"articleSection\":[\"Development\"],\"inLanguage\":\"zh-TW\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/\",\"url\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/\",\"name\":\"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01 - Tenten Blog\",\"isPartOf\":{\"@id\":\"https:\/\/tenten.co\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg\",\"datePublished\":\"2024-04-04T18:15:31+00:00\",\"dateModified\":\"2024-04-04T18:23:05+00:00\",\"description\":\"\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168\",\"breadcrumb\":{\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#breadcrumb\"},\"inLanguage\":\"zh-TW\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-TW\",\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage\",\"url\":\"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg\",\"contentUrl\":\"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg\",\"width\":1400,\"height\":735},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/tenten.co\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/tenten.co\/blog\/#website\",\"url\":\"https:\/\/tenten.co\/blog\/\",\"name\":\"AI SEO by Tenten - AI-Powered SEO + Technical SEO\",\"description\":\"Shopify Plus\u3001Webflow \u8a8d\u8b49\u5c08\u5bb6\uff01Tenten \u5e6b\u4f60\u5feb\u901f\u5efa\u7f6e\u5c08\u696d\u7db2\u7ad9\",\"publisher\":{\"@id\":\"https:\/\/tenten.co\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/tenten.co\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"zh-TW\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/tenten.co\/blog\/#organization\",\"name\":\"AI SEO by Tenten - AI-Powered SEO + Technical SEO\",\"url\":\"https:\/\/tenten.co\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-TW\",\"@id\":\"https:\/\/tenten.co\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/s5.tenten.co\/2023\/12\/site-icon.png\",\"contentUrl\":\"https:\/\/s5.tenten.co\/2023\/12\/site-icon.png\",\"width\":512,\"height\":512,\"caption\":\"AI SEO by Tenten - AI-Powered SEO + Technical SEO\"},\"image\":{\"@id\":\"https:\/\/tenten.co\/blog\/#\/schema\/logo\/image\/\"},\"sameAs\":[\"https:\/\/www.facebook.com\/tentencreative\/\",\"https:\/\/x.com\/tentencreative\",\"https:\/\/www.linkedin.com\/company\/tentenco\",\"https:\/\/www.instagram.com\/tenten.co\",\"https:\/\/www.youtube.com\/user\/tentencreative\",\"https:\/\/dribbble.com\/tentenco\"]},{\"@type\":\"Person\",\"@id\":\"https:\/\/tenten.co\/blog\/#\/schema\/person\/b8f2cfaa5cdbcc9a9be32ad46da81aba\",\"name\":\"Nancy P\",\"description\":\"Experienced Stock Market Researcher and Financial Advisor with a passion for analyzing market trends and helping clients make informed investment decisions. Combining in-depth market knowledge with personalized financial planning to deliver tailored solutions for individuals and businesses.\",\"sameAs\":[\"https:\/\/tenten.co\",\"https:\/\/instagram.com\/tenten.co\",\"https:\/\/www.linkedin.com\/in\/pladoramaria\/\",\"https:\/\/x.com\/https:\/\/twitter.com\/tentencreative\",\"https:\/\/www.youtube.com\/@tentencreative\",\"https:\/\/twitter.com\/erikthought\"],\"url\":\"https:\/\/tenten.co\/blog\/author\/tenten\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01 - Tenten Blog","description":"\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168","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:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/","og_locale":"zh_TW","og_type":"article","og_title":"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01 - Tenten Blog","og_description":"\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168","og_url":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/","og_site_name":"Tenten Blog","article_publisher":"https:\/\/www.facebook.com\/tentencreative\/","article_published_time":"2024-04-04T18:15:31+00:00","article_modified_time":"2024-04-04T18:23:05+00:00","author":"Nancy P","twitter_card":"summary_large_image","twitter_creator":"@https:\/\/twitter.com\/tentencreative","twitter_site":"@tentencreative","twitter_misc":{"\u4f5c\u8005:":"Nancy P","\u9810\u4f30\u95b1\u8b80\u6642\u9593":"1 \u5206\u9418"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#article","isPartOf":{"@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/"},"author":{"name":"Nancy P","@id":"https:\/\/tenten.co\/blog\/#\/schema\/person\/b8f2cfaa5cdbcc9a9be32ad46da81aba"},"headline":"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01","datePublished":"2024-04-04T18:15:31+00:00","dateModified":"2024-04-04T18:23:05+00:00","mainEntityOfPage":{"@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/"},"wordCount":85,"publisher":{"@id":"https:\/\/tenten.co\/blog\/#organization"},"image":{"@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage"},"thumbnailUrl":"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg","articleSection":["Development"],"inLanguage":"zh-TW"},{"@type":"WebPage","@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/","url":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/","name":"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01 - Tenten Blog","isPartOf":{"@id":"https:\/\/tenten.co\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage"},"image":{"@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage"},"thumbnailUrl":"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg","datePublished":"2024-04-04T18:15:31+00:00","dateModified":"2024-04-04T18:23:05+00:00","description":"\u64d4\u5fc3\u4e0b\u8f09\u7684\u8edf\u9ad4\u5b58\u5728\u5b89\u5168\u98a8\u96aa\uff1f\u672c\u6587\u63ed\u9732\u4e94\u5927\u5e38\u88ab\u8aa4\u89e3\u70ba\u5b89\u5168\u7684\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\uff0c\u52a9\u60a8\u8b58\u5225\u6f5b\u5728\u5a01\u8105\uff0c\u4fdd\u969c\u96fb\u8166\u5b89\u5168","breadcrumb":{"@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#breadcrumb"},"inLanguage":"zh-TW","potentialAction":[{"@type":"ReadAction","target":["https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/"]}]},{"@type":"ImageObject","inLanguage":"zh-TW","@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#primaryimage","url":"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg","contentUrl":"https:\/\/s5.tenten.co\/2024\/04\/tenten_45.jpg","width":1400,"height":735},{"@type":"BreadcrumbList","@id":"https:\/\/tenten.co\/blog\/dev\/top-malicious-package-scanners\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/tenten.co\/blog\/"},{"@type":"ListItem","position":2,"name":"\u8edf\u9ad4\u5b89\u5168\u96b1\u60a3\uff1f\u4e94\u5927\u60e1\u610f\u8edf\u9ad4\u6383\u63cf\u5de5\u5177\u63ed\u79d8\uff01"}]},{"@type":"WebSite","@id":"https:\/\/tenten.co\/blog\/#website","url":"https:\/\/tenten.co\/blog\/","name":"AI SEO by Tenten - AI-Powered SEO + Technical SEO","description":"Shopify Plus\u3001Webflow \u8a8d\u8b49\u5c08\u5bb6\uff01Tenten \u5e6b\u4f60\u5feb\u901f\u5efa\u7f6e\u5c08\u696d\u7db2\u7ad9","publisher":{"@id":"https:\/\/tenten.co\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/tenten.co\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"zh-TW"},{"@type":"Organization","@id":"https:\/\/tenten.co\/blog\/#organization","name":"AI SEO by Tenten - AI-Powered SEO + Technical SEO","url":"https:\/\/tenten.co\/blog\/","logo":{"@type":"ImageObject","inLanguage":"zh-TW","@id":"https:\/\/tenten.co\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/s5.tenten.co\/2023\/12\/site-icon.png","contentUrl":"https:\/\/s5.tenten.co\/2023\/12\/site-icon.png","width":512,"height":512,"caption":"AI SEO by Tenten - AI-Powered SEO + Technical SEO"},"image":{"@id":"https:\/\/tenten.co\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/tentencreative\/","https:\/\/x.com\/tentencreative","https:\/\/www.linkedin.com\/company\/tentenco","https:\/\/www.instagram.com\/tenten.co","https:\/\/www.youtube.com\/user\/tentencreative","https:\/\/dribbble.com\/tentenco"]},{"@type":"Person","@id":"https:\/\/tenten.co\/blog\/#\/schema\/person\/b8f2cfaa5cdbcc9a9be32ad46da81aba","name":"Nancy P","description":"Experienced Stock Market Researcher and Financial Advisor with a passion for analyzing market trends and helping clients make informed investment decisions. Combining in-depth market knowledge with personalized financial planning to deliver tailored solutions for individuals and businesses.","sameAs":["https:\/\/tenten.co","https:\/\/instagram.com\/tenten.co","https:\/\/www.linkedin.com\/in\/pladoramaria\/","https:\/\/x.com\/https:\/\/twitter.com\/tentencreative","https:\/\/www.youtube.com\/@tentencreative","https:\/\/twitter.com\/erikthought"],"url":"https:\/\/tenten.co\/blog\/author\/tenten\/"}]}},"authors":[{"term_id":533,"user_id":1,"is_guest":0,"slug":"tenten","display_name":"Nancy P","avatar_url":{"url":"https:\/\/s5.tenten.co\/2024\/06\/Kelly-w.jpg","url2x":"https:\/\/s5.tenten.co\/2024\/06\/Kelly-w.jpg"},"first_name":"Nancy","last_name":"P","user_url":"https:\/\/tenten.co","job_title":"Marketer","tiktok":"","youtube":"https:\/\/www.youtube.com\/@tentencreative","linkedin":"https:\/\/www.linkedin.com\/in\/maria-ning\/","instagram":"https:\/\/instagram.com\/tenten.co","twitter":"https:\/\/twitter.com\/tentencreative","facebook":"","description":"Experienced Stock Market Researcher and Financial Advisor with a passion for analyzing market trends and helping clients make informed investment decisions. Combining in-depth market knowledge with personalized financial planning to deliver tailored solutions for individuals and businesses."}],"_links":{"self":[{"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/posts\/5082","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/comments?post=5082"}],"version-history":[{"count":0,"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/posts\/5082\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/media\/5010"}],"wp:attachment":[{"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/media?parent=5082"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/categories?post=5082"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/tags?post=5082"},{"taxonomy":"author","embeddable":true,"href":"https:\/\/tenten.co\/blog\/wp-json\/wp\/v2\/ppma_author?post=5082"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}