pg_dump是一个postgresql备份工具
在dos下备份的格式是这样的:>pg_dump -U postgres -W  database1 > c:\backup.tar
>password:输入完密码后开始备份。难点就在这输入密码,和输出文件。从网上查到一个是vb的例子比较接近我的意图。可惜vb学得不深,看不太明白。望大侠能翻成delphi的代码,谢谢。怎么实现dos下runas自动输入密码
http://bbs.pfan.cn/post-278076.htmlOption Explicit
Private Const LOGON_WITH_PROFILE = &H1&
Private Const CREATE_DEFAULT_ERROR_MODE = &H4000000
Private Const CREATE_NEW_CONSOLE = &H10&
Private Const CREATE_NEW_PROCESS_GROUP = &H200&Private Type PROCESS_INFORMATION
  hProcess As Long
  hThread As Long
  dwProcessId As Long
  dwThreadId As Long
End TypePrivate Type STARTUPINFO
  cb As Long
  lpReserved As Long
  lpDesktop As Long
  lpTitle As Long
  dwX As Long
  dwY As Long
  dwXSize As Long
  dwYSize As Long
  dwXCountChars As Long
  dwYCountChars As Long
  dwFillAttribute As Long
  dwFlags As Long
  wShowWindow As Integer
  cbReserved2 As Integer
  lpReserved2 As Byte
  hStdInput As Long
  hStdOutput As Long
  hStdError As Long
End TypePrivate Declare Function CreateProcessWithLogon Lib "advapi32" Alias "CreateProcessWithLogonW" (ByVal lpUsername As Long, ByVal lpDomain As Long, ByVal lpPassword As Long, ByVal dwLogonFlags As Long, ByVal lpApplicationName As Long, ByVal lpCommandLine As Long, ByVal dwCreationFlags As Long, ByVal lpEnvironment As Long, ByVal lpCurrentDirectory As Long, lpStartupInfo As STARTUPINFO, lpProcessInfo As PROCESS_INFORMATION) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
'以下函数用制定名和密码调用了应用程序
Private Function AnShell(Username As String, Domain As String, Password As String, ApplicationName As String) As Long
  Dim lpUsername As String, lpDomain As String, lpPassword As String, lpApplicationName As String,     lpCommandLine As String, lpCurrentDirectory As String
Dim StartInfo As STARTUPINFO, ProcessInfo As PROCESS_INFORMATION
lpUsername = Username
lpDomain = Domain
lpPassword = Password
lpApplicationName = ApplicationName
lpCommandLine = vbNullString
lpCurrentDirectory = vbNullString
StartInfo.cb = LenB(StartInfo)
StartInfo.dwFlags = 0&
CreateProcessWithLogon StrPtr(lpUsername), StrPtr(lpDomain), StrPtr(lpPassword), LOGON_WITH_PROFILE, StrPtr(lpApplicationName), StrPtr(lpCommandLine), CREATE_DEFAULT_ERROR_MODE Or CREATE_NEW_CONSOLE Or CREATE_NEW_PROCESS_GROUP, ByVal 0&, StrPtr(lpCurrentDirectory), StartInfo, ProcessInfo
CloseHandle ProcessInfo.hThread
CloseHandle ProcessInfo.hProcess
AnShell = ProcessInfo.dwProcessId
End Function
Private Sub Form_Click()
'用刚刚建立的管理员运行一个程序,这里是记事本,参数1为用户名,参数2为域(一般为空就可以了,因为是本机),参数3为要运行的程序路径和名字(这里调用的是WINDOWS下的程序,所以WINDOWS会自己找到的,程序运行时的几个PATH是WINDOWS,SYSTEM,SYSTEM32,APP.PATH,当然可以通过修改WINDOWS的PATH来改变) 请访问:http://www.cnnic-qd.cn/it/index.html
AnShell "administrator", "", "12", "c:\radmin.exe"
End
End Sub

解决方案 »

  1.   

    CreateProcessWithLogon,指定以管理员方式运行程序
    另外,如果没猜错,这段代码不完整,完整的代码应该是自己建立了一个管理员账号,然后用CreateProcessWithLogon调用那个账号登陆的
      

  2.   

    命令行的? 写代码要用管道直接用输入重定向试试如:建一个纯文本 cmd.txt 包括 q 后面要多一空行f 100 LFF AA BB
    d 100
    q
    然后
    C:\debug<cmd.txt
    就执行哪个命令序列了
      

  3.   


    我知道一种已经试过成功“批处理”做法是这样的:
    ---------------------------------------------
    echo set pws=WScript.CreateObject("WScript.Shell")>%temp%\pws.vbs
    echo pws.SendKeys "123{ENTER}">>%temp%\pws.vbs
    wscript %temp%\pws.vbs&"%pgPath%\pg_dump.exe" -i -h localhost -p 5432 -U postgres  -F c -b -v -f "d:\backup\%Dirname%\%Filename%" database1------------------------------------------
    但是我想把密码封闭起来,所以不想用这个方法。
      

  4.   

    密码不可能封闭起来,用CreateProcessWithLogon也要输入密码,只不过没那么容易找到而已