问大家个问题WINEXEC命令好像不支持连接字符串 ( 积分: 50 )

  • 主题发起人 主题发起人 tsedlinux
  • 开始时间 开始时间
T

tsedlinux

Unregistered / Unconfirmed
GUEST, unregistred user!
如下面这条命令
winexec('xcopy //'+IP+'/dmsclient/id.txt c:/ /y',0); //复制标记文件
// xcopy //192.168.0.10/dmsclient/id.txt c:/ /y
相应的变量都赋上相应的值 即与注释中的命令完全相同 但执行后 却不能复制文件
而要如下这样写
winexec('xcopy //192.168.0.10/dmsclient/id.txt c:/ /y',0);
才可以 不知道大家有没有遇到这样的问题
 
WinExec 是 Windows API 函数,必须使用 PChar 转化为 空终止 字符串

winexec(PChar('xcopy //'+IP+'/dmsclient/id.txt c:/ /y',0));

Delphi 中是这样定义的
function WinExec(lpCmdLine: LPCSTR; uCmdShow: UINT): UINT; stdcall;

注意其中的是 LPCSTR 不是 String 类型
LPCSTR 是 PAnsiChar 的类型的别名是字符串数组的指针。
需要用 PChar 转换

相关资料:
WinExec

The WinExec function runs the specified application.

Note This function is provided only for compatibility with 16-bit Windows. Applications should use the CreateProcess function.


UINT WinExec(
LPCSTR lpCmdLine,
UINT uCmdShow
);

Parameters
lpCmdLine
[in] Pointer to a null-terminated character string that contains the command line (file name plus optional parameters) for the application to be executed. If the name of the executable file in the lpCmdLine parameter does not contain a directory path, the system searches for the executable file in this sequence:
The directory from which the application loaded.
The current directory.
The Windows system directory. The GetSystemDirectory function retrieves the path of this directory.
The Windows directory. The GetWindowsDirectory function retrieves the path of this directory.
The directories listed in the PATH environment variable.
uCmdShow
[in] For a list of the acceptable values, see the description of the nCmdShow parameter of the ShowWindow function.
Return Values
If the function succeeds, the return value is greater than 31.

If the function fails, the return value is one of the following error values:

Return Code Description
0 The system is out of memory or resources.
ERROR_BAD_FORMAT The .exe file is invalid.
ERROR_FILE_NOT_FOUND The specified file was not found.
ERROR_PATH_NOT_FOUND The specified path was not found.




Remarks
The WinExec function returns when the started process calls the GetMessage function or a time-out limit is reached. To avoid waiting for the time out delay, call the GetMessage function as soon as possible in any process started by a call to WinExec.

Security Remarks

The executable name is treated as the first white space-delimited string in lpCmdLine. If the executable or path name has a space in it, there is a risk that a different executable could be run because of the way the function parses spaces. The following example is dangerous because the function will attempt to run "Program.exe", if it exists, instead of "MyApp.exe".

WinExec("C:/Program Files/MyApp", ...)
If a malicious user were to create an application called "Program.exe" on a system, any program that incorrectly calls WinExec using the Program Files directory will run this application instead of the intended application.

To avoid this problem, use CreateProcess rather than WinExec. However, if you must use WinExec for legacy reasons, make sure the application name is enclosed in quotation marks as shown in the example below.

WinExec("/"C:/Program Files/MyApp.exe/" -L -S", ...)

Requirements
Client: Included in Windows XP, Windows 2000 Professional, Windows NT Workstation, Windows Me, Windows 98, and Windows 95.
Server: Included in Windows Server 2003, Windows 2000 Server, and Windows NT Server.
Header: Declared in Winbase.h; include Windows.h.
Library: Use Kernel32.lib.
 
接受答案了.
 
后退
顶部