Bom colega o código que você pesquisou está funcionando que é uma beleza.
bom você entendeu como ele funciona
eis aqui a explicação
primeiro o código para window XP
vamos para testar primeiro a Pasta de deve existir no diretório
então crie uma pasta no diretório c: como o nome de pasta de rede
inclua em seu form
04 text box e 01 command button
agora cole o código abaixo
'-----------------------------------------------
'Versão para XP
'-----------------------------------------------
Option Explicit
Private Declare Function NetShareAdd9x Lib "svrapi" Alias "NetShareAdd" (pszServer As Any, ByVal sLevel As Integer, pbBuffer As Any, ByVal cbBuffer As Integer) As Long
Private Const NERR_SUCCESS As Long = 0&
'share types
Private Const STYPE_ALL As Long = -1
'note: my Const
Private Const STYPE_DISKTREE As Long = 0
Private Const STYPE_PRINTQ As Long = 1
Private Const STYPE_DEVICE As Long = 2
Private Const STYPE_IPC As Long = 3
Private Const STYPE_SPECIAL As Long = &H80000000
'permissions
Private Const ACCESS_READ As Long = &H1
Private Const ACCESS_WRITE As Long = &H2
Private Const ACCESS_CREATE As Long = &H4
Private Const ACCESS_EXEC As Long = &H8
Private Const ACCESS_DELETE As Long = &H10
Private Const ACCESS_ATRIB As Long = &H20
Private Const ACCESS_PERM As Long = &H40
Private Const ACCESS_ALL As Long = ACCESS_READ Or _
ACCESS_WRITE Or _
ACCESS_CREATE Or _
ACCESS_EXEC Or _
ACCESS_DELETE Or _
ACCESS_ATRIB Or _
ACCESS_PERM
Private Type SHARE_INFO_2
shi2_netname As Long
shi2_type As Long
shi2_remark As Long
shi2_permissions As Long
shi2_max_uses As Long
shi2_current_uses As Long
shi2_path As Long
shi2_passwd As Long
End Type
Private Declare Function NetShareAdd Lib "Netapi32" _
(ByVal servername As Long, _
ByVal level As Long, _
buf As Any, _
parmerr As Long) As Long
Private Sub Form_Load()
Text1.Text = "
\\ " & Environ$("COMPUTERNAME")
' aqui mostra sua máquina
Text2.Text = "c:\program files\adobe"
' aqui a pasta a ser compartilhada Text3.Text = "vbnetdemo"
' o nome que parecerá na rede Text4.Text = "VBnet demo test share" ' aqui pode até ficar em branco
Text5.Text = "" ' este também
End Sub
Private Sub Command1_Click()
Dim success As Long
success = ShareAdd(Text1.Text, _
Text2.Text, _
Text3.Text, _
Text4.Text, _
Text5.Text)
Select Case success
Case 0: MsgBox "Pasta compartilhada com sucesso!"
Case 2118: MsgBox "Pasta não Existe"
Case Else: MsgBox "Erro numero " & success
End Select
End Sub
Private Function ShareAdd(sServer As String, _
sSharePath As String, _
sShareName As String, _
sShareRemark As String, _
sSharePw As String) As Long
Dim dwServer As Long
Dim dwNetname As Long
Dim dwPath As Long
Dim dwRemark As Long
Dim dwPw As Long
Dim parmerr As Long
Dim si2 As SHARE_INFO_2
'obtain pointers To the server, share And path
dwServer = StrPtr(sServer)
dwNetname = StrPtr(sShareName)
dwPath = StrPtr(sSharePath)
'If the remark Or password specified,
'obtain pointer To those As well
If Len(sShareRemark) > 0 Then
dwRemark = StrPtr(sShareRemark)
End If
If Len(sSharePw) > 0 Then
dwPw = StrPtr(sSharePw)
End If
'prepare the SHARE_INFO_2 structure
With si2
.shi2_netname = dwNetname
.shi2_path = dwPath
.shi2_remark = dwRemark
.shi2_type = STYPE_DISKTREE
.shi2_permissions = ACCESS_ALL
.shi2_max_uses = -1
.shi2_passwd = dwPw
End With
'add the share
ShareAdd = NetShareAdd(dwServer, _
2, _
si2, _
parmerr)
End Function
ao se iniciar o projeto você nos text aparecerá mais ou menos assim
text2 = c:program filesadobe
text3 = vbnetdemo
text4 = VBnet demo test share
text5 = ' estará em branco
no text1 o nome de exemplo é do meu computador na rede
no text2 altere para c:\pasta e rede que foi a pasta que criamos no diretório c:
e clique no botão, pronto a pasta e rede foi compartilhada
veja se era isto que você queria
até