data:image/s3,"s3://crabby-images/b1102/b11021470be53a22bd63baa007475d93e3335885" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 1 RECIBIR MENSAJES WA C"
Recibir mensajes con Api Oficial de WhatsApp en C#
En este tutorial aprenderemos a Recibir mensajes con Api Oficial de WhatsApp en C#, solo debemos seguir estos pasos:
Creamos una app en Facebook
data:image/s3,"s3://crabby-images/d424a/d424a71629775bd123e3972b3f2667bef54253fb" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 2 Enviar mensajes con Api Oficial de WhatsApp en PHP"
O podemos aceder a este link Todas las apps – Meta for Developers (facebook.com)
data:image/s3,"s3://crabby-images/7db50/7db504afb90b97d5d3bfbbc4294d51a1cf256f35" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 3 image 31"
data:image/s3,"s3://crabby-images/755d2/755d215918da71f341609dcedd721f1473ccf197" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 4 image 32"
data:image/s3,"s3://crabby-images/0c115/0c115cfb0b22451a9159f6dcd8ae415f24e0e82b" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 5 image 33"
data:image/s3,"s3://crabby-images/0a32d/0a32d9f3e3b276871e460c5544b07bb5302a8fc5" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 6 image 34"
data:image/s3,"s3://crabby-images/3cc7e/3cc7ef4d5f44521248466ecaf237624705539af4" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 7 image 35"
Configuramos el Api de WhatsApp
data:image/s3,"s3://crabby-images/98216/982160fb918360610d41946be723277cc4204c0c" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 8 image 36"
data:image/s3,"s3://crabby-images/89f6e/89f6eafbc05e724c37eb2cd9d2a446b38b572093" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 9 image 37"
data:image/s3,"s3://crabby-images/1215b/1215bbc80463e80d8f90afe91dec3e8f01172d7b" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 10 image 38"
data:image/s3,"s3://crabby-images/7f3a5/7f3a5d8999833a79aed4776aa06748698a30b0e0" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 11 image 49"
data:image/s3,"s3://crabby-images/7cc43/7cc43637663a4a00179426746187c202e5c7ee2a" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 12 image 39"
data:image/s3,"s3://crabby-images/b3901/b3901a36aba7775cfc84cb83fc7e8195b7b63a6a" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 13 image 40"
Recibir mensajes con Api Oficial de WhatsApp en C#
data:image/s3,"s3://crabby-images/387f8/387f806366c7ea2998bd36c57241d7e43df00844" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 14 image"
data:image/s3,"s3://crabby-images/57bc2/57bc2e7bb7badcbe42700ebda7583f42f68e5dfa" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 15 image 1"
data:image/s3,"s3://crabby-images/1784a/1784af311c7b3e2ca1232a83b65cac2bfd3da965" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 16 image 2"
data:image/s3,"s3://crabby-images/8284e/8284e6636e7e806e1a2099961183df76507e95b7" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 17 image 4"
data:image/s3,"s3://crabby-images/cd7fa/cd7fa85cf38860dd7119a36e0cfc273c1c5dcdbd" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 18 image 12"
//ClienteControl.cs using Microsoft.AspNetCore.Mvc; using System.Net; using System.Net.Http.Headers; using WebApiWA.Models; namespace WebApiWA.Controllers { public class ClienteControl:ControllerBase { //RECIBIMOS LOS DATOS DE VALIDACION VIA GET [HttpGet] //DENTRO DE LA RUTA webhook [Route("webhook")] //RECIBIMOS LOS PARAMETROS QUE NOS ENVIA WHATSAPP PARA VALIDAR NUESTRA URL public string Webhook( [FromQuery(Name = "hub.mode")] string mode, [FromQuery(Name = "hub.challenge")] string challenge, [FromQuery(Name = "hub.verify_token")] string verify_token ) { //SI EL TOKEN ES hola (O EL QUE COLOQUEMOS EN FACEBOOK) if (verify_token.Equals("hola")) { return challenge; } else { return ""; } } //RECIBIMOS LOS DATOS DE VIA POST [HttpPost] //DENTRO DE LA RUTA webhook [Route("webhook")] //RECIBIMOS LOS DATOS Y LOS GUARDAMOS EN EL MODELO WebHookResponseModel public dynamic datos([FromBody] WebHookResponseModel entry) { //ESTRAEMOS EL MENSAJE RECIBIDO string mensaje_recibido = entry.entry[0].changes[0].value.messages[0].text.body; //ESTRAEMOS EL ID UNICO DEL MENSAJE string id_wa = entry.entry[0].changes[0].value.messages[0].id; //ESTRAEMOS EL NUMERO DE TELEFONO DEL CUAL RECIBIMOS EL MENSAJE string telefono_wa = entry.entry[0].changes[0].value.messages[0].from; //INICIALIZAMOS LA CONEXION A LA BD Datos dat = new Datos(); //INSERTAMOS LOS DATOS RECIBIDOS dat.insertar(mensaje_recibido, id_wa, telefono_wa); //SI NO HAY ERROR RETORNAMOS UN OK var response = new HttpResponseMessage(HttpStatusCode.OK); response.Content.Headers.ContentType = new MediaTypeHeaderValue("text/plain"); return response; } } }
data:image/s3,"s3://crabby-images/e5e5b/e5e5bcc5509767654c32a106f7535009b7608fa6" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 19 image 6"
data:image/s3,"s3://crabby-images/1a440/1a440c5e5c289545d3f9267eb8ac06a412e51a46" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 20 image 7"
data:image/s3,"s3://crabby-images/26d2b/26d2bd44dd82638bc53364a58e5191ed7647ad3b" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 21 image 8"
//Recibir mensajes con Api Oficial de WhatsApp en C# namespace WebApiWA.Models { using MySqlConnector; public class Datos { public void insertar(string mensaje_recibido, string id_wa, string telefono_wa) { var connection = new MySqlConnection("Server=localhost;User ID=root;Password=;Database=aspwa"); try { var command = connection.CreateCommand(); command.CommandText = "INSERT INTO `registro` (`mensaje_recibido`, `id_wa`, `telefono_wa`) VALUES ('" + mensaje_recibido + "', '" + id_wa + "', '" + telefono_wa + "');"; connection.Open(); command.ExecuteNonQuery(); //return "Mitarbeiter wurde angelegt"; } catch (Exception ex) { //return ex.Message; } finally { connection.Close(); } } } public class WebHookResponseModel { public Entry[] entry { get; set; } } public class Entry { public Change[] changes { get; set; } } public class Change { public Value value { get; set; } } public class Value { public int ad_id { get; set; } public long form_id { get; set; } public long leadgen_id { get; set; } public int created_time { get; set; } public long page_id { get; set; } public int adgroup_id { get; set; } public Messages[] messages { get; set; } } public class Messages { public string id { get; set; } public string from { get; set; } public Text text { get; set; } } public class Text { public string body { get; set; } } }
data:image/s3,"s3://crabby-images/43b58/43b587e4afbe723051bee8ed9e530b2d2dedc5de" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 22 image 9"
data:image/s3,"s3://crabby-images/52b20/52b20f6383e15a37aabaea54ce10137df8ee7833" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 23 image 10"
data:image/s3,"s3://crabby-images/2de8f/2de8f12286682e2c552a2c47a6d53aa19aedfbb5" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 24 image 14"
NuGet Gallery | ApiAiSDK 1.6.5
NuGet Gallery | Microsoft.AspNet.WebHooks.Custom 1.2.2
NuGet Gallery | Microsoft.AspNet.WebHooks.Custom.Api 1.2.2
NuGet Gallery | Microsoft.AspNet.WebHooks.Custom.Mvc 1.2.2
NuGet Gallery | MySqlConnector 2.2.5
Creamos la bd en mysql
data:image/s3,"s3://crabby-images/83437/834378ba7c2dd2d2e88e0052a098a6fb58e4bf5b" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 25 image 11"
-- phpMyAdmin SQL Dump -- version 5.1.1 -- https://www.phpmyadmin.net/ -- -- Servidor: 127.0.0.1 -- Tiempo de generación: 03-03-2023 a las 11:32:44 -- Versión del servidor: 10.4.21-MariaDB -- Versión de PHP: 8.0.12 SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO"; START TRANSACTION; SET time_zone = "+00:00"; /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */; /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */; /*!40101 SET NAMES utf8mb4 */; -- -- Base de datos: `aspwa` -- CREATE DATABASE IF NOT EXISTS `aspwa` DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; USE `aspwa`; -- -------------------------------------------------------- -- -- Estructura de tabla para la tabla `registro` -- CREATE TABLE `registro` ( `id` int(5) NOT NULL, `fecha_hora` datetime DEFAULT current_timestamp(), `mensaje_recibido` varchar(1000) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT '', `id_wa` varchar(1000) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT '', `telefono_wa` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT '' ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- -- Índices para tablas volcadas -- -- -- Indices de la tabla `registro` -- ALTER TABLE `registro` ADD PRIMARY KEY (`id`); -- -- AUTO_INCREMENT de las tablas volcadas -- -- -- AUTO_INCREMENT de la tabla `registro` -- ALTER TABLE `registro` MODIFY `id` int(5) NOT NULL AUTO_INCREMENT; COMMIT; /*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
data:image/s3,"s3://crabby-images/d5a1b/d5a1b06c449990442b6308cabf10953fe68dac4c" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 26 image 15"
Activamos un servidor ngrok
data:image/s3,"s3://crabby-images/bbe48/bbe48767db33d3f27068e37fa9205a81f37b0e14" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 27 image 94"
data:image/s3,"s3://crabby-images/00aa9/00aa91d79fbebaa0fc1be5afe261b61911a1fd42" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 28 image 95"
data:image/s3,"s3://crabby-images/9c72c/9c72cff457d40c267614f30e28d21e32f4345214" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 29 image 97"
data:image/s3,"s3://crabby-images/37a55/37a5556decd91569d52013261bd129bb59474d73" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 30 image 60"
data:image/s3,"s3://crabby-images/7e9ed/7e9edaa693dbf49f318650d2ce4197f0fd0329a0" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 31 Recibir mensajes con Api Oficial de WhatsApp en C#"
data:image/s3,"s3://crabby-images/6610f/6610ff6f10ae9347608529b1843cd58c26761cd0" alt="Recibir mensajes con Api Oficial de WhatsApp en C# 32 image 16"