ورود

View Full Version : سوال: چجور می شه با یک برنامه نام کامپیوتر رو به دست اوورد ؟



amintiger
یک شنبه 05 تیر 1390, 23:48 عصر
سلام
چجور می شه با یک برنامه نام کامپیوتر رو به دست اوورد ؟
لطفا راهنمایی کنید .

f_f_f_f_f
دوشنبه 06 تیر 1390, 00:06 صبح
اول این کد را در جنرال فرم جنرال کپی کنید.
Option Explicit
Private Const WS_VERSION_REQD = &H101
Private Const WS_VERSION_MAJOR = WS_VERSION_REQD \ &H100 And &HFF&
Private Const WS_VERSION_MINOR = WS_VERSION_REQD And &HFF&
Private Const MIN_SOCKETS_REQD = 1
Private Const SOCKET_ERROR = -1
Private Const WSADescription_Len = 256
Private Const WSASYS_Status_Len = 128
Private Type HOSTENT
hName As Long
hAliases As Long
hAddrType As Integer
hLength As Integer
hAddrList As Long
End Type
Private Type WSADATA
wVersion As Integer
wHighVersion As Integer
szDescription(0 To WSADescription_Len) As Byte
szSystemStatus(0 To WSASYS_Status_Len) As Byte
iMaxSockets As Integer
iMaxUdpDg As Integer
lpszVendorInfo As Long
End Type
Private Declare Function WSAGetLastError Lib "WSOCK32.DLL" () As Long
Private Declare Function WSAStartup Lib "WSOCK32.DLL" (ByVal wVersionRequired As Integer, lpWSADATA As WSADATA) As Long
Private Declare Function WSACleanup Lib "WSOCK32.DLL" () As Long
Private Declare Function gethostname Lib "WSOCK32.DLL" (ByVal hostname$, ByVal HostLen As Long) As Long
Private Declare Function gethostbyname Lib "WSOCK32.DLL" (ByVal hostname$) As Long
Private Declare Sub RtlMoveMemory Lib "kernel32" (hpvDest As Any, ByVal hpvSource&, ByVal cbCopy&)
Private Declare Function GetUserName Lib "advapi32.dll" Alias "GetUserNameA" _
(ByVal lpBuffer As String, _
nSize As Long) As Long
Function hibyte(ByVal wParam As Integer)
hibyte = wParam \ &H100 And &HFF&
End Function
Function lobyte(ByVal wParam As Integer)
lobyte = wParam And &HFF&
End Function
' Return the local host's name.
Private Function LocalHostName() As String
Dim hostname As String * 256
If gethostname(hostname, 256) = SOCKET_ERROR Then
LocalHostName = "<Error>"
Else
LocalHostName = Trim$(hostname)
End If
End Function
Private Sub InitializeSockets()
Dim WSAD As WSADATA
Dim iReturn As Integer
Dim sLowByte As String, sHighByte As String, sMsg As String
iReturn = WSAStartup(WS_VERSION_REQD, WSAD)
If iReturn <> 0 Then
MsgBox "Winsock.dll is not responding."
End
End If
If lobyte(WSAD.wVersion) < WS_VERSION_MAJOR Or (lobyte(WSAD.wVersion) = _
WS_VERSION_MAJOR And hibyte(WSAD.wVersion) < WS_VERSION_MINOR) Then
sHighByte = Trim$(Str$(hibyte(WSAD.wVersion)))
sLowByte = Trim$(Str$(lobyte(WSAD.wVersion)))
sMsg = "Windows Sockets version " & sLowByte & "." & sHighByte
sMsg = sMsg & " is not supported by winsock.dll "
MsgBox sMsg
End
End If
If WSAD.iMaxSockets < MIN_SOCKETS_REQD Then
sMsg = "This application requires a minimum of "
sMsg = sMsg & Trim$(Str$(MIN_SOCKETS_REQD)) & " supported sockets."
MsgBox sMsg
End
End If
End Sub

بعد یک تکست باکس به اسم txtpc ایجاد نمایید بعد کد زیر در form lode کپی کنید.
InitializeSockets
txtpc = UCase(LocalHostName())

minaforotan
دوشنبه 06 تیر 1390, 00:26 صبح
dim a as string=environ("computername")

amintiger
دوشنبه 06 تیر 1390, 11:02 صبح
سلام
به خاطر تمام این چیزایی که شما زحمت کشیدید و زدید ازتون تشکر می کنم
ولی این چیزی که من می خوام این نیست این رو خودم قبلا با ساختن یک winsock و با دستور زیر به دست می اووردم :

msgbox winsock1.localhostname
ولی اون چیزی که مد نظر من هست رو نمی ده
من نامی رو می خوام که تو قسمت C:\users به صورت پوشه هست که این دستور اون رو نمی ده

اگه منظورم رو متوجه نشدید بگید تا بیشتر توضیح بدم

f_f_f_f_f
دوشنبه 06 تیر 1390, 16:19 عصر
سلام دوست عزیز فکر کنم این منظور شما بود.فقط یک لیبل و دکمه در فرم قرار بده.به کد زیر را کپی کن.
Private Declare Function GetUserNameA Lib "advapi32.dll" (ByVal lpBuffer As String, nSize As Long) As Long
Public Function GetUserName() As String
Dim UserName As String * 255

Call GetUserNameA(UserName, 255)
GetUserName = Left$(UserName, InStr(UserName, Chr$(0)) - 1)

End Function

Private Sub Command1_Click()
Label1.Caption = GetUserName
End Sub

محسن واژدی
دوشنبه 06 تیر 1390, 17:42 عصر
سلام عليكم
تابع زير نام كاربر را برميگرداند:

msgbox environ("username")


موفق باشيد