[VB.net] Porteo de la implementacion del api de WhatsApiNet WhatsApp WhatsAppAPI

Iniciado por 79137913, 29 Julio 2014, 23:49 PM

0 Miembros y 2 Visitantes están viendo este tema.

79137913

HOLA!!!

Antes que nada Gracias a Shiroko por desarrollar el api junto a venom0ux, y tambien a fermino por salvarme algunas dudas y por darme la idea de empezar a implementar WhatsAPI.

En este post no se explicara que es WhatsAPI, aclaro que no se usara WhatsAPI sino WhatsAPI.Net, tampoco se enseñara paso a paso y menos se daran indicaciones sobre el uso del lenguaje VB.Net.

Que vamos a necesitar:
Si es posible el ultimo VisualStudio, sino cualquier otro servira.
WART (descargar el Exe)
WhatsAppAPI.dll (Les dejo la ultima version a la fecha subida a Mediafire, pero intenten bajar una que este actualizada o compilenla del source en github).
Y por ultimo de ser posible una linea de telefono en la que no utilicemos WhatsApp (asi no se nos complican las cosas, el celular de la abuela servirá).

Empezamos:

Abrimos el WART, Colocamos nuestro numero(Sin + y sin ceros al principio, por ejemplo un numero para argentina seria 5492235352914 o 542235352914 [Nunca supe la diferencia entre con nueve y sin nueve]) y apretamos el boton Request Code

Una vez hecho esto te llegara un SMS o una llamada dandote un codigo, Colocalo en Code y presiona Confirm Code, luego nos dara una contraseña. (en caso de perder la contraseña, como ya estan registrados solo tienen que poner el numero y Clickear en Check Existing.)

La contraseña que nos dio la tenemos que copiar y guardar en un archivo de texto llamado "WAPASS.txt" en la carpeta donde se ejecute nuestra aplicacion, para testeos o debug, obviamente sera en "ruta_al_proyecto/bin/debug/WAPASS.txt".

