Como crear e implementar una interfaz en C#



El día de hoy les compartiré un concepto muy interesante y se trata nada mas y nada menos que de las interfaces en C#, por lo cual comenzaremos con su concepto y pasaremos a un sencillo ejemplo:

Hablando en llano, una interfaz no es más que una estructura de datos que muestra únicamente las firmas de los métodos de una clase. A partir de ahí, una clase que herede de la interfaz estará obligada a “rellenar” la implementación de dichos métodos. De forma simple, una interfaz sería algo así:



   interface IPruebaInterfaz
    {
        void MetodoHola();
    }


Esta interfaz únicamente dice QUÉ acciones se van a realizar, pero no CÓMO se realizarán. Para saber cómo realizarlas, crearemos clases que implementen esta interfaz, obligando a “rellenar” el contenido de los métodos que declaramos previamente.

Primero definimos la interfaz:
   interface IPruebaInterfaz
    {
        void MetodoHola();
    }

La clase anterior muestra una interfaz con el método “MetodoHola” el cual aun no esta implementado, el paso siguiente sera definir la clase que implemente dicho método:
   class ClaseImplementa : IPruebaInterfaz
    {
        void IPruebaInterfaz.MetodoHola()
        {
            Console.WriteLine("Hola TheCodingCookBook!!!");
        }
    }


Finalmente para ocupar nuestra interfaz, definimos una instancia de la misma e invocamos al método.
   static void Principal()
        {
            IPruebaInterfaz obj = new ClaseImplementa();

            obj.MetodoHola();
        }


Y esta una forma simple de definir una interfaz
Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...

Que es asterisk y con que se come?



Curso de asterisk y .NET C#

Queridos csharpedianos, estamos aquí reunidos para ser testigos de la integración de .NET en su máximo esplendor con LINUX, en algunas épocas esto parecería imposible, pero hoy comenzaremos una travesía que terminara en un software capaz de acceder a un equipo LINUX y realizar modificaciones en nuestro sistema de comunicaciones personal. Para esto es indispensable que aprendamos primeramente que es asterisk, para que lo usaremos, en que nos ayudara y con que nos lo comemos, aquí vamos:


Asterisk, es una plataforma de tecnología de código abierto y gratuito que puede convertir tu casi obsoleto pc en un sistema de comunicaciones VoIP que te permitirá desde intercomunicar por extensiones los cuartos de tu casa, hasta crear complejos sistemas de marcadores automáticos con Text To Speech e IVR Transaccionales.

Asterisk es básicamente un programa que trabaja bajo linux CENTOS el cual proporciona funcionalidades de central telefónica (PBX), se puede conectar a teléfonos para hacer llamadas entre si y hacer llamadas externas, recibir llamadas, conectar softphones, contestar llamadas, crear IVR, y todo lo que se te pueda ocurrir con una centralita telefonica.

No les hablare acerca de la historia de asterisk ya que para ser sinceros en este curso eso no nos importa en lo absoluto, seremos prácticos para hacer el curso lo mas entendible posible y que podamos sentar las bases para crear nuestro propio sistema de comunicación.

Antes de comenzar necesitaremos descargar la imagen de Linux, para asterisk debemos usar CentOS, la versión con la que trabajaremos aquí sera la 7. La imagen de linux CentOS 7 la puede descargar desde la web oficial.

La instalacion de CentOS escapa de los fines de este curso. Pero hare un tutorial de como instalarlo.













Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...

Crear Extensiones para chrome con bootstrap y HTML



Bienvenidos nuevamente, he estado un poco ausente (Esta bien, bastante ausente) del blog por temas laborales y personales pero hoy es un día glorioso para escribir un nuevo articulo y que se unan algunas neuronas para formar nuevo conocimiento, y que mejor forma de retomar el blog que con nuestro gran amigo google Chrome, y es que hoy aprenderemos a crear extensiones para chrome con HTML, BOOTSTRAP, JQUERY Y CSS.

