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 (https://github.com/venomous0x/WhatsAPI), aclaro que no se usara WhatsAPI (https://github.com/venomous0x/WhatsAPI) sino WhatsAPI.Net (https://github.com/perezdidac/WhatsAPINet), 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 (http://www.visualstudio.com/es-es/visual-studio-homepage-vs.aspx), sino cualquier otro servira.
WART (https://github.com/shirioko/WART) (descargar el Exe)
WhatsAppAPI.dll (http://www.mediafire.com/download/2zq48ba272yju7y/WhatsAppApi.rar) (Les dejo la ultima version a la fecha subida a Mediafire, pero intenten bajar una que este actualizada o compilenla del source en github (https://github.com/perezdidac/WhatsAPINet)).
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
(http://i.imgur.com/3KZEsmR.png)
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".
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)
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!!!
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.
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
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...
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!!!
amigo que pena contigo , :-X muchas gracias por el aporte me ha sido de mucha ayuda disculpame por no agradecer. :D
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:
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
Amigos não consegui fazer funcionar
estou usando o visual studio 2012
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.
HOLA!!!
Utitliza vb2013 por favor
GRACIAS POR LEER!!!
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:
Buen día,
Antes que nada agradecer las maravillosas aportaciones que hacen en el foro.
Tengo una duda con respecto al codigo que se esta agregando en este ejemplo, yo he seguido todo los pasos pero me nunca entra en la condicion:
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
No me encuentra el archivo y nunca se crea el .dat que dice según el debugger.
Estoy haciendo algo mal?, me falta algún paso?
Agradezco sus comentarios.
Cita de: findesemana en 12 Febrero 2015, 03:53 AM
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:
Hola! findesemana, una pregunta, cuales fueron las librerías que empezaste a importar? a mi aun me sigue marcando algunos errores, si me pudieras decir cuales fueron las librerías que le agregaste te lo agradecería mucho.
!!
Odio este tipo de APIs desarrolladas para .Net sin ningún tipo de documentación .Net (XML), simplemente llegan a dificultar el
majeo manejo hasta imposibilitar la comprensión y la utilización de los miembros definidos en el interior de la librería debido a un desarrollo inapropiado/descuidado al no existir documentación visualizable ni accesible en tiempo de diseño (mediante IntelliSense, Object Inspector) para una plataforma en donde hay que cuidar ciertos detalles esenciales si publicas algo cómo esto para el público.
Tras descargarme el código fuente de la última versión de WhatsAppi.Net, desarrollado en C#, y analizarlo muy, muy por encima, he podido comprobar que consta de 508 miembros públicos sin documentar, la mayoría de las classes definidas (95%) usan muchos usings de NameSpaces que no se utilizan (es decir, son totalmente innecesarios), hay un total de 427 conflictos de convenciones de nombres que no se han corregido, hay varios formatos de Strings con cantidades incorrectas de parámetros (ej: String.Format("{0}", 0, 1) ), absolutamente TODOS los event-handlers están incorrectamente definidos (no utilizan la firma 'sender, e'), y lo más importante de todo, uno de sus miembros tiene una considerable fuga de recursos ya que no libera las instancias disposables de los miembros definidos en la Class 'KeyStream', todo esto entre otro tipo de fallos generales que se pueden comprobar con un análisis básico de código en VS.
Sinceramente, yo personalmente no recomiendo la utilización de ninguna librería que esté desarrollada de una manera tan descuidada, a menos que usar esa librería sea el úncio recurso viable que exista para llevar a cabo la tarea requerida (cosa que dezconozco).Pero debido a la gran espectación que ha causado este tema ...este post (y también porque estaba un poco aburrido xD), me he tomado el tiempo de analizar, corregir, y actualizar el snippet de ejemplo que compartió el compañero @79137913 en el primer post, puesto que a muchos usuarios les ha sido dificil comprender la integración del código, o le han dado errores de algún tipo al intentar integrarlo.
Aunque por otro lado, debo confesar que yo NO utilizo WhatsApp, así que las mejoras/adaptaciones/modificaciones que he realizado en el código original, son modificaciones que he llevado a cabo bastante 'a ciegas' ya que no podré testear los resultados en un dispositivo.
Primero, antes de mostrar la actualización del código, comentaré algunos fallos (que considero bastante graves) que ustedes deberán tener en cuenta si utilizan el código original que compartió el amigo @79137913 sin hacerle ninguna modificación adicional.
Por orden de importancia/gravedad:
1.
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
Por cada vez que se llame al método 'InitWA', éste AÑADIRÁ (que no reemplazará) los listeners de los eventos especificados en el código, ya que en ningún momento se está comprobando si un evento está ya siendo escuchado, ni tampoco se están eliminando handlers anteriores con el uso de la declaración 'RemoveHandler', esto ocasionaría un comportamiento anormal en en los event-handlers definidos en el código.
Hay que tenerlo MUY en cuenta por ejemplo al desconectar (wa.Disconnect), y volver a llamar al método 'InitWa', por cada vez que se hiciera eso...
2.
Citar 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
La aplicación que utilice este método, incrementará el consumo RAM indefinidamente según la cantidad de veces que se instancie el WebClient, ya que la instancia del WebClient jamás se llega a liberar.
3.
Citar 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
La función realmente no cumple ninguna utilidad, ya que en cualquier circunstancia siempre devolverá verdadero.
Lo que habría que tratar de devolver es Verdadero si el mensaje se envia, y Falso en caso contrario,
además, quizas ni siquiera haya que fijarse en devolver True o False, ya que la función "WhatsAppApi.SendMessage" devuelve una cadena de texto cuyo contenido desconozco, pero quizás contnega detalles sobre la validación de la operación ("Succes" o "Fail"), no lo se, ya que no puedo comprobarlo sin WhatsApp (y no voy a hacerle Reflection al ensamblado solo para descubrir que valor de texto envia dicha función).
4.
Citar 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
El formato es erroneo, ya que el segundo parámetro está abierto, por lo tanto la longitud (lon) no se tendrá en cuenta en el formato del texto.
El código original estaba bastante vb6-estilizado, aunque es algo comprensible viniendo de un programador experimentado en VB6, por otro lado yo no acepto el uso de los wrappers de VB6 en .Net, y la estructurización del código era un poco "arreu" (descuidado) cómo decimos en mi tierra.
Por lo demás, he respetado mayormente el funcionamiento y la sintaxis del snippet original de @79137913.
¿Qué es lo que he hecho?- Corregir los errores mencionados arriba.
- Corregir todas las convenciones de nombres en los miembros del código original (métodos y parámetros mal nombrados) para facilitarle la tarea de búsqueda/identificación al compiler.
También he corregido aquellas definiciones de nombres que podían resultar en ambiguaciones (ej: file),
pues quiero recordarles que algunas palabras reservadas cómo "'type', 'from', es preferible "escaparlas" al definirlas como nombres de variables,
y otros nombres como "file", al importar el espacio de nombres "System.IO.File", directamente es preferible evitar ese tipo de nombramientos ambiguos y utilizar algo más específico (ej: fileObj, fileName, filePath, etc). - Añadir los Imports de los Namespaces requeridos para el uso del código, por los problemas que algunos usuarios han tenido con eso.
- Traslación de Módulo a Clase.
- Implementación de la interfáz IDisposable, para liberar la instancia de WhatsApp (WA) correctamente.
- Implementación de una excepción específica, 'WALoginFailedException', que sustituye a la terminación de ejecución en el método 'OnLoginFailed' del código original.
- Documentar todos los miembros del código. Aunque sigue siendo una documentación MUY incompleta a falta de documentación oficial por parte de los desarrolladores de la API para .Net.
¿Cómo utilizarlo?Esteticamente el código modificado es diferente, pero su utilización es practicamente igual al código original,
especifiquen sus datos en las propiedades "Number", "Password" y/o "PasswordFilepath";
el método original 'InitWa' ha sido reemplazado por el nuevo método 'Initializecomponent';
el método original 'ProcessChat' ha sido reemplazado por el nuevo método 'ProcessChatAsync', y el nuevo método 'ProcessChat' ahora es sincrónico;
el método original 'SendWA' ha sido reemplazado por el nuevo método 'SendMessage' para enviar un mensaje, y el nuevo método 'TestMessage' para testear un mensaje con un usuario temporal.
Ejemplo de uso:
Public Class TestForm
Private wa As WhatsAppHelper
Private Sub Test()
Me.wa = New WhatsAppHelper(nickName:="", [debug]:=False)
Using wa
Debug.WriteLine(Me.wa.Number)
Debug.WriteLine(Me.wa.Password)
Debug.WriteLine(Me.wa.TextEncoding.ToString)
wa.ProcessChatAsync()
wa.SendMessage(msg:="mensaje", num:="num")
End Using
End Sub
End Class
Espero que a alguien le sirva este código para despejar mejor las dudas, tengan en cuenta que esto no lo he desarrollado para mi, yo odio WhatsApp y ni lo tengo ni lo uso, este código es con la única intención de intentar ayudarles, pero si tienen alguna duda o error al usarlo entonces será mejor que la consulten con el compañero @79137913 y no conmigo, porque, vuelvo a repetir, no puedo testear las modificaciones que hice (ni el ejemplo de uso que compartí).
Source:#Region " Option statements "
Option Explicit On
Option Strict On
Option Infer Off
#End Region
#Region " Imports "
Imports System.IO
Imports System.Linq
Imports System.Net
Imports System.Text
Imports System.Threading
Imports System.Threading.Tasks
Imports WhatsAppApi
Imports WhatsAppApi.Account
Imports WhatsAppApi.Helper
Imports WhatsAppApi.Response
Imports WhatsAppApi.ApiBase
#End Region
#Region " WhatsAppHelper "
''' <summary>
''' Class WhatsAppHelper.
''' This class cannot be inherited.
''' </summary>
Public NotInheritable Class WhatsAppHelper : Implements IDisposable
#Region " Objects "
''' <summary>
''' The <see cref="WhatsAppApi.WhatsApp"/> instance.
''' </summary>
Private WithEvents wa As WhatsApp
''' <summary>
''' </summary>
Private WithEvents waDebugger As DebugAdapter
#End Region
#Region " Properties "
''' <summary>
''' Gets the...
''' </summary>
''' <value>.</value>
Public ReadOnly Property Number As String
Get
Return "5492236685519"
End Get
End Property
''' <summary>
''' Gets the...
''' </summary>
''' <value>.</value>
Public ReadOnly Property PasswordFilepath As String
Get
Return Path.Combine(Application.StartupPath, "WAPASS.txt")
End Get
End Property
''' <summary>
''' Gets the...
''' </summary>
''' <value>.</value>
Public ReadOnly Property Password As String
Get
Try
Return File.ReadAllText(Me.PasswordFilepath, Me.TextEncoding)
Catch ex As FileNotFoundException
Throw New FileNotFoundException("WhatsApp password file not found.", Me.PasswordFilepath)
Catch ex As Exception
Throw
End Try
End Get
End Property
''' <summary>
''' Gets the...
''' </summary>
''' <value>.</value>
Public ReadOnly Property TextEncoding As Encoding
Get
Return Encoding.Default
End Get
End Property
#End Region
#Region " Exceptions "
''' <summary>
''' Exception that is thrown when WhatsApp login has failed.
''' </summary>
<Serializable>
Public NotInheritable Class WALoginFailedException : Inherits Exception
''' <summary>
''' Initializes a new instance of the <see cref="WALoginFailedException"/> class.
''' </summary>
Public Sub New()
MyBase.New("WhatsApp Login Failed")
End Sub
''' <summary>
''' Initializes a new instance of the <see cref="WALoginFailedException"/> class.
''' </summary>
''' <param name="message">The message that describes the error.</param>
Public Sub New(message As String)
MyBase.New(message)
End Sub
End Class
#End Region
#Region " Constructors "
''' <summary>
''' Initializes a new instance of the <see cref="WhatsAppHelper"/> class.
''' </summary>
''' <param name="nickName">.</param>
''' <param name="debug">.</param>
Public Sub New(ByVal nickName As String,
Optional ByVal debug As Boolean = False)
Me.InitializeComponent(nickName, debug)
End Sub
''' <summary>
''' Prevents a default instance of the <see cref="WhatsApp"/> class from being created.
''' </summary>
Private Sub New()
End Sub
#End Region
#Region " Private Methods "
''' <summary>
''' </summary>
''' <param name="nickName">.</param>
''' <param name="debug">.</param>
Private Sub InitializeComponent(ByVal nickName As String,
Optional ByVal debug As Boolean = False)
Me.wa = New WhatsApp(Me.Number, Me.Password, nickName, debug)
Me.waDebugger = DebugAdapter.Instance
Me.wa.Connect()
Dim datFile As String = Me.GetDatFileName(Me.Number)
Dim nextChallenge As Byte() = Nothing
If File.Exists(datFile) Then
Dim text As String = File.ReadAllText(datFile, Me.TextEncoding)
nextChallenge = Convert.FromBase64String(text)
End If
Me.wa.Login(nextChallenge)
End Sub
''' <summary>
''' </summary>
''' <param name="pn">.</param>
''' <returns>.</returns>
Private Function GetDatFileName(ByVal pn As String) As String
Dim filename As String = String.Format("{0}.next.dat", pn)
Return Path.Combine(Application.StartupPath, filename)
End Function
''' <summary>
''' </summary>
''' <param name="filename">.</param>
''' <param name="url">The url to download.</param>
''' <param name="data">.</param>
Private Sub DownloadMedia(ByVal filename As String,
ByVal url As String,
ByVal data As Byte())
File.WriteAllBytes(String.Format("preview_{0}.jpg", filename), data)
Dim waClient As New WebClient
Try
Using waClient
waClient.DownloadFileAsync(New Uri(url), filename, 0)
End Using
Catch ex As Exception
Throw
Finally
If waClient IsNot Nothing Then
waClient.Dispose()
End If
End Try
End Sub
#End Region
#Region " Public Methods "
''' <summary>
''' </summary>
''' <param name="msg">.</param>
''' <param name="num">.</param>
''' <returns>.</returns>
Public Function SendMessage(ByVal msg As String,
ByVal num As String) As String
Return wa.SendMessage([to]:=num, txt:=msg)
End Function
''' <summary>
''' </summary>
''' <param name="msg">.</param>
''' <param name="num">.</param>
''' <returns><c>true</c> if successfull, <c>false</c> otherwise.</returns>
Public Function TestMessage(ByVal msg As String,
ByVal num As String) As Boolean
Dim tmpUser As WhatsUser = New WhatsUserManager().CreateUser(num, "User")
Try
wa.SendMessage([to]:=num, txt:=msg)
Catch ex As Exception
Return False
End Try
Return True
End Function
''' <summary>
''' </summary>
Public Sub ProcessChatAsync()
Task.Factory.StartNew(Sub()
Me.ProcessChat(Me.wa)
End Sub)
End Sub
''' <summary>
''' </summary>
Public Sub ProcessChat()
While Me.wa IsNot Nothing
Try
Me.wa.PollMessages()
Catch ex As Exception
' Throw
End Try
Thread.Sleep(millisecondsTimeout:=100)
End While
End Sub
#End Region
#Region " Event-Handlers "
''' <summary>
''' Handles the OnGetPrivacySettings event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="settings">.</param>
Private Sub WA_OnGetPrivacySettings(ByVal settings As Dictionary(Of VisibilityCategory, VisibilitySetting)) _
Handles wa.OnGetPrivacySettings
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetStatus event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="form">.</param>
''' <param name="type">.</param>
''' <param name="name">.</param>
''' <param name="status">.</param>
Private Sub WA_OnGetStatus(ByVal form As String,
ByVal type As String,
ByVal name As String,
ByVal status As String) _
Handles wa.OnGetStatus
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetSyncResult event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="index">.</param>
''' <param name="sid">.</param>
''' <param name="existingUsers">.</param>
''' <param name="failedNumbers">.</param>
Private Sub WA_OnGetSyncResult(ByVal index As Integer,
ByVal sid As String,
ByVal existingUsers As Dictionary(Of String, String),
ByVal failedNumbers As String()) _
Handles wa.OnGetSyncResult
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetGroups event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="groups">.</param>
Private Sub WA_OnGetGroups(ByVal groups As WaGroupInfo()) _
Handles wa.OnGetGroups
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetPhotoPreview event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="data">.</param>
Private Sub WA_OnGetPhotoPreview(ByVal [from] As String,
ByVal id As String,
ByVal data As Byte()) _
Handles wa.OnGetPhotoPreview
Try
File.WriteAllBytes(String.Format("preview_{0}.jpg", [from]), data)
Catch ex As Exception
Throw
End Try
End Sub
''' <summary>
''' Handles the OnGetPhoto event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="data">.</param>
Private Sub WA_OnGetPhoto(ByVal [from] As String,
ByVal id As String,
ByVal data As Byte()) _
Handles wa.OnGetPhoto
Try
File.WriteAllBytes(String.Format("{0}.jpg", [from]), data)
Catch ex As Exception
Throw
End Try
End Sub
''' <summary>
''' Handles the OnGetMessageVcard event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="name">.</param>
''' <param name="data">.</param>
Private Sub WA_OnGetMessageVcard(ByVal [from] As String,
ByVal id As String,
ByVal name As String,
ByVal data As Byte()) _
Handles wa.OnGetMessageVcard
Try
File.WriteAllBytes(String.Format("{0}.vcf", name), data)
Catch ex As Exception
Throw
End Try
End Sub
''' <summary>
''' Handles the OnGetMessageLocation event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="lon">.</param>
''' <param name="lat">.</param>
''' <param name="url">.</param>
''' <param name="name">.</param>
''' <param name="preview">.</param>
Private Sub WA_OnGetMessageLocation(ByVal [from] As String,
ByVal id As String,
ByVal lon As Double,
ByVal lat As Double,
ByVal url As String,
ByVal name As String,
ByVal preview() As Byte) _
Handles wa.OnGetMessageLocation
Try
File.WriteAllBytes(String.Format("{0}{1}end sub.jpg", lat, lon), preview)
Catch ex As Exception
Throw
End Try
End Sub
''' <summary>
''' Handles the OnGetMessageVideo event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="filename">.</param>
''' <param name="fileSize">.</param>
''' <param name="url">.</param>
''' <param name="preview">.</param>
Private Sub WA_OnGetMessageVideo(ByVal [from] As String,
ByVal id As String,
ByVal filename As String,
ByVal fileSize As Integer,
ByVal url As String,
ByVal preview As Byte()) _
Handles wa.OnGetMessageVideo
Me.DownloadMedia(filename, url, preview)
End Sub
''' <summary>
''' Handles the OnGetMessageAudio event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="filename">.</param>
''' <param name="filesize">.</param>
''' <param name="url">.</param>
''' <param name="preview">.</param>
Private Sub WA_OnGetMessageAudio(ByVal [from] As String,
ByVal id As String,
ByVal filename As String,
ByVal filesize As Integer,
ByVal url As String,
ByVal preview As Byte()) _
Handles wa.OnGetMessageAudio
Me.DownloadMedia(filename, url, preview)
End Sub
''' <summary>
''' Handles the OnGetMessageImage event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="filename">.</param>
''' <param name="size">.</param>
''' <param name="url">.</param>
''' <param name="preview">.</param>
Private Sub WA_OnGetMessageImage(ByVal [from] As String,
ByVal id As String,
ByVal filename As String,
ByVal size As Integer,
ByVal url As String,
ByVal preview As Byte()) _
Handles wa.OnGetMessageImage
Me.DownloadMedia(filename, url, preview)
End Sub
''' <summary>
''' Handles the OnGetPaused event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
Private Sub WA_OnGetPaused(ByVal [from] As String) _
Handles wa.OnGetPaused
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetTyping event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
Private Sub WA_OnGetTyping(ByVal [from] As String) _
Handles wa.OnGetTyping
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetLastSeen event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="lastseen">.</param>
Private Sub WA_OnGetLastSeen(ByVal [from] As String,
ByVal lastseen As Date) _
Handles wa.OnGetLastSeen
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetMessageReceivedServer event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
Private Sub WA_OnGetMessageReceivedServer(ByVal [from] As String,
ByVal id As String) _
Handles wa.OnGetMessageReceivedServer
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetMessageReceivedClient event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="id">.</param>
Private Sub WA_OnGetMessageReceivedClient(ByVal [from] As String,
ByVal id As String) _
Handles wa.OnGetMessageReceivedClient
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetGroupParticipants event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="gjid">.</param>
''' <param name="jids">.</param>
Private Sub WA_OnGetGroupParticipants(ByVal gjid As String,
ByVal jids As String()) _
Handles wa.OnGetGroupParticipants
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetPresence event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="from">.</param>
''' <param name="type">.</param>
Private Sub WA_OnGetPresence(ByVal [from] As String,
ByVal type As String) _
Handles wa.OnGetPresence
' Put your code here.
End Sub
''' <summary>
''' Handles the OnNotificationPicture event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="type">.</param>
''' <param name="jid">.</param>
''' <param name="id">.</param>
Private Sub WA_OnNotificationPicture(ByVal [type] As String,
ByVal jid As String,
ByVal id As String) _
Handles wa.OnNotificationPicture
' Put your code here.
End Sub
''' <summary>
''' Handles the OnGetMessage event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="node">.</param>
''' <param name="from">.</param>
''' <param name="id">.</param>
''' <param name="name">.</param>
''' <param name="message">.</param>
''' <param name="receiptSent">.</param>
Private Sub WA_OnGetMessage(ByVal node As ProtocolTreeNode,
ByVal [from] As String,
ByVal id As String,
ByVal name As String,
ByVal message As String,
ByVal receiptSent As Boolean) _
Handles wa.OnGetMessage
Dim number As String = [from].Split("@"c).First
End Sub
''' <summary>
''' Handles the OnLoginFailed event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="data">The data.</param>
Private Sub WA_OnLoginFailed(ByVal data As String) _
Handles wa.OnLoginFailed
Throw New WALoginFailedException
End Sub
''' <summary>
''' Handles the OnLoginSuccess event of the <see cref="WA"/> instance.
''' </summary>
''' <param name="phoneNumber">.</param>
''' <param name="data">.</param>
Private Sub WA_OnLoginSuccess(ByVal phoneNumber As String,
ByVal data As Byte()) _
Handles wa.OnLoginSuccess
' next password
Dim sdata As String = Convert.ToBase64String(data)
Try
File.WriteAllText(Me.GetDatFileName(Me.Number), sdata)
Catch ex As Exception
Throw
End Try
End Sub
''' <summary>
''' Handles the OnPrintDebug event of the <see cref="waDebugger"/> instance.
''' </summary>
''' <param name="value">.</param>
Private Sub Instance_OnPrintDebug(ByVal value As Object) _
Handles waDebugger.OnPrintDebug
Debug.Print(value.ToString)
End Sub
#End Region
#Region " IDisposable "
''' <summary>
''' To detect redundant calls when disposing.
''' </summary>
Private isDisposed As Boolean = False
''' <summary>
''' Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
''' </summary>
Public Sub Dispose() Implements IDisposable.Dispose
Me.Dispose(isDisposing:=True)
GC.SuppressFinalize(obj:=Me)
End Sub
''' <summary>
''' Releases unmanaged and - optionally - managed resources.
''' </summary>
''' <param name="isDisposing">
''' <c>true</c> to release both managed and unmanaged resources;
''' <c>false</c> to release only unmanaged resources.
''' </param>
Protected Sub Dispose(ByVal isDisposing As Boolean)
If Not Me.IsDisposed Then
If isDisposing Then
Try
Me.wa.Disconnect()
Me.wa = Nothing
Me.waDebugger = Nothing
Catch ex As Exception
Throw
End Try
End If
End If
Me.isDisposed = True
End Sub
#End Region
End Class
#End Region
Saludos!
HOLA!!!
@Elektro:
Muy bueno que hayas modificado el codigo, me alegra mucho, en cuanto a el codigo no es mas que un porteo de su version en c# casi textual.
Es cierto que tiene una forma muy de vb6 aunque no es mi estructura, intento respetar los lenguajes.
Confirmo que tu codigo funciona correctamente.
Este post me alienta a revivir una vieja app, que si no te importa, me gustaria que luego revisaras a ver que te parece, estoy empezando a programarla recien si queres mas info contactame por priv.
GRACIAS POR LEER!!!
Cita de: 79137913 en 27 Febrero 2015, 18:15 PMConfirmo que tu codigo funciona correctamente.
Me alegra saberlo, realmente lo hice todo "a ciegas" y tenia esa duda de que al final no sirviera de mucho xD.
Cita de: 79137913 en 27 Febrero 2015, 18:15 PMEste post me alienta a revivir una vieja app, que si no te importa, me gustaria que luego revisaras a ver que te parece, estoy empezando a programarla recien si queres mas info contactame por priv.
jajaja, no hace falta ni que menciones de que app se trata, te estoy leyendo la mente, y creo que a todos los usuarios de elhacker.net nos gustará poder ver esa gran herramienta actualizada, de hecho hace tiempo pensé en hacer una versión .Net de tu programa, pero me desmotivé bastante porque... bueno, porque la app ya existe y es funcional en VB6 así que me pareció un poco tontería el tratar de reinventarla en .Net xD, y tampoco quería que pareciese que intentaba arrebatarte ningún mérito, así que lo mejor es que lo hagas tú, y yo te ayudo si quieres y si lo necesitases, por supuesto.
Un saludo!
Cita de: chesteralex en 14 Febrero 2015, 00:46 AM
Buen día,
Antes que nada agradecer las maravillosas aportaciones que hacen en el foro.
Tengo una duda con respecto al codigo que se esta agregando en este ejemplo, yo he seguido todo los pasos pero me nunca entra en la condicion:
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
No me encuentra el archivo y nunca se crea el .dat que dice según el debugger.
Estoy haciendo algo mal?, me falta algún paso?
Agradezco sus comentarios.
A mi me esta pasando lo mismo y no consigo que realize en envio del mensaje. ¿Podeis ayudarnos?
Gracias.
HOLA!!!
Eso es por que no tenes el archivo next challenge en la carpeta del ejecutable.
GRACIAS POR LEER!!!
Claro que no tengo el archivo Next Challenge, pero de donde lo saco o como se genera.
Gracias por responder tan pronto.
Cita de: gusontop en 5 Marzo 2015, 18:42 PM
Claro que no tengo el archivo Next Challenge, pero de donde lo saco o como se genera.
Gracias por responder tan pronto.
Gusontop, tengo el mismo problema es lo único que me hace falta para poder hechar a andar la APP, ojala y esto lo puedan responder rápido, de igual manera si encuentro como se debe hacer eso del archivo Next Challenge lo posteo.
HOLA!!!
Chicos les confirmo la razon por la cual el programa no entra en ese if es por que su archivo nextchallenge no existe, puede haber 2 razones para esto, la primera es que ustedes cambiaron el numero de telefono o que ustedes nunca enviaron un mensaje.
En caso que sea la primera borren el archivo nextchallenge obsoleto, vuelvan a generar la clave e intenten de nuevo.
En caso que sea la seguda es programa no necesita del archivo next challenge la primera vez por que el next challenge estaria en blanco. Yo supongo y solo supogo, si ustedes estan usando un numero que en algun momento tuvo whatsapp lamento informarles que el nextchallenge no lo pueden obtener por estos medios, ya que sino seria muy simple hackear el whatsapp de cualquiera con esos simples pasos. Para crear la contraseña deben si o si usar un numero virgen en whatsapp.(o un numero que siempre ha usado WART.
GRACIAS POR LEER!!!
Gracias,
He cogido un telefono que nunca ha tenido WhatApp, el del abuelo, y cada vez que ejecuto la aplicacion WART con este numero de telefono, me da un texto distinto, que copio al archivo WAPASS.TXT que ubico en el direcctorio de la aplicacion, en este caso dentro de bin\Debug de hecho interrumpo el programa cuando lee este archivo y la clave que lee es la correcta.
Luego cuando hace el wa.conect() no genera el archivo NextChallenge, o tengo que crear el archivo nextchallenge con la misma clave que WAPASS.TXT
Lo siento, pero no es mi caso ninguno de los supuestos.
Gracias.
HOLA!!!
No, el archivo next challenge se genera solo, una vez que se loguea correctamente.
GRACIAS POR LEER!!!
Gracias 79137913, por el tema importante planteado, espero que no sea muy antiguo...
Estimado realice todas sus observaciones pero aun no genera el comentado archivo
numerotelefono.next.dat
Utilice dos numero diferentes que no tenían whatsapp previamente...
utilice WART, ingrese numero, me genero clave, la ingrese en el archivo WAPASS.txt
asigna correctamente la clave dentro de la aplicación... pero nunca se genera el archivo.
- Este archivo se genera automáticamente por la aplicación visual?
- y en que momento?
gracias nuevamente por su respuesta
Saludos
HOLA!!!
Deberias fijarte si Private Sub wa_OnLoginSuccess(phoneNumber As String, data() As Byte se ejecuta. Ese es el procedimiento que guarda el next challenge
GRACIAS POR LEER!!!
Muchas gracias por responder, pero aun no anda...
La instrucción que se inicializa en InitWA esta con los siguientes datos (quite los últimos 3)
wa = New WhatsAppApi.WhatsApp("56958386XXX", "BKGdtj2qtaSu//3+RjAJ0nczLXXX"," NICKXXX", False)
pero no se genera el archivo porque en wa_OnLoginFailed
el parámetro "data" recibe el dato: not-authorized
Sera un problema de mi proveedor de telefononia, aunque probé con dos compañías diferentes.
Muchas gracias.
HOLA!!!
Bueno cuando surge ese parametro hay 3 opciones:
1- Que generaste una nueva contraseña pero usas una vieja en tu codigo.
Solucion: usa de nuevo el WART y asegurate de copiar todos los parametros correctamente y recuerda que luego de un not-authorized debes rehacer la contraseña (solo tenes un intento).
2- Que colocaste una contraseña en el WART para conseguir la clave pero luego de eso no seguiste usando la misma (en el WART) por lo que la contraseña para el Whatsapi esta mal cifrada.
Solucion: recuerda la contraseña con la que cifraste en el WART o perdiste la cuenta.
3- Que tu cuenta de Whatsapp este bloqueada por Spam u otra razon.
Este no tiene solucion.
GRACIAS POR LEER!!!
no puedo bajar el archivo WART, lo puedes volver a subir
tienes el proyecto compilado. esta en c# . Necesito agregar a un proyecto el envio de whatsapp.
Buenas tardes,
Primero que nada excelente aportacion es justo lo que necesito para mejorar un sistema que estoy desarrollando, descargue la WhatsAppApi.dll, y la agregue como referencia a mi proyecto, tambien logre obtener mi password con el WART, pero al momento de compilar me aparece el siguiente error:
The currently targeted framework ".NETFramework,Version=v4.0,Profile=Client" does not include "System.Web.Extensions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" which the referenced assembly "WhatsAppApi" depends on. This caused the referenced assembly to not resolve. To fix this, either (1) change the targeted framework for this project, or (2) remove the referenced assembly from the project.
estoy trabajando en vb.net 2013, alguna sugerencia de que es lo que debo hacer para lograr compilarlo correctamente?
Gracias :-[
Cita de: Sawaa en 24 Abril 2015, 22:59 PMThe currently targeted framework ".NETFramework,Version=v4.0,Profile=Client" does not include "System.Web.Extensions ...
Estás utilizando un Framework compactado (el perfil cliente) el cual carece de varios componentes de .Net Framework, en lugar de eso, utiliza el paquete completo (".Net Framework 4.0") o bien puedes referenciar al proyecto el ensamblado que te está indicando,
System.Web.Extensions.dll y automaticamente se corregirá mosntrándote una advertencia para cambiar que cambiará el Framework objetivo del proyecto.
➢
How to: Add or Remove References By Using the Reference Manager - MSDN (https://msdn.microsoft.com/en-us/library/hh708954.aspx)
Si no tienes el paquete normal de .Net Framework 4.0 instalado en tu equipo entonces debes instalarlo.
➢
https://www.microsoft.com/en-us/download/details.aspx?id=17718Cita de: Sawaa en 24 Abril 2015, 22:59 PMalguna sugerencia de que es lo que debo hacer para lograr compilarlo correctamente?
Aparte de corregir ese error de compilación, puedes leer las páginas de este mismo hilo, justo aquí:
http://foro.elhacker.net/net/vbnet_porteo_de_la_implementacion_del_api_de_whatsapinet_whatsapp_whatsappapi-t419188.0.html;msg1998950#msg1998950
Saludos
Gracias, agregue la referencia desde la opcion de assemblies y con eso ya no me marca ese error, pero ahora tengo un error con el nextChallenge
me aparece lo siguiente:
An unhandled exception of type 'System.FormatException' occurred in mscorlib.dll
Additional information: Invalid length for a Base-64 char array or string.
en el codigo:
Me.wa.Login(nextChallenge)
saludos
Estimados, me da la impresión que esto no funciona, lo intente de muchas maneras, cambiando los números de celular de diferentes compañías y nunca me a generado el archivo con extensión .next.dat, a alguien le a funcionado?
Saludos
HOLA!!!
CAM1207, el presente codigo funciona correctamentem la extension next.dat es correcta, acabo de intentar bajar nuevamente los proyectos de WhatsapiNET y el proyecto se dio de baja hace 3 dias a mi pesar.
En mi caso funciona por que el software con el que uso lo tengo desde este post, whatsapp por lo que veo rechaza la autenticacion de nuevos numeros por que considera que utilizamos una version vieja (esto lo se por que a partir de tantas inquietudes utilice otro numero que tenia por ahi).
Ahora, de todos los que estuvieron teniendo errores, ninguno leyo el return de login! o son todos script kiddies o no prestan atencion a lo que usan, el error era claro On Login Failed "not-authorized@old-version".
Voy a buscar otra manera de realizarlo, denme tiempo (1 mes), si no contesto en este post antes, contesten asi me recuerdan, pero sepan que encontrare la forma de hacer funcionar nuevamente WhatsApp en net
GRACIAS POR LEER!!!
Gracias 79137913, para mi este es el post l mas interesante de toda la red en estos momentos, claro si funcionara.
Saludos cordiales
Chicos el error que les parace de old version es por la version del WART que estan utilizando, intente al principio con la 1.7.3 pero hace un mes salio una nueva version la 1.8.1, con esa version si permite registrar y devuelve el pasword de manera correcta (lo intente ayer mismo), les dejo el link donde lo pueden descargar:
https://github.com/mgp25/WART/.
como nota algunos antivirus lo marcan como virus tendran que desactivarlo en lo que lo descargan
Ahora una pregunta ya tengo mi password pero me marca un error al enviar el mensaje, en
Private Sub WA_OnLoginFailed(ByVal data As String) _
Handles wa.OnLoginFailed
Throw New WALoginFailedException
End Sub
Me indica que el Login es fallido, necesito poner en el nickname el numero? o cualquier nickname basta?
Saludos!
Buen día. Cómo va este proyecto?, ante todo gracias por compartir. Me bajé el WART desde la página de github y me dio contraseña, pero al colocarla incluso manualmente WAPass="MiContraseña" me sale como "not-autorized" el login. Alguien lo ha podido solucionar?
Cita de: rogi en 5 Octubre 2015, 23:39 PM
Buen día. Cómo va este proyecto?, ante todo gracias por compartir. Me bajé el WART desde la página de github y me dio contraseña, pero al colocarla incluso manualmente WAPass="MiContraseña" me sale como "not-autorized" el login. Alguien lo ha podido solucionar?
Alguien sabe si aún funciona esto?, estaba con la idea de un proyectico en vb.net 2013 pero la verdad que ahora ni siquiera me funciona el WART me dice que OLD VERSION, no entiendo, hasta el momento que publiqué el mensaje anterior funcionaba dando contraseña pero ya no. Ya probé con otro nro de celular virgen y no.
HOLA!!!
He estado haciendo los testeos pertinentes y whatsapp ha tirado abajo la compatibilidad de esta api, el core de la misma ha sido descontinuado. Ahora mismo hay otras apis fucionando pero lamentablemente no para VB.NET o C#, ademas que las que funcionan los numeros utilizados son bloqueados por varias razones luego de un tiempo aleatorio, por lo cual no son nada confiables.
Recomendaria a los moderadores bloquear el tema, y a los interesados ingresar en https://github.com/fermino/WhatsBot que es uno de los que mantiene a tiro la implementacion.
GRACIAS POR LEER!!!
Hola @79137913
Qué APIs están funcionando?, deseo intentarlo dado que mi deseo no es generar spam sino hacer un sistema de consultas por tal razón las personas deben registrar el número que yo asigne para que se les envíe las respuestas. Gracias.
HOLA!!!
@rogi , Apis para net ninguna que yo sepa, la unica que es estable y funcional es la que linkee en mi ultimo post es para php, lo podes correr local en la pc y establecer una conexión por sockets para comunicar tu soft con el WhatsBot
GRACIAS POR LEER!!!
por lo que leo ya no es funcional??
en el código me da un error en
Public Sub ProcessChatAsync()
'Task.Factory.StartNew(Sub() Me.ProcessChat(Me.wa))
Task.Factory.StartNew(Sub()
Me.ProcessChat(Me.wa)
End Sub)
End Sub
======================
Error 1 Error de resolución de sobrecarga porque ninguna de las funciones 'StartNew' a las que se tiene acceso se puede llamar con estos argumentos:
'Public Function StartNew(Of TResult)(function As System.Func(Of TResult)) As System.Threading.Tasks.Task(Of TResult)': Demasiados argumentos para 'Public Sub ProcessChat()'.
'Public Function StartNew(Of TResult)(function As System.Func(Of TResult)) As System.Threading.Tasks.Task(Of TResult)': Los tipos de datos de los parámetros de tipo no se pueden inferir de estos argumentos. Este error se puede resolver especificando los tipos de datos explícitamente.
'Public Function StartNew(action As System.Action) As System.Threading.Tasks.Task': Demasiados argumentos para 'Public Sub ProcessChat()'. C:\Users\Fabio2\Documents\Visual Studio 2010\Projects\WhatsAppMessanger\WhatsAppMessanger\mWhatsApp.vb 258 9 WhatsAppMessanger
Cita de: ghosy86 en 9 Octubre 2015, 05:16 AM
por lo que leo ya no es funcional??
en el código me da un error en
Public Sub ProcessChatAsync()
'Task.Factory.StartNew(Sub() Me.ProcessChat(Me.wa))
Task.Factory.StartNew(Sub()
Me.ProcessChat(Me.wa)
End Sub)
End Sub
======================
Error 1 Error de resolución de sobrecarga porque ninguna de las funciones 'StartNew' a las que se tiene acceso se puede llamar con estos argumentos:
'Public Function StartNew(Of TResult)(function As System.Func(Of TResult)) As System.Threading.Tasks.Task(Of TResult)': Demasiados argumentos para 'Public Sub ProcessChat()'.
'Public Function StartNew(Of TResult)(function As System.Func(Of TResult)) As System.Threading.Tasks.Task(Of TResult)': Los tipos de datos de los parámetros de tipo no se pueden inferir de estos argumentos. Este error se puede resolver especificando los tipos de datos explícitamente.
'Public Function StartNew(action As System.Action) As System.Threading.Tasks.Task': Demasiados argumentos para 'Public Sub ProcessChat()'. C:\Users\Fabio2\Documents\Visual Studio 2010\Projects\WhatsAppMessanger\WhatsAppMessanger\mWhatsApp.vb 258 9 WhatsAppMessanger
ya no funciona, murió. :(
Hola me sale este error
Excepción no controlada del tipo 'System.Exception' en WhatsAppApi.dll
Información adicional: Auth response error
al final del codigo
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)
alguien me ayuda faltA Muy poco!
whatsapp ha hecho muchos cambios desde esa epoca y el proyecto de la dll está abandonado, ergo, este proyecto no es funcional actualmente
a menos que se hagan las actualizaciones para que funcione, queda cerrado