Código PHP:
//Requeridos
include '../req/config.inc.php';
$cid = ftp_connect("dominio.com");
$resultado = ftp_login($cid, "usuario","contraseña");
if ((!$cid) || (!$resultado)) {
echo "Fallo en la conexión"; die;
} else {
echo "Conectado.";
}
ftp_pasv ($cid, true) ;
echo "<br> Cambio a modo pasivo<br />";
ftp_chdir($cid, "/mi/carpeta/images/");
echo "Cambiado al directorio necesario";
$query = mysql_query ("SELECT * FROM products");
while ($row = mysql_fetch_array($query))
{
$local = $_SERVER['DOCUMENT_ROOT'] . '/mi/carpeta/images/'.$row['products_image'].'';
$remoto = '/www/mi/carpeta/images/'.$row['products_image'].'';
echo "<br />$local<br />";
echo "$remoto<br />";
echo "subiendo el archivo...<br />";
$ruta = "/www/mi/carpeta/images/" . $local;
ftp_put($cid, $remoto, $local, FTP_BINARY);
echo "Ruta: " . $ruta;
}
ftp_close($cid);
mi consulta es la siguiente, quiero evitar que se suban los archivos que ya estan en la web, asi reducimos consumo de ancho de banda y tiempo, ya que no es una imagen, si no mas de 500, me vi en la obligacion de incrementar el tiempo de carga de los archivos por lo mismo. Quiero evitar toda esa carga incesesarias haciendo la comparacion, en php.net encontre varias formas de evitar el problema, por ejemplo obtener la lista en un array y resulta esto
Código:
pero sinceramente no se como hacer la comparacion. otra forma "barata" de evitarse el tiempo limite de espera era resetearlo cada vez que termina el while, pero no es tan solo eso lo que busco, quiero evitar carga incesaria, ya que se actualizara unas 7 veces por dia, si sumamos ancho de banda es realmente alto.array(3) { [0]=> string(65) "drwxr-x--- 3 vincent vincent 4096 Jul 12 12:16 public_ftp" [1]=> string(66) "drwxr-x--- 15 vincent vincent 4096 Nov 3 21:31 public_html" [2]=> string(73) "lrwxrwxrwx 1 vincent vincent 11 Jul 12 12:16 www -> public_html" }
y mi segunda duda es que quiero lograr quizas una especie de contador en tiempo real, hacer un mysql_num_rows() a la db, y cada vez que se suba un archivo obtener algo asi como "N de 100" donde N es el numero de archivos que lleva.
alguien me puede ayudar?, principalmente en lo primero, que es lo que reealmente me interesa.
saludos!