Hay varios puntos que debemos seguir para crear estas extensiones, tratare de ser breve y que podamos lograr nuestro objetivo, el ejemplo que plateo es crear una barra de búsqueda, que al escribir algo, abra una pestaña nueva con la búsqueda en nuestro glorioso blog de C# AL EXTREMO. Es algo muy simple a nuestro parecer pero sentara las bases para que puedas hacer lo que quieras con estas extensiones.

Cabe mencionar que puedes usar el editor de código que quieras, desde notepad hasta visual estudio si te apetece. Ahora sin mas chachara y sin mas cuento, comencemos:

  1.  Comenzaremos creando una carpeta en la que guardaremos los archivos de nuestra extensión y el primer archivo que guardaremos sera uno llamado manifest.json, el cual crearemos y le agregaremos el siguiente código:  

    {
    
      "manifest_version": 2,
    
      "name": "Búsqueda en C# AL EXTREMO",
    
      "short_name": "Busquedacsharpalextremo",
    
      "description": "Most",
    
      "version": "0.0.1",
    
      "minimum_chrome_version": "38",
    
      "permissions": ["topSites"],
    
      "browser_action": {
    
        "default_icon": "icon.png",
    
        "default_popup": "popup.html"
    
      },
    
      "content_scripts": [
    
        {
    
          "matches": ["<all_urls>"],
    
          "css": ["assets/bootstrap.min.css"],
    
          "js": ["assets/jquery.js", "main.js"],
    
          "run_at": "document_start"
    
        }
    
      ]
    
    }
    

    Vale recalcar que la información que se ingresa aquí es muy sencilla, tales como el nombre, la versión de la extensión y la mínima versión del chrome. En nuestra carpeta también debemos agregar el icono que usara nuestra extensión, este debe ser de 19px X 19px y es el que llamaremos icon.png. El resto de información agréguenla tal cual esta en el ejemplo y luego iremos desenmarañando el archivo.
  2. POPUP: Ahora explicaremos esta session del manifest, y es la que se encarga de que salga una ventana emergente al presionar click sobre la extension:

    "browser_action": {
    
        "default_icon": "icon.png",
    
        "default_popup": "popup.html"
    
      },


    Crearemos un archivo llamado popup.html y pegaremos el siguiente fragmento de código:

     <!doctype html>
    <html>
    <head>
        <title>Buscar en c sharp al extremo</title>
        <link rel="stylesheet" href="assets/bootstrap.min.css">
        <link href='https://fonts.googleapis.com/css?family=Lato' rel='stylesheet' type='text/css'>
        <script src="assets/jquery.js"></script>
        <script src="main.js"></script>
    
        <style>
            body {
                overflow: hidden;
                margin: 0px;
                padding: 0px;
                width: 400px;
                height: 35px;
            }
    
            .body {
                padding: 15px;
            }
    
            .footer {
                background-color: #f0f0f0;
                color: #636363;
                font-size: 13px;
                margin-top: 9px;
                padding: 10px;
                text-align: center;
            }
    
                .footer img {
                    margin-right: 20px;
                    width: 90px;
                    text-align: left;
                }
        </style>
    </head>
    <body>
        <div class="row body">
            <div class="col-lg-12">
                <div class="input-group">
                    <input type="text" id="txtbuscar" class="form-control" placeholder="Buscar">
                    <span class="input-group-btn">
                        <button id="btnbuscar" class="btn btn-primary" type="button">Buscar</button>
                    </span>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-lg-12 footer">
                <img src="logo.png" />
                <small><a href="http://csharpalextremo.blogspot.com.co" target"_blank">http://csharpalextremo.blogspot.com.co</a></small>
            </div>
        </div>
    </body>
    </html>
    
    
  3. Crearemos una carpeta llamada assets en la que estaran nuestros archivos js y css, dentro de esta carpeta guardaremos el archivo css de bootstrap y el js de jquery, los cuales encontraran dentro de los archivos de ejemplo de este proyecto.

    En la carpeta raiz, crearemos un archivo llamda main.js y pegaremos el siguiente fragmento de codigo

    $(document).ready(function(){
    
      $("#txtbuscar").focus();
     
     $('#txtbuscar').keyup(function(e){
        if(e.keyCode == 13)
        {
       $("#btnbuscar").click();       
        }
    }); 
     $("#btnbuscar").click(function(){
        var search = $("#txtbuscar").val();
       chrome.tabs.create({ url: "http://csharpalextremo.blogspot.com.co/search?q="+search  });  
     }); 
    
    }); 
    


    Instalemos la extensión en tu computador para verificar que todo va bien. Escribe en la barra de navegación chrome://extensions y si está inactivo, activa el modo programador del lado derecho de la página. Aparecerán inmediatamente abajo tres botones, haz clic en el primero Cargar extensión sin empaquetar y navega hasta seleccionar la carpeta donde tienes la extensión que estás desarrollando. Si lo has hecho bien, aparecerá en la parte superior de tu navegador el icono de tu extensión, el cual en estos momentos no hace función alguna.
  4. Publicar en la tienda de chrome store:
    Ahora que tenemos las bases de la aplicacion, seguramente quieres montarlo en la chrome store para que todos puedan descargarla, pues hagamoslo:

    Primero, escoge todos los archivos y comprímelos en un zip. Después, ingresa al Dashboard de Google Chrome y sigue los pasos para publicarla, si no te has registrado antes, te pedirá en este momento que lo hagas. Te pedirá información y unos screenshots de tu extensión para una mejor visualización a los usuario, es recomendable llenar toda la información y adjuntar todos los screenshot posibles, esto ayudara a raquear tu app y a que mas usuarios la descarguen. 

