以文本方式查看主题

-  Foxtable(狐表)  (http://www.foxtable.com/bbs/index.asp)
--  专家坐堂  (http://www.foxtable.com/bbs/list.asp?boardid=2)
----  socket  (http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=28063)

--  作者:ttitt147
--  发布时间:2013/1/17 14:29:00
--  socket

我需要用3000端口,ip是200.200.200.190

 

是不是在全局代码中加入下面的代码就可以实现?

 

Imports System
Imports System.Text
Imports System.IO
Imports System.Net
Imports System.Net.Sockets
Imports Microsoft.VisualBasic

Public Class GetSocket
  
   Private Shared Function ConnectSocket(server As String, port As Integer) As Socket
      Dim s As Socket = Nothing
      Dim hostEntry As IPHostEntry = Nothing     
    
         \' Get host related information.
        hostEntry = Dns.GetHostEntry(server)
        
         \' Loop through the AddressList to obtain the supported AddressFamily. This is to avoid
         \' an exception that occurs when the host host IP Address is not compatible with the address family
         \' (typical in the IPv6 case).
      Dim address As IPAddress
 
        For Each address In  hostEntry.AddressList
            Dim endPoint As New IPEndPoint(address, port)
            Dim tempSocket As New Socket(endPoint.AddressFamily, SocketType.Stream, ProtocolType.Tcp)
     
\'tempSocket.Connect(endPoint)
           

            tempSocket.Connect(200.200.200.190,3000)


            If tempSocket.Connected Then
               s = tempSocket
               Exit For
            End If

         Next address
     
      Return s
   End Function
  
  
   \' This method requests the home page content for the specified server.
  
   Private Shared Function SocketSendReceive(server As String, port As Integer) As String
      \'Set up variables and String to write to the server.
      Dim ascii As Encoding = Encoding.ASCII
      Dim request As String = "GET / HTTP/1.1" + ControlChars.Cr + ControlChars.Lf + "Host: " + server + ControlChars.Cr + ControlChars.Lf + "Connection: Close" + ControlChars.Cr + ControlChars.Lf + ControlChars.Cr + ControlChars.Lf
      Dim bytesSent As [Byte]() = ascii.GetBytes(request)
      Dim bytesReceived(255) As [Byte]
     
      \' Create a socket connection with the specified server and port.
      Dim s As Socket = ConnectSocket(server, port)
     
      If s Is Nothing Then
         Return "Connection failed"
      End If

      \' Send request to the server.
      s.Send(bytesSent, bytesSent.Length, 0)
     
      \' Receive the server  home page content.
      Dim bytes As Int32
     
      \' Read the first 256 bytes.
      Dim page as [String] = "Default HTML page on " + server + ":" + ControlChars.Cr + ControlChars.Lf
     
      \' The following will block until the page is transmitted.
      Do
         bytes = s.Receive(bytesReceived, bytesReceived.Length, 0)
            page = page + Encoding.ASCII.GetString(bytesReceived, 0, bytes)
      Loop While bytes > 0
     
      Return page
   End Function
  
   \'Entry point which delegates to C-style main Private Function
   Public Overloads Shared Sub Main()
      Main(System.Environment.GetCommandLineArgs())
   End Sub
  
  
   Overloads Private Shared Sub Main(args() As String)
      Dim host As String
      Dim port As Integer = 80
     
      If args.Length = 1 Then
         \' If no server name is passed as argument to this program,
         \' use the current host name as default.
         host = Dns.GetHostName()
      Else
         host = args(1)
      End If
     
      Dim result As String = SocketSendReceive(host, port)
     
      Console.WriteLine(result)
   End Sub \'Main
End Class 


--  作者:ttitt147
--  发布时间:2013/1/17 14:38:00
--  
提示类似 import System 未声明,不可用
--  作者:lin_hailun
--  发布时间:2013/1/17 14:42:00
--  
 添加引用,请参考你发的另一个帖子。

 对于你的这种应用,最好在vs环境下编写测试通过以后,然后生成dll文件在狐表里直接引用,直接调用比较方便。