Cómo crear un identificador de teléfonos móviles


¿Cuántas veces nos hemos encontrado con la siguiente situación?:
Nuestro plan de telefonía móvil nos entrega X cantidad de minutos a la Compañía 1, Y cantidad de minutos a la Compañía 2 y Z cantidad de minutos a la compañía 3. Agotamos una de las opciones y necesitamos hacer una llamada urgente, pero empezamos a pensar ¿Y si es de los minutos que ya no me quedan? Me cobrarán extra o no podré hacer la llamada. Y ante la duda, una oportunidad pasa.
Hoy en Internet es posible encontrar algunas aplicaciones que nos permiten reconocer la compañía a la que pertenece un número móvil. Sin embargo, algunas de ellas presentan requisitos específicos o son de licencia comercial, lo que no las hace accesibles para cualquier persona.
Pero que no panda el cúnico amigos nuestros, que hoy en CLH, mediante un realmente simple y rápido tutorial (siempre lo decimos, pero este en verdad es muy simple), les enseñaremos a construir un identificador de teléfonos móviles de forma gratuita y en la comodidad de su hogar.
¿Qué hacer? Solo seguirnos después del salto :)

Cómo crear un identificador de teléfonos móviles

Detalles del tutorial

  • Tiempo aproximado de implementación: 30 minutos.
  • Dificultad: Básico.

toolsImplementos necesarios:

  • Un servidor Web que ejecute archivos PHP y un sistema de gestión de bases de datos MySQL (Recomendamos XAMPP).
  • La base de numeración telefónica móvil publicada por la Subtel. Pueden descargarla en formato PDF desde el siguiente enlace.
  • Un editor para la codificación (Recomendamos Notepad++).
Notas sobre el proceso:
Probablemente en este punto se preguntarán: ¿Cómo funciona esto? Bastante sencillo. La Subsecretaría de Telecomunicaciones en Chile define una serie de prefijos los cuales son asignados en rangos a las distintas compañías que entregan servicios de telefonía móvil. Estos prefijos están compuestos por 4 dígitos y van desde el 6200 hasta el 9999.
Ahora, ¿qué tienen que ver estos prefijos? Son ellos los que forman la primera mitad de nuestros números de teléfonos móviles. En consecuencia, cada prefijo tiene 4 dígitos más que forman un número único completo. Si nuestras matemáticas no fallan, podemos deducir que eso significa que existe un total de 9999 números de teléfonos móviles únicos por cada prefijo. Considerando que son 3799 prefijos en total, en Chile tenemos 37.986.201 posibles combinaciones de números.
¿Eso significa que eventualmente habrán 37 millones de celulares dando vuelta en el país?. Puede ser, pero de momento no, ya que como podrán fijarse en la base de numeración, hay prefijos asignados a compañías que actualmente no ofrecen servicios de telefonía móvil de libre acceso al público general… pero nunca se sabe. Adicionalmente, hay algunos rangos de prefijos que no están asignados, lo que deja un total 2620 prefijos y por ende 26.197.380 combinaciones. Pero eso es un dato anecdótico más que nada.
Con esa información, ya tenemos la lógica clara para realizar nuestra aplicación, así que manos a la obra.

Procedimiento:

1.- Lo primero que debemos hacer, y que es el paso más crítico, es transformar la base de numeración telefónica a un formato adecuado, ya que la que descargamos esta en formato PDF y no podremos acceder a ella de forma normal, así que nuestro objetivo es traspasarla a nuestra base de datos MySQL con el fin de poder consultarla mediante el script que desarrollaremos.
Para esto tenemos varias opciones:
  • Podemos copiar el contenido de la base y traspasarlo a una planilla Excel, en la cual debemos eliminar las XXXX que aparecen en el campo suscriptor y solo mantener el prefijo y en otra columna la compañía a la que pertenece ese prefijo. Adicionalmente, es bueno que al menos para las tres compañías más conocidas, cambiemos sus nombres completos o razones sociales a nombres más amigables y reconocibles para el usuario (por ej. ENTEL PCS TELECOMUNICACIONES S.A. a ENTEL PCS).
  • Una vez que tenemos nuestro Excel armado con el formato que queremos, lo traspasamos a MySQL. ¿Dudas sobre como hacerlo? No se preocupen, en el pasado hemos hecho un tutorial que cubre el proceso de forma completa.