Ahora que has hecho esta sencilla aplicación para google chrome, puedes comenzar a explorar agregándole mas código al jquery o al html, puedes agregar los estilos que quieras y disfrutar las maravillas que te ofrece internet.
Recomiendo que recibes la documentación oficial de chrome store y que no le pongas limites a tu imaginación ;).

A continuación les dejo el videotutorial, suscribanse al canal para recibir mas contenido como este:



Si quieres consultar el codigo, puedes descargar todo el html, css, js y todo el fuente usado en este proyecto desde aqui:

Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...

Guardar y obtener Texto dentro de imagen como propiedad


Criptografia con C# - Guardar y obtener Texto dentro de imagen como propiedad

Hoy les traigo dos funciones interesantes, que les servira mucho a aquellos que trabajan mucho con procesamiento de imagenes (jpg;jpeg;png;bmp;etc), sobre todo cuando necesitamos guardar descripciones o comentarios para cada imagen que queremos procesar.

Imaginense que tenemos una pagina web que ofrece productos y tenemos imagenes para cada uno de los productos, realizar rutinas que guarden la descripcion para cada imagen de cada producto nos puede acarrear mucho trabajo, sobre todo al momento de crear la logica para que se guarde en la base de datos y luego para leer cada registro y relacionarlo con cada una de las imagenes.

Pues bien, les traigo una solución fácil y practica con la que nos  evitaremos horas de desarrollo y consiste en guardar la descripción de cada imagen dentro de la misma imagen como un metatag o mas bien una propiedad.

El enlace para descargar el código de ejemplo, se encuentra al final del post.

Con este primer método puedes agregarle la descripción a una imagen creando una propiedad con la información deseada:
        
        ///         
        /// Método usado para entrar a las propiedades de una imagen 
        /// y crear una nueva propiedad con información personalizada
        ///         /// 
        /// 
        private void SetDescription(Image Pic, string NewDescription)
        {
            byte[] bDescription = new Byte[NewDescription.Length];

            // Se copia la descripcion dentro de un byte array
            for (int i = 0; i < NewDescription.Length; i++) bDescription[i] = (byte)NewDescription[i];

            //Descomentar para cargar la imgen como stream
            //System.Drawing.Image Pic = Image.FromStream(Filename);

            //Descomentar la siguiente linea si se desea trabajar con rutas de archivos
            // System.Drawing.Image Pic = Image.FromFile(Filename);

            //Si la imagen ya tiene la propiedad con el id especificado, se elimina esta propiedad de la imagen 
            //para crearla nuevamente
            if (Pic.PropertyItems.Any(p => p.Id == NuevaPropiedad)) Pic.RemovePropertyItem(NuevaPropiedad);

            //Se genera la nueva propiedad
            PropertyItem PropertyItems = (PropertyItem)FormatterServices.GetUninitializedObject(typeof(PropertyItem));
           
           //0815 es el código de la nueva propiedad, puedes usar cualquiera 
            //siempre y cuando la imagen no tenga otra propiedad con ese código
            PropertyItems.Id = 0815;
            PropertyItems.Type = 2;
            PropertyItems.Len = bDescription.Length;
            PropertyItems.Value = bDescription;
            Pic.SetPropertyItem(PropertyItems);

            NombreImagen = Guid.NewGuid().ToString() + Ext;
            Pic.Save(NombreImagen, ImageFormat.Jpeg);

            //pbload es el nombre de un picture box que tengo en la aplicación, 
           //al que le voy a asignar la imagen para mostrarla
            pbload.Image = Image.FromFile(NombreImagen);
            pbload.SizeMode = PictureBoxSizeMode.StretchImage;

            //Limpio los recursos usados
            Pic.Dispose();
            Pic = null;
        }


