LionSpain Posted January 4, 2019 Posted January 4, 2019 (edited) Im trying make a File Sender TCP for update all clients when I update Client.exe the problem is... If i change Local $sFile = FileOpenDialog('Seleccione el archivo a ejecutar', @ScriptDir, 'ALL (*.*)') ;Working for Local $sFile = FileOpen(ClientUpdate\Client.exe) No Work I no want always FileOpenDialog because is more faster click Updater and update all clients This is my Code SERVER Case $Disk Local $sSelected = _ItemSelect() TCPSend($sConections[$sSelected][0], 'Disk') Local $sFile = FileOpen('ClientsUpdate\Client.exe') Local $sEXT = StringSplit($sFile, '.', 1) Local $sEnd = UBound($sEXT) - 1 TCPSend($sConections[$sSelected][0], $sEXT[$sEnd]) Local $sFileopen = FileOpen($sFile) While 1 TCPSend($sConections[$sSelected][0], $sFile) Local $sFileopen = FileOpen($sFile) While 1 Local $sData = FileRead($sFileopen, 2048) If @error Then ExitLoop TCPSend($sConections[$sSelected][0], $sData) If @error Then ExitLoop WEnd FileClose($sFileopen) TCPSend($sConections[$sSelected][0], 'OK') Client if $sAcciones = 'Disk' then do Local $sExt = TCPRecv($sConect, 1024) until $sExt <> '' Local $sOpen = FileOpen(@ScriptDir & '\Client.' & $sExt, 18) Do Local $sData = TCPRecv($sConect, 2048) If @error Then ExitLoop 2 If StringRight($sData, 2) = 'OK' Then ExitLoop FileWrite($sOpen, $sData) Until False FileClose($sOpen) ShellExecute(@ScriptDir & '\Client.' & $sExt) EndIf Edited January 4, 2019 by LionSpain
BrewManNH Posted January 4, 2019 Posted January 4, 2019 FileOpenDialog returns a file name with its path. FileOpen returns a handle to the file, they're not the same thing and you should just use the filename with full path instead of using FileOpen. If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag GudeHow to ask questions the smart way! I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from. Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays. - ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script. - Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label. - _FileGetProperty - Retrieve the properties of a file - SciTE Toolbar - A toolbar demo for use with the SciTE editor - GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI. - Latin Square password generator
LionSpain Posted January 4, 2019 Author Posted January 4, 2019 12 minutes ago, BrewManNH said: FileOpenDialog returns a file name with its path. FileOpen returns a handle to the file, they're not the same thing and you should just use the filename with full path instead of using FileOpen. You say this? Case $Disk Local $sSelected = _ItemSelect() TCPSend($sConections[$sSelected][0], 'Disk') Local $sFile = @ScriptDir &'\ClientsUpdate\Client.exe' Local $sEXT = StringSplit($sFile, '.', 1) Local $sEnd = UBound($sEXT) - 1 TCPSend($sConections[$sSelected][0], $sEXT[$sEnd]) Local $sFileopen = FileOpen($sFile) While 1 TCPSend($sConections[$sSelected][0], $sFile) Local $sFileopen = FileOpen($sFile) While 1 Local $sData = FileRead($sFileopen, 2048) If @error Then ExitLoop TCPSend($sConections[$sSelected][0], $sData) If @error Then ExitLoop WEnd FileClose($sFileopen) TCPSend($sConections[$sSelected][0], 'OK')
BrewManNH Posted January 4, 2019 Posted January 4, 2019 Yes, because trying to use the file handle instead of the file name wouldn't work. Use the filename where you need a file name, and a handle where you need the handle. If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag GudeHow to ask questions the smart way! I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from. Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays. - ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script. - Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label. - _FileGetProperty - Retrieve the properties of a file - SciTE Toolbar - A toolbar demo for use with the SciTE editor - GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI. - Latin Square password generator
LionSpain Posted January 5, 2019 Author Posted January 5, 2019 19 hours ago, BrewManNH said: Yes, because trying to use the file handle instead of the file name wouldn't work. Use the filename where you need a file name, and a handle where you need the handle. No work, just download a file 0kb and some times 180MB and original file is 850kb
BrewManNH Posted January 5, 2019 Posted January 5, 2019 If you're sending an .EXE file make sure you open it in binary mode, because the first time it hits a CHR(0) it will stop. If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag GudeHow to ask questions the smart way! I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from. Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays. - ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script. - Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label. - _FileGetProperty - Retrieve the properties of a file - SciTE Toolbar - A toolbar demo for use with the SciTE editor - GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI. - Latin Square password generator
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now