Pero, equipo de CLH, este proceso es largo y tedioso, ¿pueden echarnos una mano por favor?. Bueno, bueno, pero solo porque lo pidieron por favor. Si hacen click en este enlace, pueden descargar la base de datos completa lista para importar a MySQL. Pero no le cuenten a nadie, ¿ya?.
El archivo que les dejamos es un fiel reflejo de la base de datos que creamos, llamada moviles, la cual tiene una tabla llamada numeracion. Esta a su vez tiene 2 campos: prefijo (INT) y empresa (TEXT). Más sencillo imposible.
2.- Ahora que hemos ordenado nuestros datos, podemos empezar a codificar lo que será nuestra pequeña aplicación. Para empezar, haremos un formulario el cual contendrá un campo de texto para que el usuario ingrese el número de teléfono móvil a consultar y un botón para enviar la consulta. Para esto, crearemos un archivo en formato PHP, llamado consulta.php, el cual contendrá además de lo anterior, un autollamado donde se ejecutará el script y consultaremos la base de datos. Pero primero, el formulario:
  1. <div id="formulario">
  2. <form name="formulario-consulta" id="formulario-consulta" action="consulta.php" method="post">
  3. <label for="numero">Ingrese el n&uacute;mero a consultar:</label>
  4. <input type="text" name="numero" id="numero" />
  5. <p><input type="submit" id="submit" name="submit"
  6. value="Consultar n&uacute;mero" />
  7. </form>
  8. </div>
3.- Luego de codificar nuestro formulario, procedemos a hacer el código PHP, el cual validará el número ingresado y luego hará cortará los primeros 4 caracteres de la cadena ingresada (para igualarlo al prefijo), hará la consulta en la base de datos y desplegará el resultado de acuerdo a lo que se obtenga:
  1. if($_POST) {
  2. if($_POST['numero'] == '') {
  3. $mensaje = "<span id='error'>Debe ingresar un n&uacute;mero para
  4. consultar.</span>";
  5. }
  6. else {
  7. if(!$conexion = mysqli_connect("localhost", "usuario", "clave", "bd")) {
  8. $mensaje = "<span id='error'>No se pudo conectar
  9. a la base de datos.</span>";
  10. }
  11. else {
  12. $numero = substr(trim($_POST['numero']), 0, 4);
  13. $consulta = "SELECT empresa FROM numeracion WHERE prefijo = ".$numero;
  14. if($resultado = mysqli_query($conexion, $consulta)) {
  15. if(mysqli_num_rows($resultado) == 0) {
  16. $mensaje = "<span id='error'>No hay coincidencias para el
  17. n&uacute;mero ".$_POST['numero'].".</span>";
  18. }
  19. else {
  20. $datos = mysqli_fetch_array($resultado, MYSQL_ASSOC);
  21. $mensaje = "<span id='exito'>El n&uacute;mero ".$_POST['numero']."
  22. pertenece a ".$datos['empresa']."</span>";
  23. }
  24. }
  25. else {
  26. $mensaje = "<span id='error'>Ocurri&oacute; un error al ejecutar
  27. la consulta. Int&eacute;ntelo nuevamente.</span>";
  28. }
  29. }
  30. }
  31. }
4.- El código en si es bastante autoexplicativo. Comprobamos primero si se enviaron datos, conectamos a la base de datos y ejecutamos la consulta. En cada paso creamos una variable llamada mensaje, la cual almacena información correspondiente al resultado de la operación. Este mensaje lo añadiremos al final del formulario para que le informe al usuario que sucedió:
  1. <div id="mensaje"><?php
  2. if(isset($mensaje)) {
  3. echo $mensaje;
  4. }
  5. ?></div>
