可以使用DCOM,下面是我曾经使用过的函数(从ActiveX Exe中摘录) '上传文件 Public Function PutFile(ByVal sFile As String, ByRef vData As Variant) As Boolean On Error Resume Next Dim cErr As CError, hFile As Long, lLen As Long, lWrite As Long, bWrite() As Byte Set cErr = New CError Err.Clear lLen = FileLen(sFile) If lLen = 0 And Dir(sFile) = "" Then hFile = CreateFile(sFile, GENERIC_WRITE, FILE_SHARE_READ Or FILE_SHARE_WRITE, 0, CREATE_NEW, FILE_ATTRIBUTE_NORMAL, 0) If hFile <> INVALID_HANDLE_VALUE Then bWrite = vData lLen = UBound(bWrite) + 1 If lLen > 0 Then Call WriteFile(hFile, bWrite(0), lLen, lWrite, 0) Call CloseHandle(hFile) Erase bWrite PutFile = True Else cErr.mRaise mclErrorBase + 1, "试图写文件(" & sFile & ")时发生错误", "PutFile" RaiseEvent eError(cErr) End If Else cErr.mRaise mclErrorBase + 2, "文件(" & sFile & ")已经存在", "PutFile" RaiseEvent eError(cErr) End If Set cErr = Nothing RaiseEvent eOptFinished(ePutFile) End Function'下载文件 Public Function GetFile(ByVal sFile As String, ByRef vData As Variant) As Boolean On Error Resume Next Dim cErr As CError, hFile As Long, lLen As Long, lRead As Long, bRead() As Byte Set cErr = New CError Err.Clear lLen = FileLen(sFile) If Err.Number = 0 Then hFile = CreateFile(sFile, GENERIC_READ, FILE_SHARE_READ Or FILE_SHARE_WRITE, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0) If hFile <> INVALID_HANDLE_VALUE Then ReDim bRead(lLen - 1) As Byte Call ReadFile(hFile, bRead(0), lLen, lRead, 0) vData = bRead Call CloseHandle(hFile) Erase bRead GetFile = True Else cErr.mRaise mclErrorBase + 3, "试图打开文件(" & sFile & ")时发生错误", "GetFile" RaiseEvent eError(cErr) End If Else cErr.mRaise mclErrorBase + 4, "试图获取文件(" & sFile & ")长度时发生错误", "GetFile" RaiseEvent eError(cErr) End If Set cErr = Nothing RaiseEvent eOptFinished(eGetFile) End Function
看看下面一篇文章吧:INTERNET热火朝天,众多的精彩创意令人应接不暇——因为这里是一个“淘金”的 宝地。ICQ可能就是一个很好的典型了,它的成功主要归结为独特的创意(最先出 现的就叫做创意^o^)。如今网络上流行模仿,这不,OICQ等一批中文的网络寻呼 机也在中文网络领域博得了一席之地。那么你有没有想过自己设计一个网络寻呼机 呢?这可能很刺激哟,但是……是不是太难了?相信,很多人都会这样想。其实, 不要让好的想法被技术上的屏障所扼杀!真的,如果你这样想过(自己设计一个网 络寻呼机),那么就应该坚持下去!说不定你明天就会成功!这里有一个实现你伟 大梦想的技术参考,有兴趣就看看吧。 其实,网络寻呼的原理很简单,它就是——当客户端程序连接服务器时,通过 服务器搜索所要呼叫的ID号码,如果检测到此用户且该用户正处于联网状态,则服 务器通知此用户的客户端程序响应主叫方客户端程序,然后在主叫方和被叫方建立 连接后,双方就可以聊天或进行其它的通信——这里,如果你真的有好的想法,说 不定明天网络上就会有一种新的通信方式,而这种新的通行方式出自你的伟大构想 ! 下来我们看看网络寻呼机(模型)具体的程序设计方法。一般来讲,网络应用 程序都有一个客户端程序和一个服务器端程序。同样,我们要设计的网络寻呼机也 不例外,它也需要建立两个程序,一个为客户端程序Client,另一个为服务器端程 序Server。我们先看看客户端程序——也就是你电脑上的OICQ或者其他的ICQ程序 。具体设计如下: 在Client工程中建立一个窗体,加载WinSock控件,称为tcpClient,协议选择 TCP。再加入四个文本框,用以输入服务器的IP地址、服务器端口号,被呼叫的网 络寻呼ID号以及用户登录ID号。然后再在窗体中加入三个按钮,分别命名为“连接 ”、“断开”和“退出”,点击“连接”按钮,并进行如下初始化连接,代码如下 : Private Sub Command1_Click() If Len(Text1.Text) = 0 And Len(Text2.Text) = 0 Then MsgBox ("请输入主机名或主机IP地址。") Exit Sub ElseIf Len(Text1.Text) > 0 Then tcpClient.RemoteHost = Text1.Text tcpClient.RemotePort = Text2.Text End If tcpClient.Connect Timer1.Enabled = True End Sub Private Sub Command2_Click() tcpClient.Close '断开连接 End Sub Private Sub Command3_Click() End End Sub Private Sub Form_Load() Text2.Text = "1001" End Sub Private Sub tcpClient_Connect() tcpClient.SendData (Text3.Text&"@"&Text4.Text) End Sub Private Sub tcpClient_DataArrival(ByVal bytesTotal As Long) Dim strData As String tcpClient.GetData strData strData = strData + "呼叫" '在收到呼叫消息后弹出一对话框并显示主叫方ID号码 MsgBox (strData) End Sub OK,客户端的程序就完成了(运行后的参考界面图如图所示),是不是很简单 呀?当然了,本来就不难嘛。不过这仅仅是一个演示而已,它还不能进行基本的通 信。如果你要想设计更多的通信功能的话——比如文字聊天、语音聊天等等,那么 还需要更多的努力才行!不过,这里我们接下来要看的是服务器端的程序了^.^。 在服务器端Server工程中也建立一个窗体,加载WinSock控件,称为 tcpServer,协议选择TCP,设置其Index属性值为0,并在工程中添加如下模块: Private Type ActiveUser ClientIP As String '记录客户的IP地址 ClientPort As Integer '记录当前会话的端口 ClientID As Long '记录客户的ID号码 ClientConnected As Boolean '客户连接状态,True表示已连接,False表示没有连接 End Type Dim CurUser() As ActiveUser Dim tcpIndex As Integer '跟踪当前建立连接数 然后在Form_Load事件中加入如下代码: Private Sub Form_Load() tcpServer(0).Protocol = sckTCPProtocol tcpServer(0).LocalPort = 1001 '将 LocalPort 属性设置为一个整数。 tcpServer(0).Listen '然后调用 Listen 方法。 tcpIndex = 1 End Sub 准备应答客户端程序的请求连接,使用ConnectionRequest事件来应答户端程 序的请求。具体代码可以如下: Private Sub tcpServer_ConnectionRequest (Index As Integer, ByVal requestID As Long) Dim i As Integer On Error GoTo ErrHandle For i = 1 To tcpIndex '选择一个空闲端口 If CurUser(i).ClientConnected = False And i < > tcpIndex Then Load tcpServer(i) tcpServer(i).LocalPort = CurUser(i).ClientPort - 1 tcpServer(i).Accept requestID Exit For ElseIf CurUser(i).ClientConnected = False Then Load tcpServer(i) tcpServer(i).LocalPort = Port If tcpServer(i).State < > sckClosed Then tcpServer(i).Close End If tcpServer(i).Accept requestID Exit For End If Next DoEvents '测试连接是否成功 If tcpServer(i).State = sckConnected Then If i = tcpIndex Then '已经没有可用端口,记录客户的IP地址和端口号 tcpIndex = tcpIndex + 1 Port = Port + 1 ReDim Preserve CurUser(tcpIndex) CurUser(i).ClientIP = tcpServer(i).RemoteHostIP CurUser(i).ClientConnected = True CurUser(i).ClientPort = Port CurUser(tcpIndex).ClientConnected = False Else CurUser(i).ClientIP = tcpServer(i).RemoteHostIP CurUser(i).ClientPort = Port CurUser(i).ClientConnected = True End If End If Exit Sub ErrHandle: Resume Next '检查控件的 State 属性,如未关闭,在接受新的连接之前关闭此连接。 If tcpServer(0).State <> sckClosed Then tcpServer(0).Close tcpServer(0).Accept requestID '接受具有 requestID 参数的,连接。 End Sub Private Sub tcpServer_DataArrival(Index As Integer, ByVal bytesTotal As Long) Dim i As Integer Dim s As String Dim RequID As Long '主叫方ID号码 Dim SearchID As Long '被叫方ID号码 On Error GoTo ErrHandle tcpServer(Index).GetData s, vbString '接收数据并存入s If Mid(s, i, 1) = "@" Then '分离s中的主叫方和被叫方ID号码 SearhID = Left(s, i - 1) '把号存入mKey RequID = Right(s, Len(s) - i) 'ID存入RequID End If '如果是请求寻呼某一ID号码,则检索当前此ID用户是否登录(即CurUser数组 中是否存在此用户),然后发送信息,通知此用户响应呼叫并显示主叫用户ID号码 。 For i = 1 To tcpIndex If RequID = CurUser(i).ClientID And CurUser(i) .ClientConnected = True Then tcpServer(i).SendData (SearhID) End If Next Exit Sub ErrHandle: If Err.Number = sckBadState Then '连接不正确 CurUser(i).ClientConnected = False CurUser(i).ClientIP = "" Unload tcpServer(i) Resume Next End If End Sub 好了,服务器端的程序(演示)也完成了!是不是很爽呀?当然了,已经很有 成就感了嘛……嘿嘿,不过,唉,这里最大的遗憾就是不能进行任何的通信。如果 能在这个程序的基础之上进行一些改进(或者彻底推翻这里的程序而重新设计)的 话,那么,明天的“某某ICQ”可能将会出自你的手笔!这个任务就交给你了,哥 们,因为你肯定比我更有创意也更有技术细胞的!
'上传文件
Public Function PutFile(ByVal sFile As String, ByRef vData As Variant) As Boolean
On Error Resume Next
Dim cErr As CError, hFile As Long, lLen As Long, lWrite As Long, bWrite() As Byte
Set cErr = New CError
Err.Clear
lLen = FileLen(sFile)
If lLen = 0 And Dir(sFile) = "" Then
hFile = CreateFile(sFile, GENERIC_WRITE, FILE_SHARE_READ Or FILE_SHARE_WRITE, 0, CREATE_NEW, FILE_ATTRIBUTE_NORMAL, 0)
If hFile <> INVALID_HANDLE_VALUE Then
bWrite = vData
lLen = UBound(bWrite) + 1
If lLen > 0 Then Call WriteFile(hFile, bWrite(0), lLen, lWrite, 0)
Call CloseHandle(hFile)
Erase bWrite
PutFile = True
Else
cErr.mRaise mclErrorBase + 1, "试图写文件(" & sFile & ")时发生错误", "PutFile"
RaiseEvent eError(cErr)
End If
Else
cErr.mRaise mclErrorBase + 2, "文件(" & sFile & ")已经存在", "PutFile"
RaiseEvent eError(cErr)
End If
Set cErr = Nothing
RaiseEvent eOptFinished(ePutFile)
End Function'下载文件
Public Function GetFile(ByVal sFile As String, ByRef vData As Variant) As Boolean
On Error Resume Next
Dim cErr As CError, hFile As Long, lLen As Long, lRead As Long, bRead() As Byte
Set cErr = New CError
Err.Clear
lLen = FileLen(sFile)
If Err.Number = 0 Then
hFile = CreateFile(sFile, GENERIC_READ, FILE_SHARE_READ Or FILE_SHARE_WRITE, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0)
If hFile <> INVALID_HANDLE_VALUE Then
ReDim bRead(lLen - 1) As Byte
Call ReadFile(hFile, bRead(0), lLen, lRead, 0)
vData = bRead
Call CloseHandle(hFile)
Erase bRead
GetFile = True
Else
cErr.mRaise mclErrorBase + 3, "试图打开文件(" & sFile & ")时发生错误", "GetFile"
RaiseEvent eError(cErr)
End If
Else
cErr.mRaise mclErrorBase + 4, "试图获取文件(" & sFile & ")长度时发生错误", "GetFile"
RaiseEvent eError(cErr)
End If
Set cErr = Nothing
RaiseEvent eOptFinished(eGetFile)
End Function
宝地。ICQ可能就是一个很好的典型了,它的成功主要归结为独特的创意(最先出
现的就叫做创意^o^)。如今网络上流行模仿,这不,OICQ等一批中文的网络寻呼
机也在中文网络领域博得了一席之地。那么你有没有想过自己设计一个网络寻呼机
呢?这可能很刺激哟,但是……是不是太难了?相信,很多人都会这样想。其实,
不要让好的想法被技术上的屏障所扼杀!真的,如果你这样想过(自己设计一个网
络寻呼机),那么就应该坚持下去!说不定你明天就会成功!这里有一个实现你伟
大梦想的技术参考,有兴趣就看看吧。
其实,网络寻呼的原理很简单,它就是——当客户端程序连接服务器时,通过
服务器搜索所要呼叫的ID号码,如果检测到此用户且该用户正处于联网状态,则服
务器通知此用户的客户端程序响应主叫方客户端程序,然后在主叫方和被叫方建立
连接后,双方就可以聊天或进行其它的通信——这里,如果你真的有好的想法,说
不定明天网络上就会有一种新的通信方式,而这种新的通行方式出自你的伟大构想
!
下来我们看看网络寻呼机(模型)具体的程序设计方法。一般来讲,网络应用
程序都有一个客户端程序和一个服务器端程序。同样,我们要设计的网络寻呼机也
不例外,它也需要建立两个程序,一个为客户端程序Client,另一个为服务器端程
序Server。我们先看看客户端程序——也就是你电脑上的OICQ或者其他的ICQ程序
。具体设计如下:
在Client工程中建立一个窗体,加载WinSock控件,称为tcpClient,协议选择
TCP。再加入四个文本框,用以输入服务器的IP地址、服务器端口号,被呼叫的网
络寻呼ID号以及用户登录ID号。然后再在窗体中加入三个按钮,分别命名为“连接
”、“断开”和“退出”,点击“连接”按钮,并进行如下初始化连接,代码如下
:
Private Sub Command1_Click()
If Len(Text1.Text) = 0 And Len(Text2.Text) = 0 Then
MsgBox ("请输入主机名或主机IP地址。")
Exit Sub
ElseIf Len(Text1.Text) > 0 Then
tcpClient.RemoteHost = Text1.Text
tcpClient.RemotePort = Text2.Text
End If
tcpClient.Connect
Timer1.Enabled = True
End Sub
Private Sub Command2_Click()
tcpClient.Close '断开连接
End Sub
Private Sub Command3_Click()
End
End Sub
Private Sub Form_Load()
Text2.Text = "1001"
End Sub
Private Sub tcpClient_Connect()
tcpClient.SendData (Text3.Text&"@"&Text4.Text)
End Sub
Private Sub tcpClient_DataArrival(ByVal
bytesTotal As Long)
Dim strData As String
tcpClient.GetData strData
strData = strData + "呼叫"
'在收到呼叫消息后弹出一对话框并显示主叫方ID号码
MsgBox (strData)
End Sub
OK,客户端的程序就完成了(运行后的参考界面图如图所示),是不是很简单
呀?当然了,本来就不难嘛。不过这仅仅是一个演示而已,它还不能进行基本的通
信。如果你要想设计更多的通信功能的话——比如文字聊天、语音聊天等等,那么
还需要更多的努力才行!不过,这里我们接下来要看的是服务器端的程序了^.^。 在服务器端Server工程中也建立一个窗体,加载WinSock控件,称为
tcpServer,协议选择TCP,设置其Index属性值为0,并在工程中添加如下模块: Private Type ActiveUser
ClientIP As String '记录客户的IP地址
ClientPort As Integer '记录当前会话的端口
ClientID As Long '记录客户的ID号码
ClientConnected As Boolean
'客户连接状态,True表示已连接,False表示没有连接
End Type
Dim CurUser() As ActiveUser
Dim tcpIndex As Integer '跟踪当前建立连接数
然后在Form_Load事件中加入如下代码:
Private Sub Form_Load()
tcpServer(0).Protocol = sckTCPProtocol
tcpServer(0).LocalPort = 1001
'将 LocalPort 属性设置为一个整数。
tcpServer(0).Listen '然后调用 Listen 方法。
tcpIndex = 1
End Sub
准备应答客户端程序的请求连接,使用ConnectionRequest事件来应答户端程
序的请求。具体代码可以如下:
Private Sub tcpServer_ConnectionRequest
(Index As Integer, ByVal requestID As Long)
Dim i As Integer
On Error GoTo ErrHandle
For i = 1 To tcpIndex '选择一个空闲端口
If CurUser(i).ClientConnected = False And i < > tcpIndex Then
Load tcpServer(i)
tcpServer(i).LocalPort = CurUser(i).ClientPort - 1
tcpServer(i).Accept requestID
Exit For
ElseIf CurUser(i).ClientConnected = False Then
Load tcpServer(i)
tcpServer(i).LocalPort = Port
If tcpServer(i).State < > sckClosed Then
tcpServer(i).Close
End If
tcpServer(i).Accept requestID
Exit For
End If
Next
DoEvents
'测试连接是否成功
If tcpServer(i).State = sckConnected Then
If i = tcpIndex Then
'已经没有可用端口,记录客户的IP地址和端口号
tcpIndex = tcpIndex + 1
Port = Port + 1
ReDim Preserve CurUser(tcpIndex)
CurUser(i).ClientIP = tcpServer(i).RemoteHostIP
CurUser(i).ClientConnected = True
CurUser(i).ClientPort = Port
CurUser(tcpIndex).ClientConnected = False
Else
CurUser(i).ClientIP = tcpServer(i).RemoteHostIP
CurUser(i).ClientPort = Port
CurUser(i).ClientConnected = True
End If
End If
Exit Sub
ErrHandle:
Resume Next
'检查控件的 State 属性,如未关闭,在接受新的连接之前关闭此连接。
If tcpServer(0).State <> sckClosed Then
tcpServer(0).Close
tcpServer(0).Accept requestID
'接受具有 requestID 参数的,连接。
End Sub
Private Sub tcpServer_DataArrival(Index As Integer,
ByVal bytesTotal As Long)
Dim i As Integer
Dim s As String
Dim RequID As Long '主叫方ID号码
Dim SearchID As Long '被叫方ID号码
On Error GoTo ErrHandle
tcpServer(Index).GetData s, vbString
'接收数据并存入s
If Mid(s, i, 1) = "@" Then
'分离s中的主叫方和被叫方ID号码
SearhID = Left(s, i - 1) '把号存入mKey
RequID = Right(s, Len(s) - i) 'ID存入RequID
End If
'如果是请求寻呼某一ID号码,则检索当前此ID用户是否登录(即CurUser数组
中是否存在此用户),然后发送信息,通知此用户响应呼叫并显示主叫用户ID号码
。
For i = 1 To tcpIndex
If RequID = CurUser(i).ClientID And CurUser(i)
.ClientConnected = True Then
tcpServer(i).SendData (SearhID)
End If
Next
Exit Sub
ErrHandle:
If Err.Number = sckBadState Then '连接不正确
CurUser(i).ClientConnected = False
CurUser(i).ClientIP = ""
Unload tcpServer(i)
Resume Next
End If
End Sub
好了,服务器端的程序(演示)也完成了!是不是很爽呀?当然了,已经很有
成就感了嘛……嘿嘿,不过,唉,这里最大的遗憾就是不能进行任何的通信。如果
能在这个程序的基础之上进行一些改进(或者彻底推翻这里的程序而重新设计)的
话,那么,明天的“某某ICQ”可能将会出自你的手笔!这个任务就交给你了,哥
们,因为你肯定比我更有创意也更有技术细胞的!