Despues vamos a hacer un proyecto nuevo y vamos a agregar un modulo "mWhatsApp".
Código (vbnet) [Seleccionar]
Module mWhatsApp
   Dim WAPass As String
   Const WANum As String = "5492236685519"
   Dim wa As WhatsApp
   Public Sub InitWA(ByVal NickName As String, Optional ByVal debug As Boolean = False)
       WAPass = File.ReadAllText(My.Application.Info.DirectoryPath & "\WAPASS.txt")
       wa = New WhatsApp(WANum, WAPass, NickName, debug)
       AddHandler wa.OnLoginSuccess, AddressOf wa_OnLoginSuccess
       AddHandler wa.OnLoginFailed, AddressOf wa_OnLoginFailed
       AddHandler wa.OnGetMessage, AddressOf wa_OnGetMessage
       AddHandler wa.OnGetMessageReceivedClient, AddressOf wa_OnGetMessageReceivedClient
       AddHandler wa.OnGetMessageReceivedServer, AddressOf wa_OnGetMessageReceivedServer
       AddHandler wa.OnNotificationPicture, AddressOf wa_OnNotificationPicture
       AddHandler wa.OnGetPresence, AddressOf wa_OnGetPresence
       AddHandler wa.OnGetGroupParticipants, AddressOf wa_OnGetGroupParticipants
       AddHandler wa.OnGetLastSeen, AddressOf wa_OnGetLastSeen
       AddHandler wa.OnGetTyping, AddressOf wa_OnGetTyping
       AddHandler wa.OnGetPaused, AddressOf wa_OnGetPaused
       AddHandler wa.OnGetMessageImage, AddressOf wa_OnGetMessageImage
       AddHandler wa.OnGetMessageAudio, AddressOf wa_OnGetMessageAudio
       AddHandler wa.OnGetMessageVideo, AddressOf wa_OnGetMessageVideo
       AddHandler wa.OnGetMessageLocation, AddressOf wa_OnGetMessageLocation
       AddHandler wa.OnGetMessageVcard, AddressOf wa_OnGetMessageVcard
       AddHandler wa.OnGetPhoto, AddressOf wa_OnGetPhoto
       AddHandler wa.OnGetPhotoPreview, AddressOf wa_OnGetPhotoPreview
       AddHandler wa.OnGetGroups, AddressOf wa_OnGetGroups
       AddHandler wa.OnGetSyncResult, AddressOf wa_OnGetSyncResult
       AddHandler wa.OnGetStatus, AddressOf wa_OnGetStatus
       AddHandler wa.OnGetPrivacySettings, AddressOf wa_OnGetPrivacySettings
       AddHandler WhatsAppApi.Helper.DebugAdapter.Instance.OnPrintDebug, AddressOf Instance_OnPrintDebug
       wa.Connect()
       Dim datFile As String = getDatFileName(WANum)
       Dim nextChallenge() As Byte
       If (File.Exists(datFile)) Then
           Dim foo As String = File.ReadAllText(datFile)
           nextChallenge = Convert.FromBase64String(foo)
       End If
       wa.Login(nextChallenge)
       ProcessChat(wa)
   End Sub
   Public Function SendWA(ByVal MSG As String, Num As String) As Boolean
       Dim usrMan As New WhatsUserManager()
       Dim tmpUser = usrMan.CreateUser(Num, "User")
       wa.SendMessage(Num, MSG)


       Return True
   End Function
   Public Sub Instance_OnPrintDebug(value As Object)
       Debug.Print(value)
   End Sub
   Public Sub wa_OnGetPrivacySettings(settings As Dictionary(Of WhatsApp.VisibilityCategory, WhatsApp.VisibilitySetting))

   End Sub
   Public Sub wa_OnGetStatus(form As String, type As String, name As String, status As String)

   End Sub
   Public Function getDatFileName(pn As String) As String
       Dim filename As String = String.Format("{0}.next.dat", pn)
       Return Path.Combine(Directory.GetCurrentDirectory(), filename)
   End Function
   Public Sub wa_OnGetSyncResult(index As Integer, sid As String, existingUsers As Dictionary(Of String, String), failedNumbers As String())

   End Sub
   Public Sub wa_OnGetGroups(groups As WaGroupInfo())

   End Sub
   Public Sub wa_OnGetPhotoPreview(from As String, id As String, data() As Byte)
       File.WriteAllBytes(String.Format("preview_{0}.jpg", from), data)
   End Sub
   Public Sub wa_OnGetPhoto(from As String, id As String, data() As Byte)
       File.WriteAllBytes(String.Format("{0}.jpg", from), Data)
   End Sub
   Public Sub wa_OnGetMessageVcard(from As String, id As String, name As String, data() As Byte)
       File.WriteAllBytes(String.Format("{0}.vcf", name), Data)
   End Sub
   Public Sub wa_OnGetMessageLocation(from As String, id As String, lon As Double, lat As Double, url As String, name As String, preview() As Byte)
       File.WriteAllBytes(String.Format("{0}{1end sub.jpg", lat, lon), preview)
   End Sub
   Public Sub wa_OnGetMessageVideo(from As String, id As String, filename As String, fileSize As Integer, url As String, preview() As Byte)
       OnGetMedia(filename, url, preview)
   End Sub
   Public Sub OnGetMedia(file As String, url As String, data() As Byte)
       My.Computer.FileSystem.WriteAllBytes(String.Format("preview_{0}.jpg", file), data, False)
       Dim WA_WC As New WebClient
       WA_WC.DownloadFileAsync(New Uri(url), file, 0)
   End Sub
   Public Sub wa_OnGetMessageAudio(from As String, id As String, filename As String, filesize As Integer, url As String, preview() As Byte)
       OnGetMedia(filename, url, preview)
   End Sub
   Public Sub wa_OnGetMessageImage(from As String, id As String, filename As String, size As Integer, url As String, preview() As Byte)
       OnGetMedia(filename, url, preview)
   End Sub
   Public Sub wa_OnGetPaused(from As String)

   End Sub
   Public Sub wa_OnGetTyping(from As String)

   End Sub
   Public Sub wa_OnGetLastSeen(from As String, lastseen As DateTime)

   End Sub
   Public Sub wa_OnGetMessageReceivedServer(from As String, id As String)

   End Sub
   Public Sub wa_OnGetMessageReceivedClient(from As String, id As String)

   End Sub
   Public Sub wa_OnGetGroupParticipants(gjid As String, jids() As String)

   End Sub
   Public Sub wa_OnGetPresence(from As String, type As String)

   End Sub
   Public Sub wa_OnNotificationPicture(type As String, jid As String, id As String)

   End Sub
   Public Sub wa_OnGetMessage(node As ProtocolTreeNode, from As String, id As String, name As String, message As String, receipt_sent As Boolean)
       Dim Number As String = Split(from, "@")(0)

   End Sub
   Private Sub wa_OnLoginFailed(data As String)
       End
   End Sub
   Private Sub wa_OnLoginSuccess(phoneNumber As String, data() As Byte)
       ' next password
       Dim sdata As String = Convert.ToBase64String(data)
       My.Computer.FileSystem.WriteAllText(getDatFileName(WANum), sdata, False)
   End Sub
   Private Sub ProcessChat(wa As WhatsApp)
       Dim thRecv = New Thread(AddressOf ProcessChatT) : thRecv.IsBackground = True
       thRecv.Start()
   End Sub
   Sub ProcessChatT(t)
       Try
           While wa IsNot Nothing
               wa.PollMessages()
               Thread.Sleep(100)
               Continue While
           End While
       Catch generatedExceptionName As ThreadAbortException
       End Try

   End Sub
End Module


