17. oktober 2000 - 19:04Der er
5 kommentarer og 2 løsninger
Kigge på netværksbiblioteker i VB
Kan man i VB5 lave noget så man kan komme til at se de andre computere i netværket OG deres drev i en DirListBox eller noget lignende? Det skal være sådan, at man kan komme til at indtaste passwordet til den delte mappe i koden.
Problemet her er at hvis der er password på ressourcen, så skriver den bare \"Path not found\", så der er altså ikke mulighed for at indtaste password, hverken manuelt eller i kode!
Kun hvis der ikke er nogen der kommer med en bedre idé:
Lav en \"server\" som du køre på den anden computer, derefter lav en client (som er dig) der logger sig på hans computer... Derefter kan du programmer et funktion i serven der gør det mulig at slette fil med Kill: dvs. en funktion på serven som gør det muligt for clienten at sende den fil der skal slettes... Bare en idé der sagtens og let kan gøres...
Declare Function WNetAddConnection2 Lib \"mpr.dll\" Alias _ \"WNetAddConnection2A\" (lpNetResource As NETRESOURCE, _ ByVal lpPassword As String, ByVal lpUserName As String, _ ByVal dwFlags As Long) As Long
Declare Function WNetCancelConnection2 Lib \"mpr.dll\" Alias _ \"WNetCancelConnection2A\" (ByVal lpName As String, _ ByVal dwFlags As Long, ByVal fForce As Long) As Long
Type NETRESOURCE dwScope As Long dwType As Long dwDisplayType As Long dwUsage As Long lpLocalName As String lpRemoteName As String lpComment As String lpProvider As String End Type
Public Const NO_ERROR = 0 Public Const CONNECT_UPDATE_PROFILE = &H1 \' The following includes all the constants defined for NETRESOURCE, \' not just the ones used in this example. Public Const RESOURCETYPE_DISK = &H1 Public Const RESOURCETYPE_PRINT = &H2 Public Const RESOURCETYPE_ANY = &H0 Public Const RESOURCE_CONNECTED = &H1 Public Const RESOURCE_REMEMBERED = &H3 Public Const RESOURCE_GLOBALNET = &H2 Public Const RESOURCEDISPLAYTYPE_DOMAIN = &H1 Public Const RESOURCEDISPLAYTYPE_GENERIC = &H0 Public Const RESOURCEDISPLAYTYPE_SERVER = &H2 Public Const RESOURCEDISPLAYTYPE_SHARE = &H3 Public Const RESOURCEUSAGE_CONNECTABLE = &H1 Public Const RESOURCEUSAGE_CONTAINER = &H2 \' Error Constants: Public Const ERROR_ACCESS_DENIED = 5& Public Const ERROR_ALREADY_ASSIGNED = 85& Public Const ERROR_BAD_DEV_TYPE = 66& Public Const ERROR_BAD_DEVICE = 1200& Public Const ERROR_BAD_NET_NAME = 67& Public Const ERROR_BAD_PROFILE = 1206& Public Const ERROR_BAD_PROVIDER = 1204& Public Const ERROR_BUSY = 170& Public Const ERROR_CANCELLED = 1223& Public Const ERROR_CANNOT_OPEN_PROFILE = 1205& Public Const ERROR_DEVICE_ALREADY_REMEMBERED = 1202& Public Const ERROR_EXTENDED_ERROR = 1208& Public Const ERROR_INVALID_PASSWORD = 86& Public Const ERROR_NO_NET_OR_BAD_PATH = 1203&
Indsæt 2 kommandoknapper på din form der hedder cmdTilslut og cmdAfbryd. Indsæt en tekstboks der hedder txtNetDrev.
Tilføj følgende kode :
Option Explicit
Private Sub cmdTilslut_Click() Dim NetR As NETRESOURCE Dim ErrInfo As Long Dim MyPass As String, MyUser As String
NetR.dwScope = RESOURCE_GLOBALNET NetR.dwType = RESOURCETYPE_DISK NetR.dwDisplayType = RESOURCEDISPLAYTYPE_SHARE NetR.dwUsage = RESOURCEUSAGE_CONNECTABLE NetR.lpLocalName = \"X:\" \' If undefined, Connect with no device NetR.lpRemoteName = txtNetDrev.Text \' Your valid share \'NetR.lpComment = \"Optional Comment\" \'NetR.lpProvider = \' Leave this undefined
\' If the MyPass and MyUser arguments are null (use vbNullString), the \' user context for the process provides the default user name. ErrInfo = WNetAddConnection2(NetR, MyPass, MyUser, _ CONNECT_UPDATE_PROFILE) If ErrInfo = NO_ERROR Then MsgBox \"Du er tilsluttet netværksdrevet \" & txtNetDrev.Text, vbInformation, _ \"Netværksdrev er tilsluttet !\" Else MsgBox \"ERROR: \" & ErrInfo & \" - Tilslutning mislykkedes !\", _ vbExclamation, \"FEJL i tilslutning !\" End If End Sub
Private Sub cmdAfbryd_Click() Dim ErrInfo As Long Dim strLocalName As String
\' You may specify either the lpRemoteName or lpLocalName \'strLocalName = \"\\\\ServerName\\ShareName\" strLocalName = \"X:\" ErrInfo = WNetCancelConnection2(strLocalName, _ CONNECT_UPDATE_PROFILE, False) If ErrInfo = NO_ERROR Then MsgBox \"Tilslutning til \" & txtNetDrev.Text & \" er afbrudt.\", vbInformation, _ \"Forbindelsen er afbrudt\" Else MsgBox \"ERROR: \" & ErrInfo & \" - Forbindelsen kunne ikke afbrydes\", _ vbExclamation, \"FEJL !\" End If End Sub
Fejl 67 er fordi der ikke er deling på det drev du prøver at tilslutte til.
Synes godt om
Ny brugerNybegynder
Din løsning...
Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.