📄 88.htm
字号:
<p>用VB创建自己的通信程序 </p>
<p></p>
<p>---- Winsock 控 件 建 立 在TCP、UDP 的 协 议 基 础 上, 以 完 成 计 算 机 网 络 间 的 通 信。 下 面 将 详 细 的 介 绍 具 体 的 程 序 创 建 过 程, 以 便 使 大 家 更 好 的 理 解 程 序 的 源 代 码。 </p>
<p></p>
<p>---- 服 务 器 端 程 序 的 运 行 过 程 是: </p>
<p></p>
<p>---- (4) 服 务 器 端 要 设 置 好 侦 听 端 口 即LocalPort 属 性, 作 为 侦 听 端 口 的 值 必 须 是 一 个 整 数( 一 定 要 是 其 它TCP/IP 应 用 程 序 没 有 用 过 的 值, 并 且 不 能 与 系 统 缺 省 端 口 冲 突)。 </p>
<p></p>
<p>---- (5) 用Listen 方 法 进 入 侦 听 状 态, 等 待 客 户 机 的 连 接 请 求。 </p>
<p></p>
<p>---- (6) 当 客 户 机 发 出 连 接 请 求 时, 使 服 务 器 产 生 一 个ConnectionRequest 事 件, 且 该 事 件 得 到 一 个 参 数requestID。 </p>
<p></p>
<p>---- (7) 服 务 器 程 序 用Accept 方 法 接 受 客 户 机requestID 请 求。 这 样, 服 务 器 程 序 便 可 以 用SendData 方 法 来 发 送 数 据 了。 但 是,Accept 方 法 必 须 用 上 一 个 步 得 到 的requestID 作 为 其 参 数。 </p>
<p></p>
<p>---- (8) 当 服 务 器 程 序 接 收 到 数 据 时, 便 会 产 生 一 个DataArrial 事 件, 参 数BytesTotal 包 含 接 收 到 的 数 据 字 节 数。 在 该 事 件 中, 可 以 用GetData 方 法 接 收 数 据。 </p>
<p></p>
<p>---- (9) 如 果 接 收 到Close 事 件, 则 用Close 方 法 关 闭TCP/IP 连 接。 </p>
<p></p>
<p>---- 客 户 机 的 程 序 的 运 行 过 程 是: </p>
<p></p>
<p>---- (8) 在 客 户 程 序 中 设 置Remmotehost 属 性, 以 便 指 定 运 行 服 务 器 程 序 的 主 机 名, 该 字 符 串 可 以 在 服 务 器“ 控 制 面 板| 网 络| 标 识| 计 算 机” 中 查 到。 </p>
<p></p>
<p>---- (9) 设 置RemotePort 属 性, 以 便 指 定 服 务 器 程 序 的 侦 听 端 口( 其 设 置 方 法 与 服 务 器 端 类 似)。 </p>
<p></p>
<p>---- (10) 使 用Connect 方 法, 向 服 务 器 提 出 连 接 请 求。 </p>
<p></p>
<p>---- (11) 当 服 务 器 程 序 接 受 到 客 户 机 程 序 的 请 求 后, 客 户 机 程 序 产 生Connect 事 件, 就 可 以 用SendData 方 法 发 送 数 据 了。 </p>
<p></p>
<p>---- (12) 当 客 户 机 程 序 接 收 到 数 据 时, 便 会 产 生DataArrival 事 件, 参 数BytesTotal 包 含 接 收 到 的 数 据 字 节 数。 类 似 的 在 该 事 件 中 也 可 以 用GetData 方 法 接 收 数 据。 </p>
<p></p>
<p>---- (13) 如 果 客 户 机 程 序 接 收 到Close, 则 用Close 方 法 关 闭 连 接。 </p>
<p></p>
<p>---- 使 用 说 明: </p>
<p></p>
<p>---- 本 程 序 实 现 了 两 台 计 算 机 之 间 的 自 由 通 信。 先 将 编 译 好 的 程 序 分 别 放 入 两 台 已 联 网 的 计 算 机 的| 开 始| 启 动| 中, 这 样 每 次 启 动 时, 程 序 将 会 自 动 运 行, 程 序 启 动 时 将 以 最 小 化 的 形 式 出 现 在 任 务 栏 中, 当 用 户 使 用 时 可 以 通 过 点 击 任 务 栏 上 的 该 程 序 图 标 来 激 活 该 程 序, 一 方 将 程 序 激 活 后, 在“ 请 输 入 所 要 连 接 的 主 机 名:“ 右 侧 的 编 辑 框 中 输 入 需 要 连 接 的 计 算 机 名, 并 敲“ 连 接” 键 便 可 连 接 成 功。 此 时 在“ 接 收 窗 口:” 下 的 编 辑 框 中 将 会 出 现“ 连 接 成 功” 的 提 示。 然 后 就 可 以 在“ 发 送 窗 口:” 下 的 编 辑 框 中 输 入 要 说 的 话 了, 输 入 完 毕 后 敲“ 发 送” 键 后 便 可 使 另 一 方 收 到 你 的 话 了, 如 果 另 一 方 的 程 序 尚 未 正 常 化, 那 么 另 一 方 程 序 将 发 出 提 示 音 并 使 任 务 栏 中 程 序 的 图 标 闪 烁, 直 到 另 一 方 将 程 序 激 活 为 正 常 化 并 与 你 对 话 为 止。 如 果 暂 时 停 止 对 话 可 以 点 击 该 程 序 的 极 小 化 按 钮 将 程 序 最 小 化, 一 旦 需 要 再 次 通 话 可 直 接 激 活 该 程 序 发 送 过 去, 如 果 另 一 方 的 程 序 尚 未 正 常 化, 那 么 程 序 仍 将 发 出 提 示 音 并 使 开 使 栏 中 程 序 的 小 图 标 闪 烁, 直 到 另 一 方 将 程 序 正 常 化 并 与 你 对 话 为 止。 所 以, 无 论 什 么 时 候 想 与 对 方 通 话 只 要 对 方 开 了 机 便 可 以 实 现。 当 需 要 断 开 连 接 时 请 按“ 关 闭” 键, 该 程 序 能 自 动 发 送 结 束 消 息, 使 对 方 能 够 知 道 你 已 断 开 连 接, 以 结 束 程 序 运 行。 </p>
<p></p>
<p>---- FORM 的 构 造 如 下: </p>
<p></p>
<p>---- Timer 控 件----MMXControl 控 件 ----Gettest 控 件 </p>
<p></p>
<p>---- Winsock 控 件----CommandButton 控 件----Test 控 件 </p>
<p></p>
<p>---- 一 段 的 源 程 序 如 下: </p>
<p></p>
<p>Dim sign As Boolean</p>
<p>Dim flashsign As Boolean</p>
<p>Dim con As Boolean</p>
<p></p>
<p>Private Sub transfer_Click()</p>
<p>On Error GoTo transfererror</p>
<p>Timer1.Enabled = False</p>
<p>gettext.Text = " 陈 涛 说:" + sendtext.Text + Chr(13) + Chr(10) + gettext.Text</p>
<p>Dim say As String</p>
<p>If sign = True Then</p>
<p>say = " 陈 涛 说:" + sendtext.Text + Chr(13) + Chr(10)</p>
<p>Winsockout.SendData say</p>
<p>Else</p>
<p>say = " 陈 涛 说:" + sendtext.Text + Chr(13) + Chr(10)</p>
<p>Winsock1.SendData say</p>
<p>End If</p>
<p>sendtext.Text = ""</p>
<p>Exit Sub</p>
<p>transfererror:</p>
<p> Dim a As String</p>
<p>a = " 计 算 机 还 没 有 进 入 网 络 或 者 </p>
<p>是 它 的 相 应 程 序 没 有 运 行 !"</p>
<p> MsgBox (a)</p>
<p> End</p>
<p>Exit Sub</p>
<p>End Sub</p>
<p>Private Sub conbut_Click()</p>
<p>On Error GoTo connecterror</p>
<p>Winsockout.RemoteHost = hostnametext.Text</p>
<p>Winsockout.Connect</p>
<p>sign = True</p>
<p>conbut.Default = False</p>
<p>transfer.Default = True</p>
<p>Exit Sub</p>
<p>connecterror:</p>
<p> Dim a As String</p>
<p>a = " 计 算 机 还 没 有 进 入 网 络 或 者 是 </p>
<p>它 的 相 应 程 序 没 有 运 行 !"</p>
<p> Dim b As String</p>
<p> b = " 要 连 接 的 机 器 名 输 入 错 误,"</p>
<p> MsgBox (b + a)</p>
<p> End</p>
<p>Exit Sub</p>
<p>End Sub</p>
<p></p>
<p>Private Sub exitbut_Click()</p>
<p>On Error GoTo exiterror</p>
<p>If con = True Then</p>
<p>End</p>
<p>End If</p>
<p>If sign = True Then</p>
<p>Winsockout.SendData " 中 断 联 接!"</p>
<p>Else</p>
<p>Winsock1.SendData " 中 断 联 接!"</p>
<p>End If</p>
<p>Exit Sub</p>
<p>exiterror:</p>
<p> Dim a As String</p>
<p>a = " 计 算 机 还 没 有 进 入 网 络 或 者 是</p>
<p> 它 的 相 应 程 序 没 有 运 行 !"</p>
<p> MsgBox (a)</p>
<p> End</p>
<p>Exit Sub</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Form_Load()</p>
<p>Winsock1.Listen</p>
<p>sign = False</p>
<p>flashsign = True</p>
<p>Timer1.Enabled = False</p>
<p>con = False</p>
<p>conbut.Default = True</p>
<p>End Sub</p>
<p></p>
<p></p>
<p>Private Sub hostnametext_Change()</p>
<p>conbut.Enabled = True</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Timer1_Timer()</p>
<p>If Form1.WindowState = 1 Then</p>
<p>If flashsign = True Then</p>
<p>Form1.Icon = LoadPicture(App.Path + "\zhcn010.ico")</p>
<p>flashsign = False</p>
<p>ElseIf flashsign = False Then</p>
<p>Form1.Icon = LoadPicture(App.Path + "\zhcn020.ico")</p>
<p>flashsign = True</p>
<p>End If</p>
<p>End If</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Winsock1_Close()</p>
<p>conbut.Enabled = True</p>
<p>hostnametext.Enabled = True</p>
<p>Winsock1.Close</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Winsock1_ConnectionRequest(ByVal requestID As Long)</p>
<p>If Winsock1.State <> 0 Then</p>
<p>Winsock1.Close</p>
<p>End If</p>
<p>transfer.Default = True</p>
<p>If Form1.WindowState = 1 Then</p>
<p>Timer1.Enabled = True</p>
<p>MMControl1.Notify = False</p>
<p>Form1.MMControl1.Wait = True</p>
<p>Form1.MMControl1.Shareable = False</p>
<p>Form1.MMControl1.DeviceType = "waveaudio"</p>
<p>Form1.MMControl1.filename = App.Path + "\mcitest.wav"</p>
<p>Form1.MMControl1.Command = "Open"</p>
<p>Form1.MMControl1.Command = "play"</p>
<p>Form1.MMControl1.Command = "prev"</p>
<p>End If</p>
<p>conbut.Enabled = False</p>
<p>hostnametext.Enabled = False</p>
<p>sendtext.Enabled = True</p>
<p>gettext.Enabled = True</p>
<p>gettext.Text = " 连 接 成 功!" + Chr(13) + Chr(10)</p>
<p>sign = False</p>
<p>Winsock1.Accept requestID</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Winsock1_DataArrival(ByVal bytesTotal As Long)</p>
<p>Dim str As String</p>
<p>If Form1.WindowState = 1 Then</p>
<p>Timer1.Enabled = True</p>
<p>MMControl1.Notify = False</p>
<p>Form1.MMControl1.Wait = True</p>
<p>Form1.MMControl1.Shareable = False</p>
<p>Form1.MMControl1.DeviceType = "waveaudio"</p>
<p>Form1.MMControl1.filename = App.Path + "\mcitest.wav"</p>
<p>Form1.MMControl1.Command = "Open"</p>
<p>Form1.MMControl1.Command = "play"</p>
<p>Form1.MMControl1.Command = "prev"</p>
<p>End If</p>
<p>Winsock1.GetData str</p>
<p>If str = " 中 断 联 接!" Then</p>
<p>con = True</p>
<p>Winsock1.SendData " 可 以 中 断 联 接!"</p>
<p>ElseIf str = " 可 以 中 断 联 接!" Then</p>
<p>End</p>
<p>End If</p>
<p>gettext.Text = str + gettext.Text</p>
<p>End Sub</p>
<p>Private Sub Winsockout_Close()</p>
<p>hostnametext.Enabled = True</p>
<p>Winsockout.Close</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Winsockout_Connect()</p>
<p>Form1.WindowState = 0</p>
<p>gettext.Enabled = True</p>
<p>sendtext.Enabled = True</p>
<p>conbut.Enabled = False</p>
<p>gettext.Text = " 连 接 成 功!" + Chr(13) + Chr(10)</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Winsockout_DataArrival(ByVal bytesTotal As Long)</p>
<p>Dim tempstr As String</p>
<p>If Form1.WindowState = 1 Then</p>
<p>Timer1.Enabled = True</p>
<p>MMControl1.Notify = False</p>
<p>Form1.MMControl1.Wait = True</p>
<p>Form1.MMControl1.Shareable = False</p>
<p>Form1.MMControl1.DeviceType = "waveaudio"</p>
<p>Form1.MMControl1.filename = App.Path + "\mcitest.wav"</p>
<p>Form1.MMControl1.Command = "Open"</p>
<p>Form1.MMControl1.Command = "play"</p>
<p>Form1.MMControl1.Command = "prev"</p>
<p>End If</p>
<p>Winsockout.GetData tempstr</p>
<p>If tempstr = " 中 断 联 接!" Then</p>
<p>con = True</p>
<p>Winsockout.SendData " 可 以 中 断 联 接!"</p>
<p>ElseIf tempstr = " 可 以 中 断 联 接!" Then</p>
<p>End</p>
<p>End If</p>
<p>gettext.Text = tempstr + gettext.Text</p>
<p>End Sub</p>
<p></p>
<p></p>
<p>---- 说 明: </p>
<p></p>
<p>---- 在 以 上 程 序 中, 包 括 两 个Winsock 控 件 一 个 是 服 务 器 端 的, 另 一 个 是 客 户 端 的, 以 此 来 实 现 相 互 通 信 的 目 的。 现 将 程 序 中 的 重 要 部 件 的 主 要 属 性 列 表 如 下( 以 下 的 各 表 格 的 起 头 均 为 控 件 的Name 属 性): </p>
<p></p>
<p>Form1 </p>
<p>MaxButton</p>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -