求教一个WINSOCK向服务器上传的问题.

caixicn 2006-01-11 12:43:32
传到服务器时会出现错误,但用WEB传不会出现.
请前辈帮我修正以下代码:


Dim blnConnected As Boolean

Private Sub Command1_Click()

If blnConnected Then Exit Sub

Dim postSize As Long
Dim postData As String
Dim postHeader As String
Dim strHttp As String

filePath = "C:\ddd.EXE"
fileContent = GetFileContents(filePath)

'测试
postData = "-----------------------------7d6251223700b8" & vbCrLf
postData = postData & "Content-Disposition: form-data; name=""image1""; filename=""" & filePath & """" & vbCrLf
postData = postData & "Content-Type: application/octet-stream" & vbCrLf & vbCrLf
postData = postData & fileContent & vbCrLf


postData = postData & "-----------------------------7d6251223700b8" & vbCrLf
postData = postData & "Content-Disposition: form-data; name=""submit""" & vbCrLf & vbCrLf

postData = postData & "submit" & vbCrLf
postData = postData & "-----------------------------7d6251223700b8--" & vbCrLf & vbCrLf

postSize = Len(postData)
'MsgBox postSize

postHeader = "POST /test/imageupload.asp HTTP/1.1" & vbCrLf
postHeader = postHeader & "Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*" & vbCrLf
postHeader = postHeader & "Referer: http://127.0.0.1/imageupload.htm" & vbCrLf
postHeader = postHeader & "Accept-Language: zh-cn" & vbCrLf
postHeader = postHeader & "Content-Type: multipart/form-data; boundary=---------------------------7d6ab313700b8" & vbCrLf
postHeader = postHeader & "UA -CPU: x86" & vbCrLf
postHeader = postHeader & "Accept-Encoding: gzip , deflate" & vbCrLf
postHeader = postHeader & "User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; SV1; Maxthon; .NET CLR 1.1.4322; icast 0.1214)" & vbCrLf
postHeader = postHeader & "Host: 127.0.0.1" & vbCrLf
postHeader = postHeader & "Content-Length: " & postSize & vbCrLf
postHeader = postHeader & "Connection: Keep-Alive" & vbCrLf
postHeader = postHeader & "cache-Control: no-cache" & vbCrLf
postHeader = postHeader & "Cookie: ASPSESSIONIDQADCDABC=MCHJBLEBMBBHMOELCOAKICDO" & vbCrLf & vbCrLf

strHttp = postHeader & postData

Winsock1.Protocol = sckTCPProtocol
Winsock1.RemoteHost = "www.0069.cn"
Winsock1.RemotePort = 80
' make the connection and send the HTTP request
Winsock1.Connect

While Not blnConnected
DoEvents
Wend

txtRequest.Text = strHttp
Winsock1.SendData strHttp

End Sub

Private Function GetFileContents(ByVal strPath As String) As String
Dim StrReturn As String
Dim lngLength As Long

lngLength = FileLen(strPath)
StrReturn = String(lngLength, Chr(0))

On Error GoTo ERR_HANDLER

Open strPath For Binary As #1

Get #1, , StrReturn

GetFileContents = StrReturn

Close #1

Exit Function

ERR_HANDLER:
MsgBox Err.Description, vbCritical, "ERROR"

Err.Clear
End Function
...全文
119 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
celevantis 2006-01-18
  • 打赏
  • 举报
回复
UP
kmlxk0 2006-01-14
  • 打赏
  • 举报
回复
study..
yoyo9250 2006-01-14
  • 打赏
  • 举报
回复
用call copymemory API函数
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
试试看吧
faysky2 2006-01-13
  • 打赏
  • 举报
回复
UP
一、WinSock简介 Socket(套接字)最初是由加利福尼亚大学Berkeley(伯克利)分校为UNIX操作系统开发的网络通信接口,随着UNIX的广泛使用,Socket成为当前最流行的网络通信应用程序接口之一。20世纪90年代初,由Sun Microsystems,JSB,FTP software,Microdyne和Microsoft等几家公司共同定制了一套标准,即Windows Socket规范,简称WinSock。 VB编写网络程序主要有两种方式:1.winsock控件 2.winsockAPI 二、WinSock控件的使用 1.WinSock控件的主要属性 LocalHostName属性 本地机器名 LocalIP属性 本地机器IP地址 LocalPort属性 本地机器通信程序的端口(0<端口<65536) RemoteHost属性 远程机器名 RemotePort属性 远程机器的通信程序端口 Protocol属性 通过Protocol属性可以设置WinSock控件连接远程计算机使用的协议。可选的协议是TCP和UDP对应的VB的常量分别是sckTCPProtocol和sckUDPProtocol,Winsock控件默认协议是TCP。注意:虽然可以在运行时设置协议,但必须在连接未建立或断开连接后。 SocketHandle属性 返回当前socket连接的句柄,这是只读属性。 RemoteHostIP属性 属性返回远程计算机的IP地址。在客户端,当使用了控件的Connect方法后,远程计算机的IP地址就赋给了RemoteHostIP属性,而在服务器端,当ConnectRequest事件后,远程计算机(客户端)的IP地址就赋给了这个属性。如果使用的是UDP协议那么当DataArrival事件后,发送UDP报文的计算机的IP才赋给了这个属性。 ByteReceived属性 返回当前接收缓冲区中的字节数 State属性 返回WinSock控件当前的状态 常数 值 描述 sckClosed 0 缺省值,关闭。 SckOpen 1 打开。 SckListening 2 侦听 sckConnectionPending 3 连接挂起 sckResolvingHost 4 识别主机。 sckHostResolved 5 已识别主机 sckConnecting 6 正在连接。 sckConnected 7 已连接。 sckClosing 8 同级人员正在关闭连接。 sckError 9   错误 2.WinSock主要方法 Listen方法 方法用于服务器程序,等待客户访问。格式:Winsock对象.listen Connect方法 用于向远程主机发出连接请求。格式:Winsock对象.connect [远程主机IP,远程端口] Accept方法 用于接受一个连接请求。格式:Winsock对象.accept Request ID Senddata方法 用于发送数据。格式:Winsock对象.senddata 数据 Getdata方法 用来取得接收到的数据。格式:Winsock对象.getdata 变量 [,数据类型 [,最大长度]] Close方法 关闭当前连接。格式:Winsock对象.close Bind方法 用Bind方法可以把一个端口号固定为本控件使用,使得别的应用程序不能再使用这个端口。 Listen方法Listen方法只在使用TCP协议时有用。它将应用程序置于监听检测状态。 Connect方法 当本地计算机希望和远程计算机建立连接时,就可以调用Connect方法。Connect方法调用的规范为:Connect RemoteHost,RemotePort Accept方法 当服务器接收到客户端的连接请求后,服务器有权决定是否接受客户端的请求。 SendData方法当连接建立后,要发送数据就可以调用SendData方法,该方法只有一个参数,就是要发送的数据。 GetData方法 当本地计算机接收到远程计算机的数据时,数据存放在缓冲区中,要从缓冲区中取出数据,可以使用GetData方法。GetData方法调用规范如下:GetData

1,453

社区成员

发帖
与我相关
我的任务
社区描述
VB 控件
社区管理员
  • 控件
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