Este otro método, obtiene el texto guardado en la imagen:
        
        /// 
        /// Metodo usado para leer cualquier propiedad de una imagen
        /// 
        /// 
        /// 
        static public string GetDescription(Image img)
        {
            string text = string.Empty;
            System.Text.ASCIIEncoding encoding = new System.Text.ASCIIEncoding();

            try
            {
                //Descomentar esta linea si se desea cargar la imagen por medio de path
                //System.Drawing.Image img = new System.Drawing.Bitmap(ImgPath);

                //Se lee la propiedad donde se almaceno la informacion. 0815 es el identificador que le asignamos a la propiedad
                PropertyItem item = img.GetPropertyItem(0815);

                //Se lee el valor y se almacena en una variable para ser devuelto.
                text = encoding.GetString(item.Value);

                //Se liberan los recursos usados.
                img.Dispose();
                GC.SuppressFinalize(img);

                return text;
            }
            catch { return ""; }
        }


Muy pronto agregare el ejemplo de un proyecto detallado junto con un vídeo de explicación: Esperenlo...

Por ahora, les dejo el código de un ejemplo: Descargarlo aqui

Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...

Curso asterisk con .NET



En estos tiempos donde la comunicación y las telecomunicaciones hacen parte de nuestro diario vivir, es importante que como desarrolladores nos vallamos de frente hacia estos campos.

En ocasiones al ser desarrollador .NET nos enfocamos en solo estas tecnologías y dejamos de lado cualquier cosa que no haga parte del universo microsoft, pero hoy les traigo algo divertido, donde converge el universo pago de microsoft y .NET con lo libre, gratuito y mágico de Linux.

Se trata de unir C# con Asterisk para crear un marcador que desde windows pueda llamar a través de CentOS y Asterisk a cualquier numero.

Los temas de este pequeño pero sustancioso curso son:
  1. Que es asterisk y con que se come?
  2. Montar y configurar servidor con asterisk y CentOS 1
  3. Montar y configurar servidor con asterisk y CentOS 2
  4. Configurar Manager de asterisk
  5. Conectando asterisk con C#

En este curso, aprenderemos como montar y configurar un servidor Asterisk en CentOS 7 para luego conectarnos desde C# y desde aquí poder ejecutar comandos o hacer llamadas en Aterisk.

Semanalmente se subirá una nueva publicación de este super curso! Manténganse atentos y cualquier inquietud, no duden en comentarla!


Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...

Hora Militar o Formato 24 Horas en SQL SERVER


Es curioso los problemas que nos encontramos a diario al desarrollar, siempre resulta que hay algo nuevo y algo que no sabemos, aprendemos día a día con cada cosa que hacemos, y cada código que escribimos.
El día de hoy les traigo una instrucción que si bien es muy sencilla, puede ahorrarnos varias horas de búsqueda infructuosa en san google. Se trata de convertir una hora en sql server al formato militar o formato de 24 horas.
Para esto tenemos varias formas:


SELECT CONVERT(VARCHAR(8), dateadd(HOUR,12, cast('2017-01-01 10:15:00' as datetime)), 108) 
AS HoraMilitar

Veamos lo que se hace en la instrucción anterior:

