Просмотр файла ftp/inst.php

Размер файла: 5.79Kb
<?php
error_reporting(0);
$k=trim($_GET['k']); include("key.php");
$d=rawurldecode(trim($_GET['d'])); $n=rawurldecode(trim($_GET['n']));
if ($d==NULL) {$d="";} if ($n==NULL) {$n=preg_replace("~.*/([^/]*)~m","\\1",$d);
$d=preg_replace("~(.*)/[^/]*~m","\\1",$d);}
$rd=rawurlencode($d); $rn=rawurlencode($n);
$d=str_replace(".|htaccess",".htaccess",$d); $n=str_replace(".|htaccess",".htaccess",$n);
$nm=trim($_POST['nm']); $csr=trim($_POST['csr']); $cus=trim($_POST['cus']);
$cps=trim($_POST['cps']); $cbd=trim($_POST['cbd']); $dp=trim($_POST['dp']);
$cr=trim($_POST['cr']); $in=trim($_POST['in']);
if ($nm<>NULL) {
 $repl=array("\\"=>"","/"=>"",":"=>"","*"=>"","?"=>"","\""=>"","<"=>"",">"=>"",
 "|"=>"","`"=>""," "=>"_");
 $nm=trim(strtr($nm,$repl));
 include("repl.php"); $nm=u2t($nm);
 if (($nm==".")||($nm=="..")) {$nm="";}
}

