VB中如何实现上传文件的功能?

VB中如何实现上传文件的功能,主要是要实现如用CommonDialog1.ShowOpen后得到的文件上传(复制)到程序运行的目录下的指定目录中(如app.path\co... VB中如何实现上传文件的功能,主要是要实现如用CommonDialog1.ShowOpen后得到的文件上传(复制)到程序运行的目录下的指定目录中(如app.path\content\). 展开
 我来答
149005501
推荐于2017-09-23 · TA获得超过8.6万个赞
知道顶级答主
回答量:7.9万
采纳率:90%
帮助的人:1.3亿
展开全部

用script脚本 直接调用 FTP 命令实现上传文件到FTP服务器。

代码如下:

'定义API函数
Const SYNCHRONIZE = &H100000
Const INFINITE = &HFFFFFFFF
Private Declare Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long

Private Sub Command1_Click()
Dim filename As String
Dim ftp As String
Dim uname As String
Dim upin As String
ftp = InputBox("请输入服务器地址")
uname = InputBox("请输入帐号", , "anonymous")
upin = InputBox("请输入密码", , "IE@User")

filename = Timer() '取时间为文件名filename
Open filename & ".script" For Output As #1 '生成filename.script脚本,传输FTP用
    Print #1, "user"
    Print #1, uname
    Print #1, upin
    Print #1, "pwd"
    Print #1, "hash"
    Print #1, "put " & filename & ".txt"
    Print #1, "quit"
Close #1

Open filename & ".txt" For Output As #1 '生成的filename.txt保存了combo1和text1的文字
    Print #1, Text1.Text
    Print #1, Combo1.Text
Close #1
DoEvents
'调用ftp命令传输,不需要inet或winsock控件
Dim pId As Long, pHnd As Long
pId = Shell("ftp -n -s:" & filename & ".script" & " " & ftp, vbHide)
pHnd = OpenProcess(SYNCHRONIZE, 0, pId)
If pHnd <> 0 Then
Call WaitForSingleObject(pHnd, INFINITE)
Call CloseHandle(pHnd)
End If
Kill filename & ".script" '因为script脚本保存了帐号和密码,当传输完成后删除filename.script脚本
End Sub
BlueEnchanter
推荐于2017-10-14 · TA获得超过199个赞
知道小有建树答主
回答量:339
采纳率:66%
帮助的人:178万
展开全部
Dim InPutFile As String
Dim OutPutFile As String

Private Sub cmdChoose_Click()
CommonDialog1.ShowOpen
InPutFile = CommonDialog1.FileName
txtFileLoad.Text = InPutFile
End Sub

Private Sub cmdExit_Click()
End
End Sub

Private Sub cmdUpload_Click()
If InPutFile = "" Then
MsgBox "Choose a File first!"
Exit Sub
End If
OutPutFile = GetNameFromFilePath(InPutFile)
FileCopy InPutFile, App.Path & "\" & OutPutFile & ""
MsgBox "The File has already uploaded!"
End Sub

Private Sub Form_Load()
InPutFile = ""
txtFileLoad.Text = "Choose The File"
cmdChoose.Caption = "Choose"
cmdUpload.Caption = "Upload"
cmdExit.Caption = "Exit"

txtFileLoad.Enabled = False
End Sub

Public Function GetNameFromFilePath(ByVal strFullPath As String, Optional ByVal strSplitor As String = "\") As String
Dim thePath As String

thePath = Left$(strFullPath, InStrRev(strFullPath, strSplitor, , vbTextCompare))
GetNameFromFilePath = Mid(InPutFile, Len(thePath) + 1, Len(InPutFile))
End Function
====================
我这个程序只能算是复制文件,复制的文件放在程序目录下
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ihss23
2007-04-09 · TA获得超过701个赞
知道小有建树答主
回答量:1472
采纳率:0%
帮助的人:1336万
展开全部
因为我也在找这个问题,所以和你一同在等.还请别生气.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式