5.- De forma opcional, si así lo deseamos, podemos estilizar un poco esta pequeña aplicación, creando un archivo estilos.css y añadiéndolo a la cabecera de consulta.php:
  1. #formulario {
  2. width: 450px;
  3. margin: 0 auto;
  4. font-family: Arial;
  5. font-size: 11px;
  6. border: solid 1px black;
  7. padding: 20px;
  8. background-color: #fac519;
  9. }
  10. #formulario-consulta {
  11. margin-left: 150px;
  12. }
  13. #submit {
  14. font-family: inherit;
  15. font-size: 11px;
  16. }
  17. label {
  18. display: block;
  19. }
  20. #mensaje {
  21. font-family: Arial;
  22. font-size: 11px;
  23. padding: 3px;
  24. border: 1px dashed black;
  25. }
  26. #exito {
  27. background-color: #6ad11b;
  28. }
  29. #error {
  30. background-color: #f51414;
  31. }
6.- Finalmente, nuestro consulta.php quedaría de la siguiente forma:
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
  5. <link rel="stylesheet" href="estilos.css" />
  6. <title>Identificador de tel&eacute;fonos m&oacute;viles</title>
  7. </head>
  8. <body>
  9. <?php
  10. if($_POST) {
  11. if(emptyempty($_POST['numero'])) {
  12. $mensaje = "<span id='error'>Debe ingresar un n&uacute;mero para consultar.</span>";
  13. }
  14. else {
  15. if(!$conexion = mysqli_connect("localhost", "root", "dumbass", "movil")){
  16. $mensaje = "<span id='error'>No se pudo conectar a la base de datos.</span>";
  17. }
  18. else {
  19. $numero = substr(trim($_POST['numero']), 0, 4);
  20. $consulta = "SELECT empresa FROM numeracion WHERE prefijo = ".$numero;
  21. if($resultado = mysqli_query($conexion, $consulta)) {
  22. if(mysqli_num_rows($resultado) == 0) {
  23. $mensaje = "<span id='error'>No hay coincidencias para el n&uacute;mero ".$_POST['numero'].".</span>";
  24. }
  25. else {
  26. $datos = mysqli_fetch_array($resultado, MYSQL_ASSOC);
  27. $mensaje = "<span id='exito'>El n&uacute;mero ".$_POST['numero']." pertenece a ".$datos['empresa']."</span>";
  28. }
  29. }
  30. else {
  31. $mensaje = "<span id='error'>Ocurri&oacute; un error al ejecutar la consulta. Int&eacute;ntelo nuevamente.</span>";
  32. }
  33. }
  34. }
  35. }
  36. ?>
  37. <div id="formulario">
  38. <form name="formulario-consulta" id="formulario-consulta" action="consulta.php" method="post">
  39. <label for="numero">Ingrese el n&uacute;mero a consultar:</label>
  40. <input type="text" name="numero" id="numero" />
  41. <p><input type="submit" id="submit" name="submit" value="Consultar n&uacute;mero" />
  42. </form>
  43. <div id="mensaje"><?php
  44. if(isset($mensaje)) {
  45. echo $mensaje;
  46. }
  47. ?></div>
  48. </div>
  49. </body>
  50. </html> 

Probamos y todo debiese funcionar sin problemas.
Y así de simple tenemos un identificador de números móviles para cuando lo necesitemos. Si nos fijamos, el proceso es bastante simple de implementar, por lo que los incentivamos a animarse, en solo minutos tendrán una muy útil aplicación para compartir.
Notas antes del cierre:
1.- Para nuestros amigos de fuera del país, lamentablemente este proceso sirve para Chile. Sin embargo, nos imaginamos que afuera debe ser bastante similar, por lo que los invitamos a compartir sus experiencias con otros usuarios.

Share this:

 
Copyright © Trucos Del PC. Designed by OddThemes | Distributed By Blogger Templates20