if (($nm==NULL)||(($dp==NULL)&&($cr==NULL)&&($in==NULL))) {
 $num=@file_get_contents("allnumbd.dat");
 $num++; if ($num>9999999) {$num=0;}
 $f=@fopen("allnumbd.dat","w"); @fwrite($f,$num); @fclose($f);
 $d=str_replace('$','$$',$d); $n=str_replace('$','$$',$n);
header("Cache-Control: no-cache, must-revalidate");
header("Content-Type: text/vnd.wap.wml; charset=Utf-8");
echo ("<?xml version=\"1.0\" encoding=\"Utf-8\"?><!DOCTYPE wml PUBLIC \"-//WAPFORUM//DTD WML 1.2//EN\" \"http://www.wapforum.org/DTD/wml_1.2.xml\"><wml>
<head><meta forua=\"true\" http-equiv=\"Cache-Control\" content=\"no-cache,no-store,must-revalidate\"/></head><card title=\"FTP - Создать установщик\">
<p align=\"left\"><small>
<a href=\"ftp.php?k=$k&amp;d=$rd\">$d/</a><a href=\"file.php?k=$k&amp;d=$rd&amp;n=$rn\">$n</a><br/>
- - -<br/>
Имя:</small><input name=\"nm".$num."\" type=\"text\" value=\"install.php\" maxlength=\"150\"/><br/><small>
Сервер:</small><input name=\"csr".$num."\" type=\"text\" value=\"localhost\" maxlength=\"150\"/><br/><small>
Пользователь:</small><input name=\"cus".$num."\" type=\"text\" value=\"\" maxlength=\"150\"/><br/><small>
Пароль:</small><input name=\"cps".$num."\" type=\"text\" value=\"\" maxlength=\"150\"/><br/><small>
БД:</small><input name=\"cbd".$num."\" type=\"text\" value=\"\" maxlength=\"150\"/><br/>
<select name=\"dp\" multiple=\"true\" value=\"1\"><option value=\"1\">DROP</option></select>
<select name=\"cr\" multiple=\"true\" value=\"1\"><option value=\"1\">CREATE</option></select>
<select name=\"in\" multiple=\"true\" value=\"1\"><option value=\"1\">INSERT</option></select><br/>
<small><anchor>Создать
<go href=\"$dftp/inst.php?k=$k&amp;d=$rd&amp;n=$rn\" method=\"post\">
<postfield name=\"nm\" value=\"$(nm".$num.")\"/>
<postfield name=\"csr\" value=\"$(csr".$num.")\"/>
<postfield name=\"cus\" value=\"$(cus".$num.")\"/>
<postfield name=\"cps\" value=\"$(cps".$num.")\"/>
<postfield name=\"cbd\" value=\"$(cbd".$num.")\"/>
<postfield name=\"dp\" value=\"$(dp)\"/>
<postfield name=\"cr\" value=\"$(cr)\"/>
<postfield name=\"in\" value=\"$(in)\"/>
</go></anchor><br/>
- - -<br/>
<anchor>Назад<prev/></anchor>
</small></p>
</card></wml>");
} else {
 if (($ftp=ftp_connect($sr))&&(ftp_login($ftp,$lg,$ps))) {
  @ftp_pasv($ftp,true); $sz=@ftp_size($ftp,"$d/$n");
  if (($sz<1)||($sz>204800)) {header("Location: $dftp/ftp.php?k=$k&d=$rd"); exit;}
  @ftp_get($ftp,"data/$k.txt","$d/$n",FTP_BINARY);

  $drop=1; $create=1; $insert=1;
  if ($dp<>1) {$drop=0;} if ($cr<>1) {$create=0;} if ($in<>1) {$insert=0;}

  $sql=file_get_contents("data/$k.txt");
  $sql=str_replace("\r\n","\n",$sql); $sql=str_replace("\n","\r",$sql);
  $sql=preg_replace("~(--|##)[^\r]*\r~","\r",$sql);
  $sql=preg_replace("~\r\s*\r~","\r",$sql);

  $fd='';
  if ($drop==1) {$fd.='DROP';}
  if ($create==1) {if ($drop==1) {$fd.='|';} $fd.='CREATE';}
  if ($insert==1) {if (($create==1)||($drop==1)) {$fd.='|';} $fd.='INSERT';}
  preg_match_all("~(".$fd.").*(\r[)][^()]*)?;~iU",$sql,$ar);
  $cnt=count($ar[0]); if ($cnt>999) {$cnt=999;}

  $f=@fopen("data/$k.txt","w");
  @fwrite($f,'<?php'."\r\n/*Punk77-FTP (http://mysiem.net/ftp)*/\r\n".'header("Content-Type: text/vnd.wap.wml; charset=utf-8");'."\r\n".'echo("<?xml version=\"1.0\" encoding=\"utf-8\"?><!DOCTYPE wml PUBLIC \"-//WAPFORUM//DTD WML 1.2//EN\" \"http://www.wapforum.org/DTD/wml_1.2.xml\"><wml><head><meta forua=\"true\" http-equiv=\"Cache-Control\" content=\"no-cache,no-store,must-revalidate\"/></head><card title=\"Install\"><p><small>\r\n");'."\r\n".'$ms=mysql_connect("'.$csr.'","'.$cus.'","'.$cps.'") or exit("Connect Failed");'."\r\n".'mysql_select_db("'.$cbd.'") or exit("Database Not Select");'."\r\n".'echo("--BEGIN--<br/><br/>\r\n");'."\r\n");

  for ($i=0;$i<$cnt;$i++) {
   if (strtolower(trim($ar[1][$i]))=='drop') {
     @fwrite($f,'$query="'.trim(str_replace('"','\"',str_replace("\r","",$ar[0][$i]))).'";'."\r\n".'mysql_query($query);'."\r\n");
   } elseif (strtolower(trim($ar[1][$i]))=='create') {
     @fwrite($f,'$query="'.trim(str_replace('"','\"',str_replace("\r","",$ar[0][$i]))).'";'."\r\n".'$r=mysql_query($query);'."\r\n".'if (!$r) {echo("Error!! CREATE TABLE \"'.preg_replace("~\s*CREATE TABLE[^(;`]*[`]?([^\s(`]*)[`]?\s*[(].*~i","\\1",str_replace("\r","",$ar[0][$i]),1).'\"<br/>\r\n");}'."\r\n");
   } elseif (strtolower(trim($ar[1][$i]))=='insert') {
     @fwrite($f,'$query="'.trim(str_replace('"','\"',str_replace("\r","",$ar[0][$i]))).'";'."\r\n".'mysql_query($query);'."\r\n");
   }
  }

  @fwrite($f,'mysql_close($ms);'."\r\n".'echo("<br/>--AND--\r\n</small></p></card></wml>");'."\r\n".'?>');
  @fclose($f);

  @ftp_put($ftp,"$d/$nm","data/$k.txt",FTP_BINARY);

  @ftp_close($ftp); @unlink("data/$k.txt");
  header("Location: $dftp/ftp.php?k=$k&d=$rd"); exit;
 } else {
echo("<p align=\"center\"><small>
Нет соединения с сервером.<br/>
- - -<br/>
<anchor>Назад<prev/></anchor>
</small></p>
</card></wml>");
 }
}
?>