Tenemos la fecha y hora: 2017-01-01 10:15:00 la cual convertimos a datetime cast('2017-01-01 10:15:00' as datetime) luego le sumamos 12 horas para ejemplificar el ejercicio "dateadd(HOUR,12," y por ultimo pasamos a varchar para darle formato militar

CONVERT(VARCHAR(8), "Aquí la fecha",108)

Notese que uso el código 108 de conversión, este le indica al motor de base de datos que queremos la hora militar.

Otra forma mas sencilla es convirtiendo a datetime la fecha y hora agregandole AM/PM segun el formato que necesitemos:

SELECT  cast('2017-01-01 10:15:00PM' as datetime) AS HoraMilitar


La diferencia radica en el resultado devuelto, mientras que el primer ejemplo, nos devuelve solo el formato fecha: 22:15:00 el segundo ejemplo nos devuelve el formato completo: 2017-01-01 22:15:00.000

Si tienen una forma mas sencilla o simplemente quieren expresar su opinión, por favor dejen sus comentarios!


Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...

Goto Inicio



He estado un poco ausente del blog (Bueno en verdad mucho) pero ya es momento de ponernos al día con todas las nuevas tecnologías que han aparecido y que se están convirtiendo poco a poco en el diario vivir de los que estamos inmersos en este mundo del desarrollo y la programación, incluso aquellos que están aprendiendo y quieren llegar mas allá.
Espero que dejen sus comentarios y nos indiquen que les gustaría escribir, recibimos sus códigos y posts para publicarlos!!
Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...

Desencriptar cadena de texto con C#

Podemos desencriptar cualquier cadena de texto con C# en base a una key de encriptación. El siguiente código espera un parámetro texto del que queremos desencriptar, la key secreta de encriptación, y el CyphMode).

Podemos desencriptar cualquier cadena de texto con C# en base a una key de encriptación. El siguiente código espera un parámetro texto del que queremos desencriptar, la key secreta de encriptación, y el CyphMode).

La función devolverá el valor desencriptado. Nos puede venir bien si queremos desencriptar id's de valores, por ejemplo...


public static string Decrypt(string p_InputString, string p_SecretKey, CipherMode p_CyphMode)

{

 if (String.IsNullOrEmpty(p_InputString)) {

  return String.Empty;

 } else {

  StringBuilder ret = new StringBuilder();

  byte[] InputbyteArray = new byte[Convert.ToInt32(p_InputString.Length) / 2];

  TripleDESCryptoServiceProvider Des = new TripleDESCryptoServiceProvider();

  MD5CryptoServiceProvider hashMD5 = new MD5CryptoServiceProvider();


  try {

   Des.Key = hashMD5.ComputeHash(ASCIIEncoding.ASCII.GetBytes(p_SecretKey));

   Des.Mode = p_CyphMode;

   for (int X = 0; X <;= InputbyteArray.Length - 1; X++) {

    Int32 IJ = (Convert.ToInt32(p_InputString.Substring(X * 2, 2), 16));

    ByteConverter BT = new ByteConverter();

    InputbyteArray[X] = new byte();

    InputbyteArray[X] = Convert.ToByte(BT.ConvertTo(IJ, typeof(byte)));

   }


   MemoryStream ms = new MemoryStream();

   CryptoStream cs = new CryptoStream(ms, Des.CreateDecryptor(), CryptoStreamMode.Write);


   //Flush the data through the crypto stream into the memory stream

   cs.Write(InputbyteArray, 0, InputbyteArray.Length);

   cs.FlushFinalBlock();


   //Get the decrypted data back from the memory stream

   byte[] B = ms.ToArray();

   ms.Close();

   for (int I = 0; I <;= B.GetUpperBound(0); I++) {

    ret.Append(Convert.ToChar(B[I]));

   }

  } catch (Exception ex) {

   //   ME.Publish("SF.Utils.Utils", "DecryptString", ex, ManageException_Enumerators.ErrorLevel.FatalError);

   return String.Empty;

  }


  return ret.ToString();

 }

}


Espero que lo disfruten, compartan y comenten. ;)

"Si se puede imaginar... se puede programar."
Leer más...
Google