Yo, desde hace años utilizo el siguiente programa para subir ficheros por ftp, no he tenido ningún problema. Es para xharbour, son ficheros de texto. Este código lo saqué de éste foro ha ce años.
Code: Select all | Expand
#include "fivewin.ch"
#include "xbrowse.ch"
#include "Directry.ch"
memvar Publicas
//*************************
Function subirf()
local aAlias,j,cNom,cFicheros,cdestino,cArcOri,cNomarc
local Ficheros:=Directory( Publicas:cUnidad+"ficheros\*.txt" )
Local oFTP
local oUrl
Local cServer := Publicas:cserver //change ftpserver to the real name or ip of your ftp server
Local cUser := Publicas:cUser // change ftpuser to an valid user on ftpserer
Local cPassword := Publicas:cPassword // change ftppass to an valid password for ftpuser
Local cUrl := "ftp://" + cUser + ":" + cPassword + "@" + cServer
cUser:= strtran(cUser,"@","&at;")
oUrl := tUrl():New( cUrl )
IF At( "@", cUser ) > 0
oUrl:cUserID := strtran(cUser,"&at;","@")
oUrl:cPassword := cPassword
ENDIF
oFTP := tIPClientFtp():New( oUrl, .F. )
oFTP:nConnTimeout := 20000
oFTP:bUsePasv := .T.
if .not. oFtp:open()
msginfo("ftp error "+oFtp:LastErrorMessage())
return(.f.)
endif
oFTP:Open( )
aAlias:=cargaAlias()
dbUseArea(.T.,,Publicas:cUnidad+Publicas:cSubd+"\PROVE",aAlias[21],.T.)
(aAlias[21])->(OrdSetFocus("Codigo"))
(aAlias[21])->( dbGotop() )
if len (ficheros)>0
for j = 1 to len (Ficheros)
cNom := SUBSTR(Ficheros[J,1], -12 )
aadd(Ficheros[j],nombre(cNom,aAlias))
next j
cFicheros:=Selecciona(Ficheros)
if len(cFicheros)>0
if msgyesno("QUIERES SUBIR AL SERVIDOR "+alltrim(str(len(cFicheros)))+" FICHEROS?","AVISO")
FOR J := 1 TO LEN(cFicheros)
cArcOri := Publicas:cUnidad+"ficheros\"+Ficheros[cFicheros[J],1]
cNomArc := SUBSTR(cArcOri,-12 )
oftp:UploadFile( cARcOri,Publicas:cRutafiles+cNomarc )
Ferase( cArcOri )
NEXT J
msgwait("Hemos subido "+alltrim(str(len(cFicheros)))+" Ficheros al servidor","AVISO",2)
else
msgwait("No has elegido ningun fichero para subir al servidor","AVISO",2)
endif
else
msgwait("No has elegido ningun fichero para la subida al servidor","AVISO",2)
endif
else
msgwait("Lo siento no hay ficheros para Subir al Servidor","AVISO",2)
endif
(aAlias[21])->( dbClosearea() )
*borrafich()
return nil
//*******************************
Static function nombre(busca,aAlias)
local nombrec
busca:=substr(busca,1,5)
(aAlias[21])->(Dbseek(busca))
nombrec:=(aAlias[21])->Nombre
Return nombrec
//***********************
static Function Selecciona(carchivo)
LOCAL oDlg, oLbx,oWnd,oboton,aselect:=0
LOCAL oFont, oMultiSel, oBmpOn, oBmpOff,oBrw
DEFINE BITMAP oBmpOn RESOURCE "bmpenable"
DEFINE BITMAP oBmpOff RESOURCE "bmpdisable"
DEFINE FONT oFont NAME 'MS Sans Serif' SIZE 0,-8
DEFINE DIALOG oDlg FROM 1, 1 TO 25,90 TITLE "Subida de ficheros al servidor"
@ 10,10 XBROWSE oBrw SIZE -55,-10 PIXEL OF oDlg ;
COLUMNS 1,6 ;
DATASOURCE carchivo;
CELL LINES NOBORDER
WITH OBJECT oBrw
:l2007 := .F.
:lFooter := .T.
:lHScroll := .T.
:nColDividerStyle := LINESTYLE_NOLINES
:nRowDividerStyle := LINESTYLE_NOLINES
:nRowHeight := 20
:lAllowColSwapping := .F.
:lColDividerComplete := .T.
:nStretchCol := STRETCHCOL_WIDEST
:bClrSelFocus := { || { CLR_RED, nRGB( 255, 188, 130 ) } }
:aCols[1]:cHeader:= " Fichero "
:aCols[2]:cHeader:= " Cliente "
:cTitle:= "Selecciona los ficheros para subir al servidor"
:nMarqueeStyle = MARQSTYLE_HIGHLROWMS //6
:lRecordSelector = .T.
:aCols[1]:bFooter := { || "Total archivos: " + LTrim( TransForm( obRw:nLen, "999,999" ) ) }
:CreateFromCode()
END
@ 30,300 BTNBMP OF oDlg SIZE 50,15 2007 NOBORDER PROMPT " Ninguno" FONT oFont LEFT RESOURCE "aspa" ACTION (obrw:aSelected:={},oDlg:End())
@ 100,300 BTNBMP OF oDlg SIZE 50,15 2007 NOBORDER PROMPT " Subir" FONT oFont LEFT RESOURCE "copidat" ACTION (aselect:=1,oDlg:End())
ACTIVATE DIALOG oDlg CENTERED
RELEASE BITMAP oBmpOn, oBmpOff
RELEASE FONT oFont
return iif(aselect=1,obrw:aSelected,obrw:aSelected:={})
//******
Function borrafich()
local lficheros,llongitud,lnumfiles,i
/*
lficheros := Array( ADir( Publicas:cUnidad+"*.log" ) )
llongitud := Array( ADir( Publicas:cUnidad+"*.log" ) )
lnumFiles := aDir (Publicas:cUnidad+"*.log", lficheros, llongitud)
FOR i:=1 TO lnumFiles
Ferase(Publicas:cUnidad+lficheros[i])
NEXT
*/
lficheros := Array( ADir( "ftp*.log" ) )
llongitud := Array( ADir( "ftp*.log" ) )
lnumFiles := aDir ("ftp*.log", lficheros, llongitud)
FOR i:=1 TO lnumFiles
Ferase(lficheros[i])
NEXT
Return nil