Una vez agregado este codigo vamos a Agregar codigo al form principal para terminar con este ejemplito. (Mi from se llama Principal, ojo)
Código (vbnet) [Seleccionar]
   Private Sub Principal_Load(sender As Object, e As EventArgs) Handles MyBase.Load
       InitWA("Tutorial By 79137913")
       Call SendWA("Prueba 1", "ACAPONEELNUMEROALQUEQUIERASMANDARELMENSAJE")
   End Sub


En InitWA pones el Nick que quieras y en SendWa pones el mensaje seguido del numero al que quieras enviar un mensaje

Nota: para que no sea spam ambas personas deben estar en sus respectivas listas de contactos, por ende agrega al sistema a tu lista de contactos antes de enviar mensajes para que no se bloquee el usuario.

GRACIAS POR LEER!!!
"Como no se puede igualar a Dios, ya he decidido que hacer, ¡SUPERARLO!"
"La peor de las ignorancias es no saber corregirlas"

79137913                          *Shadow Scouts Team*

jalvear1

Amigo tengo una pregunta, quiero saber caunto tiempo de duracion tiene esta aplicacion ya que a los clientes de mi empresa les envio un mensaje diario , de sus ingresos segun el software que manejann con nosotros, son casi 100 clientes yo use ese codigo para hacer un programa de envio masivo, ahi algun problema, nos puede bloquear whatsapp el envio de mensajes , puede que en algun momento el codigo no siga sirviendo, o no voy a tener problemas ya que me sirvio de mucho.

joel_del

Una pregunta, no hay peligro de que Whatsapp me bloquee mi aplicación y no me deje volver a enviar mensajes, no has escuchado casos? Gracias por responder

engel lex

que tal si revisan los términos de servicio de whatssapp? jalvear1 probablemente el departamento legal te pueda ayudar con eso y puedas respondernos aquí esa duda...
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

79137913

HOLA!!!

Jalvear1, te invito a la proxima que uses los codigos de aqui primero agradecer y luego en el caso que tengas un prolema ahi preguntar.

Si, lo mas probable es que haya bloqueado el numero por spam, eso pasa cuando le envias mensajes a numeros que no te tienen agendado, tenes que hacer que todos tus clientes agenden el numero, sino no podes.

El numero que tenes ya no sirve, vas a tener que utilizar otro.

En cuanto a lo que dice Joel_del , no no bloquean la aplicacion, no tienen manera de identificarla, lo que bloquean es el numero.

GRACIAS POR LEER!!!
"Como no se puede igualar a Dios, ya he decidido que hacer, ¡SUPERARLO!"
"La peor de las ignorancias es no saber corregirlas"

79137913                          *Shadow Scouts Team*

jalvear1

amigo que pena contigo ,  :-X muchas gracias por el aporte me ha sido de mucha ayuda disculpame por no agradecer. :D

pachoduran

Hola, muy interesante este tema, hice la prueba y me ha funcionado muy bien, he tratado de enviar un mensaje con una foto y no he podido, podrian ayudarme?

Modifique la funcion SendWA del ejemplo para poder enviar imagenes:

Código (vbnet) [Seleccionar]
   Public Function SendWA(ByVal MSG As String, ByVal Num As String) As Boolean
       Dim usrMan As New WhatsUserManager()
       Dim imgSegnature As Image

       Dim tmpUser = usrMan.CreateUser(Num, "User")
       imgSegnature = Image.FromFile("p.jpg")
       Dim ms = New MemoryStream()
       imgSegnature.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg) ' Use appropriate format here
       Dim bytes = ms.ToArray()

       wa.SendMessageImage(Num, bytes, ApiBase.ImageType.JPEG)

       Return True
   End Function


Siempre se bloquea y nunca envia la imagen.

Muchas gracias. Dios los bendiga

laercio.tersi

Amigos não consegui fazer funcionar

estou usando o visual studio 2012

Código (vbnet) [Seleccionar]
 InitWA = coloquei o meu usuario
 Call SendWA("mensagem para enviar", "numero para envio")

   Const WANum As String = "aqui não sei oque coloco" ' muito obrigado pela ajuda





[MOD]: Estás en una comunidad Española, porfavor, intenta utilizar el traductor de Google la próxima vez.

79137913

"Como no se puede igualar a Dios, ya he decidido que hacer, ¡SUPERARLO!"
"La peor de las ignorancias es no saber corregirlas"

79137913                          *Shadow Scouts Team*

findesemana

Hola! Gracias por el tutorial! pero necesito un poco de ayuda..
He seguido los pasos pero me daba varios errores. Entonces empece a importar librerias hasta que me quedo un solo error en la linea:
   AddHandler wa.OnGetGroups, AddressOf wa_OnGetGroups
Pregunto: No tendras un ejemplo funcionando que puedas subir?
DE verdad me interesa el tema.. Gracias por tu ayuda de antemano..
PD estoy usando vb 2013

por favor por favor por favor  :huh: