Pues eso, quería crear este post para ir poniendo pequeños truquillos, aunque sean tonterias, pero que nos pueden ayudar en ciertos momentos cuando programamos.
Este post es para que le vayais hechando un ojo de vez en cuando, y que, si algun día os encontreís un problema podais acudir aquí para ver como se hacía.
Scripts PHP-MYSQL
http://foro.elhacker.net/php/scripts_phpmysql-t48315.0.html
Clases hechas en PHP (POO)
http://foro.elhacker.net/php/clases_hechas_en_php_poo-t147928.0.html
Glosario de funciones
http://foro.elhacker.net/php/glosario_de_funciones-t65126.0.html
Evitar la caché de los navegadores
A veces podemos encontrarnos el problema de que una página no nos actualiza el contenido porque está en caché. Se puede solucionar modificando las cabeceras.
<?php
header( "Expires: Mon, 26 Jul 1997 05:00:00 GMT" ); // disable IE caching
header( "Last-Modified: " . gmdate( "D, d M Y H:i:s" ) . " GMT" );
header( "Cache-Control: no-cache, must-revalidate" );
header( "Pragma: no-cache" );
?>
Contador en SQL
Puede ser que necesitemos un contador (de lecturas, por ejemplo) de una noticia guardada en SQL. Si queremos aumentar este valor, muchos habríamos leído el campo, lo hubieramos incrementado y luego hubieramos hecho el UPDATE. Pues hay una forma mucho más fácil, segura y limpia de hacerlo y con solo una SQL.
<?php
mysql_query('UPDATE trucos SET lecturas = lecturas + 1 WHERE id=12 LIMIT 1');
?>
Hacer funcionar la función mail()
En local, la función mail() nos devolverá un error porque no tenemos configurado un cliente SMTP.
Aquí teneis la forma más fácil y rápida de solucionar este problema.
http://www.forosdelweb.com/showpost.php?p=662241&postcount=115
Intercambiar colores en X filas
A la hora de hacer listados, puede darse el caso que la legibilidad de las filas no sea buena, por lo tanto sera conveniente usar dos colores diferentes de background para cada fila, de manera que se vayan intercalando y la legibilidad sea buena. Como hacemos esto? Pues una de las maneras más elegantes es usar el operador ternario. Ahí va:
<?php
$color = "#000000";
$i = 0;
while ($i < 10)
{
$color = ($color == "#000000") ? "#FFFFFF" : "#000000";
echo $color."<br>";
$i++;
}
?>
Fechas en MySQL
Una lista de funciones muy útiles para trabajar con fechas en nuestra base de datos MySQL
http://www.xlwebmasters.com/modules.php?d=doc&f=doc2&id=1057
Saber si un año es bisiesto
Pues eso :xD (por Azielito)
<?php
function Bisiesto($anyo)
{
return checkdate(02,29,$anyo);
}
?>
... y asi funciona ...
<?php
$actual = date("Y");
$sig = $actual+1;
if(Bisiesto($actual)){
echo $actual." es bisiesto<br>";
}else{
echo $actual." no es bisiesto<br>";
}
if(Bisiesto($sig)){
echo $sig." es bisiesto<br>";
}else{
echo $sig." no es bisiesto<br>";
}
?>
Forzar descarga
Forzar la descarga de un archivo desde PHP en un navegador
header("Content-type: application/force-download");
Aquí dejo una función muy sencilla pero útil ;)
<?php
function conectar($host, $user, $pass, $database){
$conectar = mysql_connect($host, $user, $pass) or die(mysql_error());
mysql_select_db($database,$conectar);
return $conectar;
}
$conexion=conectar("tuhost","user","password","basededatos");
?>
Por ejemplo, en cada desarrollo creo un archivo llamado db.php y lo incluyo (include()) en mis php que usan MySQL. Ya solo utilizamos la variable $conexion como identificador de conexión.
Validar email
Una función para validar tu email (incluyendo subdominios).
<?php
function ValidaMail($v_email) {
if (ereg("^[_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*@+([_a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]{2,200}\.[a-zA-Z]{2,6}$", $v_email )){
return true;
}
else{
return false;
}
}
?>
Asegurando contra Inyección SQL
Es una función que incluye el SMF para evitar inyección SQL:
<?php
function addslashes__recursive($var){
if (!is_array($var))
return addslashes($var);
$new_var = array();
foreach ($var as $k => $v)$new_var[addslashes($k)]=addslashes__recursive($v);
return $new_var;
}
$_POST=addslashes__recursive($_POST);
$_GET=addslashes__recursive($_GET);
$_REQUEST=addslashes__recursive($_REQUEST);
$_SERVER=addslashes__recursive($_SERVER);
$_COOKIE=addslashes__recursive($_COOKIE);
?>
Redireccionar a HTTPS
Si nuestra web la tenemos normal con el 'HTTP' pero si queremos redireccionarlos automaticamente a HTTPS (necesitas un certificado) con esto lo puedes hacer:
<?php
if(!$_SERVER['HTTPS']== 'on'){
$nueva="https://". $_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
header("Location: $nueva");
exit();
}
?>
Mandar email con PHP
Enviar email con la función mail() de PHP.
<?php
//Ejemplo: send_mail("user@mail.com","cuerpo","asunto","demi@localhost","demi");
function send_mail($to, $body, $subject, $fromaddress, $fromname, $attachments=false)
{
$eol="\r\n";
$mime_boundary=md5(time());
# Common Headers
$headers .= "From: ".$fromname."<".$fromaddress.">".$eol;
$headers .= "Reply-To: ".$fromname."<".$fromaddress.">".$eol;
$headers .= "Return-Path: ".$fromname."<".$fromaddress.">".$eol; // these two to set reply address
$headers .= "Message-ID: <".time()."-".$fromaddress.">".$eol;
$headers .= "X-Mailer: PHP v".phpversion().$eol; // These two to help avoid spam-filters
# Boundry for marking the split & Multitype Headers
$headers .= 'MIME-Version: 1.0'.$eol.$eol;
$headers .= "Content-Type: multipart/mixed; boundary=\"".$mime_boundary."\"".$eol.$eol;
# Open the first part of the mail
$msg = "--".$mime_boundary.$eol;
$htmlalt_mime_boundary = $mime_boundary."_htmlalt"; //we must define a different MIME boundary for this section
# Setup for text OR html -
$msg .= "Content-Type: multipart/alternative; boundary=\"".$htmlalt_mime_boundary."\"".$eol.$eol;
# Text Version
$msg .= "--".$htmlalt_mime_boundary.$eol;
$msg .= "Content-Type: text/plain; charset=iso-8859-1".$eol;
$msg .= "Content-Transfer-Encoding: 8bit".$eol.$eol;
$msg .= strip_tags(str_replace("<br>", "\n", substr($body, (strpos($body, "<body>")+6)))).$eol.$eol;
# HTML Version
$msg .= "--".$htmlalt_mime_boundary.$eol;
$msg .= "Content-Type: text/html; charset=iso-8859-1".$eol;
$msg .= "Content-Transfer-Encoding: 8bit".$eol.$eol;
$msg .= $body.$eol.$eol;
//close the html/plain text alternate portion
$msg .= "--".$htmlalt_mime_boundary."--".$eol.$eol;
if ($attachments !== false)
{
for($i=0; $i < count($attachments); $i++)
{
if (is_file($attachments[$i]["file"]))
{
# File for Attachment
$file_name = substr($attachments[$i]["file"], (strrpos($attachments[$i]["file"], "/")+1));
$handle=fopen($attachments[$i]["file"], 'rb');
$f_contents=fread($handle, filesize($attachments[$i]["file"]));
$f_contents=chunk_split(base64_encode($f_contents)); //Encode The Data For Transition using base64_encode();
$f_type=filetype($attachments[$i]["file"]);
fclose($handle);
# Attachment
$msg .= "--".$mime_boundary.$eol;
$msg .= "Content-Type: ".$attachments[$i]["content_type"]."; name=\"".$file_name."\"".$eol; // sometimes i have to send MS Word, use 'msword' instead of 'pdf'
$msg .= "Content-Transfer-Encoding: base64".$eol;
$msg .= "Content-Description: ".$file_name.$eol;
$msg .= "Content-Disposition: attachment; filename=\"".$file_name."\"".$eol.$eol; // !! This line needs TWO end of lines !! IMPORTANT !!
$msg .= $f_contents.$eol.$eol;
}
}
}
# Finished
$msg .= "--".$mime_boundary."--".$eol.$eol; // finish with two eol's for better security. see Injection.
# SEND THE EMAIL
ini_set(sendmail_from,$fromaddress); // the INI lines are to force the From Address to be used !
$mail_sent = mail($to, $subject, $msg, $headers);
ini_restore(sendmail_from);
return $mail_sent;
}
?>
Checar headers
Chequea si ya se enviaron cabeceras y en que parte.
<?php
// Si no se han enviado cabeceras, enviar una
if (!headers_sent()) {
header('Location: http://www.example.com/');
exit;
}
// Un ejemplo del uso de las parametros opcionales archivo y linea, a
// partir de PHP 4.3.0.
// Note que $nombre_archivo y $num_linea son pasados para su uso posterior.
// No les asigne valores con anterioridad.
if (!headers_sent($nombre_archivo, $num_linea)) {
header('Location: http://www.example.com/');
exit;
// Probablemente quiera producir un error aqui.
} else {
echo "Las cabeceras ya fueron enviadas en $nombre_archivo en la linea " .
"$num_linea\nNo es posible redireccionar, por ahora por favor " .
"pulse este <a href=\"http://www.example.com\">enlace</a> en su " .
"lugar\n";
exit;
}
?>
Otros más:
Glosario de funciones
http://foro.elhacker.net/index.php/topic,65126.0.html
Aqui algunas funciones simples y utiles :)
<?php
function mysql_now() {
$fecha = fecha("Y-m-d H:i:s");
return $fecha;
}
?>
Con la función MySqlNow, podemos obtener la hora y fecha local desde MYSQL.
<?php
// Abrimos la conexion FTP
$conn_id = ftp_connect($ftp_server);
// Entramos con nuestro user & pass
$login_result = ftp_login($conn_id, $ftp_user_name, $ftp_user_pass);
// Chequeamos la conexion
if ((!$conn_id) || (!$login_result)) {
echo "Fallo conexion";
exit;
} else {
echo "Conectado a $ftp_server, for user $ftp_user_name";
}
// Cerramos la conexion
ftp_close($conn_id);
?>
Con esta función nos conectamos a un servidor FTP, y luego nos desconectamos, esto es util para si tenemos algun script y tenemos que renombrar archivos, etc.
B0rn2kill
Ps ay les voy con unas
//------ Funciones de abstraccion de consultas SQL ---------------------
//-INSERT- $columns=get_commas(...) $values=get_commas(...)
function get_insert($table, $columns, $values){
return "INSERT INTO $table ($columns) VALUES ($values)";
}
//-UPDATE- $values=get_mult_set(...) $where=get_mult_set(...) o get_simp_set(...)
function get_update($table, $values, $where){
return "UPDATE $table SET $values WHERE $where";
}
//-UPDATE- actualiza una tabla con valores de otra (sólo MySQL >4.xx)
function get_update_join($table_a, $table_b, $id_a, $id_b, $values, $where=''){
if($where!='') $where="AND ($where)";
return "UPDATE $table_a a, $table_b b SET $values WHERE a.$id_a=b.$id_b $where";
}
//-SELECT- $columns=get_commas(...) o '*' $where=get_mult_set(...) o get_simp_set(...)
function get_select($table, $columns, $where='', $order=''){
$tmp = "SELECT $columns FROM $table";
if($where!=''){
$tmp.=" WHERE $where";
}
if($order!=''){
$tmp.=" ORDER BY $where";
}
return $tmp;
}
//-SELECT- entre 2 tablas por 2 indices comunes
function get_select_join($table_a, $table_b, $id_a, $id_b, $columns, $where='', $order=''){
$table ="$table_a a, $table_b b";
$w="a.$id_a=b.$id_b ";
if($where!='') $w.="AND ($where)";
return get_select($table, $columns, $w, $order);
}
//-DELETE- $where=get_mult_set(...) o get_simp_set(...)
function get_delete($table, $where=''){
$tmp = "DELETE FROM $table";
if($where!=''){
$tmp.=" WHERE $where";
}
return $tmp;
}
//- get_commas(true|false, 1, 2, 4...) true pone comillas => '1','2','4'...
function get_commas(){
$a=func_get_args();
$com = $a[0];
return get_commasA(array_slice($a, 1, count($a)-1), $com);
}
//- como la anterior pero devuelve entre comas el array pasado
function get_commasA($arr_in, $comillas=true){
$temp='';
$coma="'";
if(!$comillas) $coma=''; //-el 1er param==true, metemos comas
foreach($arr_in as $arg){
if($temp!='') $temp.=",";
if(substr($arg,0,2)=='!!'){ //- Si empieza por !! no le pongo comas...
$temp.=substr($arg,2); continue;
}
$temp.="$coma".$arg."$coma";
}
return $temp;
}
//- Devuelve una asignacion (por defecto) simple entre comillas X='1'
function get_simp_set($col, $val, $sign='=', $comillas=true){
$cm="'";
if(!$comillas) $cm='';
if(substr($val,0,2)=='!!'){ //- Si empieza por !! no le pongo comas...
$val=substr($val,2); $cm='';
}
return $col."$sign $cm".$val."$cm";
}
//-Mezcla cada valor de $a_cols, con uno de $a_vals "X='1', T='2'...
//- ej: con $simb='or' X='1' or T='2'...
//- ej: con $sign='>' X>'1' or T>'2'...
function get_mult_set($a_cols, $a_vals, $simb=',', $sign='=', $comillas=true){
$temp='';
for($x=0;$x<count($a_cols);$x++){
if($temp!='') $temp.=" $simb ";
$temp.= get_simp_set($a_cols[$x],$a_vals[$x], $sign, $comillas);
}
return $temp;
}
function get_between($col, $min, $max){
return "($col BETWEEN $min AND $max)";
}
?>
aqui les paso mi clase:
hola que tal, bueno hice una clase para evitar tener que cambiar la sintaxis con diferentes bases de datos, todo ese proceso de queries y connects es muy engorroso y bueno aqui esta mi clase hecha en php5 (la hice en php4 pero la actualize).
Deben nombrar a este archivo "DBALL.php" (nota: no significa Dragon Ball, significa data bases all - todas las bases de datos) ;D ;D
<?php
/**
* Creador: Coolfrog from Bolivia
* Correo: jm.neutron@gmail.com
* Blog: http://mundocoolf.blogspot.com
* Web Page: ***En progreso***
* Version:1.1
*
* Clase para php5 que permite ejecutar MYSQL, POSTGRESQL E ISIS
* en versiones siquientes se aumentara para oracle y otras que sean necesarias.
* Ultima Acualización 6/8/07
*
* Es cogigo libre y puede ser distribuido a cualquier persona, solo una condicion ,para usar esta clase deben dejar mis datos ;) es lo unico que les agradeceria que hicieran
*/
include("iniDB.php"); //archivo que inicia las variables estaticas, SIRVE PARA TRABAJAR CON UN SOLO MOTOR DE BASE DATOS
class DBALL{
public static $host;
public static $usr;
public static $pass;
public static $dbname;
public static $motor;
private $conex;
private $result;
public static $showErrors;
/*#######DESCOMENTAR EL CONSTRUCTOR SI SE QUIERE TRABAJAR CON DOS O MAS MOTORES DE BASES DE DATOS AL MISMO TIEMPO, Y HACER LA CONEXCION CON EL CONSTRUCTOR PARA CADA MOTOR#######*/
/**
* constructor que inicia las variables
*
* @param str $host
* @param str $usr
* @param str $pass
* @param str $dbname
* @param str $motor
*/
/*function __construct($host,$usr,$pass,$dbname,$motor){
self::$host=$host;
self::$usr=$usr;
self::$pass=$pass;
self::$dbname=$dbname;
self::$motor=$motor;
}*/
/*#####CONSTRUCTOR: DESCOMENTAR HASTA AQUI#####*/
/**
* metodo que conecta a una base de datos dependiendo del parameto $motor
* @return boolean
*/
public function dbConnect(){
self::$motor=strtoupper(self::$motor);
$v=false;
if(self::$motor=="MYSQL"){
$this->conex=mysql_connect(self::$host,self::$usr,self::$pass);
$var=mysql_select_db(self::$dbname,$this->conex);
if($var){
$v=true;
}
} else if(self::$motor=="PSQL"){
$this->conex=@pg_connect("host=".self::$host." dbname=".self::$dbname." user=".self::$usr." password=".self::$pass);
if($this->conex){
$v=true;
}
} else if(self::$motor=="ISIS"){
$this->conex=isis_open(self::$dbname,"-v error -format aligned -encoding ISO8859_1");
if($this->conex){
$v=true;
}
}
//devuelve true si se conecto y false si hay error
return $v;
}
/**
* selecciona registros SELECTS
*
* @param string $consulta
* @return array
*/
public function dbSelect($consulta){
$res=array();
if(self::$motor=="MYSQL"){
$this->result = mysql_query($consulta);
if(self::$showErrors){
if(mysql_errno($this->conex)!=0)
echo "Error ".mysql_errno($this->conex)." : ".mysql_error($this->conex);
}
$fila= mysql_num_rows($this->result);
$i=0;
while ($row = mysql_fetch_object($this->result)){
$res[$i]=$row;
$i++;
}
mysql_free_result($this->result);
}else if(self::$motor=="PSQL"){
$this->result = @pg_query($this->conex,$consulta);
$fila=@pg_numrows($this->result);
for($i=0;$i<$fila;$i++){
$res[$i]=@pg_fetch_object($this->result,$i);
}
@pg_free_result($this->result);
}else if (self::$motor=="ISIS"){
$this->result = isis_query($consulta,$this->conex);
$i=0;
if ($this->result!=null && $this->result!='') {
while($record = isis_fetch_flat_array($this->result)){
$res[$i]=$record;
$i++;
}
}
}
return $res;
}
/**;
* realiza consultas como:UPDATE,INSERT AND DELETE
* retorna true si la consulta se ejecuto correctamente caso contrario false
*
* @param string $consulta
* @return boolean
*/
public function dbABM($consulta){
$r=false;
if(self::$motor=="MYSQL"){
$this->result = mysql_query($consulta);
if(self::$showErrors){
if(mysql_errno($this->conex)!=0)
echo "Error ".mysql_errno($this->conex)." : ".mysql_error($this->conex);
}
//mysql_free_result($this->result);
}else if(self::$motor=="PSQL"){
$this->result = @pg_query($this->conex,$consulta);
pg_free_result($this->result);
}
if ($this->result) {
$r=true;
}
//Devuelve false en caso de error
return $r;
}
/**
* Inicia la transaccion, retorna true si la transaccion se Inicia correctamente caso contrario false
*
* @return Boolean
*/
public function dbBeginTransaction(){
if(self::$motor=="MYSQL"){
$this->result = mysql_query("BEGIN");
}else{
$this->result = pg_query($this->conex,"BEGIN");
}
if ($this->result) {
return true;
//echo "Transaccion Iniciada";
}
else
return false;
}
/**
* Cancela la transaccion, retorna true si la transaccion es cancelada correctamente caso contrario false
*
* @return Boolean
*/
public function dbCancelTransaction(){
if(self::$motor=="MYSQL"){
$this->result = mysql_query("ROLLBACK");
}else{
$this->result = pg_query($this->conex,"ROLLBACK");
}
if ($this->result) {
return true;//$r=true;
//echo "Transaccion Cancelada";
}
else
return false;
}
/**
* Termina la transaccion, retorna true si la transaccion termina correctamente caso contrario false
*
* @return Boolean
*/
public function dbEndTransaction(){
if(self::$motor=="MYSQL"){
$this->result = mysql_query("COMMIT");
}else{
$this->result = pg_query($this->conex,"COMMIT");
}
if ($this->result) {
return true;
//echo "Transaccion Terminada";
} else
return false;
}
public function dbClose(){
if(self::$motor=="MYSQL"){
mysql_close();
}else if(self::$motor=="PSQL"){
pg_close();
}else if (self::$motor=="ISIS"){
@isis_close($this->conex);//$this->dbname,"-v error -format aligned -encoding ISO8859_1"
}
}
// #################### FUNCIONES EXCLUSIVAS PARA ISIS #######################
/*PUEDEN BORRAR O COMENTAR ESTAS FUNCIONES SI NO UTILIZAN ISIS*/
private function num_reg_query(){ //retorna el numer de registros de la consulta
if ($this->result!=null && $this->result!='') {
return isis_num_rows($this->result);
}//else return 0;
}
private function num_reg(){ //retorna el numer de registros de toda la BD
return isis_last_mfn($this->conex);
}
private function get_reg($mfnindex){ //retorna el registro especificado
return isis_fetch_flat_array_from_mfn($mfnindex,$this->conex);
}
// #################### FUNCIONES EXCLUSIVAS PARA ISIS #######################
}
?>
El archivo de configuracion de los parametros iniciales es este:
Deben nombrar a este archivo "iniDB.php"
<?php
//parametros de inicio de la base de datos
DBALL::$host="localhost"; //la ruta del servidor donde esta la BD
DBALL::$usr="root"; //el usuario para conectarse
DBALL::$pass="mysql"; //el password para conectarse
DBALL::$dbname="logico"; //nombre de la base de datos
DBALL::$motor="mysql"; //el motor puede ser mysql,postgres o isis
DBALL::$showErrors=true; // indica si se deben mostrar los errores de la BD
?>
Como dice al inicio de los comentarios cualquiera que este interesado puede usar mi clase solo les pido que dejen mis datos al inicio smiley
Ahora su forma de uso es la siguiente para un INSERT, DELETE O UPDATE:
$categoria="php"
$categoriaPadre=1
include("DBALL.php"); //incluyen el archivo que contiene la clase
$mydb=new DBALL(); //instancian a la clase
if($mydb->dbConnect()){ //el metodo dbConnect devuelve true si no hay problemas
//una consulta insert
$sql="INSERT INTO CATEGORIA VALUES(default,'$categoria',$categoriaPadre);";
if($mydb->dbABM($sql)) //procesa consultas insert,delete y update
echo "SE INSERTO CORRECTAMENTE");
else echo "NO SE PUEDO INSERTAR";
}
else{
echo "NO SE PUDO CONECTAR";
}
Ahora su forma de uso es la siguiente para un SELECT
include("DBALL.php"); //incluyen el archivo que contiene la clase
$mydb=new DBALL(); //instancian a la clase
if($mydb->dbConnect()){ //el metodo dbConnect devuelve true si no hay problemas
//una consulta select
$sql="select * from categoria";
$reg=$mydb->dbSelect($sql); //dbSelect devuelve un array de objetos
//para recorrer el array
for($i=0;$i<count($reg);$i++){
echo "<option value=".$reg[$i]->idCat.">".$reg[$i]->nombreCategoria."</option>";
//se accede a los nombres los campos como si fueran propiedades de objetos
}
}
else{
echo "NO SE PUDO CONECTAR";
}
Para terminar deben guardar los dos archivos "DBALL.php" y "iniDB.php" en el mismo directorio.
Bueno eso es todo, tb. tiene metodo para manejar transacciones pero eso es mas facil y si tienen dudas pregunten que con gusto voy a contestar.
PD: Si alguien quiere modificar o ayudarme a hacer algunas mejoras con gusto las recibo, y si quieren la clase para php 4 solo avisen.
Funcion para cortar texo o limitar, ideal para ultimas noticias y demas
<?
// Funcion para cortar texto
// Programado por alienmaster <efnworkz@hotmail.com>
// http://4cosas.com
function cortar($text0, $limite){
$comp = strlen($text0);
if($comp > $limite){
return = substr($text0, 0, $limite)."...";
}
else{
return "$text0";
}
}
?>
Forma abreviada para imprimir en pantalla
Es sencillo!!!
$nick="Soy Carxl";
<?=$nick?>
Esa instrucción reemplazaría: <?php echo $nick;?>
Saludos ;D
Hice una pequeña función que permite seleccionar lo que hay dentro de un string desde la palabra necesitada hasta la que finaliza...
<?php
function desde_hasta($desde, $hasta, $contenido){
if(eregi($desde ,$contenido)){
$retorno = explode($desde, $contenido);
$retorno = $retorno[1];
$retorno = explode($hasta, $retorno);
$retorno = $retorno[0];
return $retorno;
} else {
return FALSE;
}
}
?>
De esta forma ejecutas:
<?php
$contenido = 'tienes <a href="http://foro.elhacker.net/pm.html">111 mensajes</a>';
$cantidad_mensajes = desde_hasta('tienes <a href="http://foro.elhacker.net/pm.html">', 'mensajes</a>', $contenido);
echo "Cantidad de mensajes: $cantidad_mensajes\n";
?>
Desbuelve:
CitarCantidad de mensajes: 111
Estaba realizando unas funciones propias para un sistema que estoy haciendo y quería compartirlo con ustedes si es que agún dia tienen la misma necesidad:
<?php
$palabra = "1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950";
echo whk_recorta($palabra,10);
/* Resultado: 1234567891...4647484950 */
function whk_recorta($palabra,$limite){
if($limite < 1){
return $palabra;
}
if(strlen($palabra)>(($limite * 2) + 1)){
for($cuenta=0;$cuenta<$limite;$cuenta++){
$palabra_final .= $palabra[$cuenta];
}
$palabra_final .= "...";
for($cuenta = (strlen($palabra) - $limite); $cuenta <= strlen($palabra); $cuenta++){
$palabra_final .= $palabra[$cuenta];
}
return $palabra_final;
}else{
return $palabra;
}
}
?>
De esta forma se recortan hacia ambos lados... derecha e isquierda.
function rnd_string($LongString){
$RndString = '';
for ($i=0; $i<$LongString - 1; $i++){
switch (rand(0,2)){
case 0: $RndString .= chr((rand(0,9)) + 48);break;
case 1: $RndString .= chr((rand(0,25)) + 65);break;
case 2: $RndString .= chr((rand(0,25)) + 97);break;
}
}
return $RndString;
}
Cita de: alienmaster en 16 Septiembre 2007, 04:53 AM
Funcion para cortar texo o limitar, ideal para ultimas noticias y demas
<?
// Funcion para cortar texto
// Programado por alienmaster <efnworkz@hotmail.com>
// http://4cosas.com
function cortar($text0, $limite){
$comp = strlen($text0);
if($comp > $limite){
return = substr($text0, 0, $limite)."...";
}
else{
return "$text0";
}
}
?>
oe man una consultatita , como aria esta esta funcion con una consulta en mysql
que muestre las noticias no entiendo bien con mysql
Transformación de Strings en múltiples formas
// Powered by GreenCode - WHK
function codifica_base64_gz($buffer){
$buffer = bin2hex(base64_encode(gzcompress($_POST['buffer'])));
$separador = 16; // Editable, separador de 16 bytes.
$separa = 0;
for($cuenta=0;$cuenta<strlen($buffer);$cuenta+=2){
if($separa == 0){
$dump .= '"';
}
$dump .= '\x'.$buffer[$cuenta].$buffer[$cuenta+1];
$separa++;
if($separa == $separador){
$dump .= '"';
if($cuenta != (strlen($buffer))-2){
$dump .= '.'."\n";
}
$separa = 0;
}
}
if($dump[strlen($dump)-1] != '"'){
$dump .= '"';
}
return
"\x3c\x3fphp\n// ...\n\n/* El retorno es tu buffer */".
"\$str = gzuncompress(base64_decode(\n$dump\n));\n\n// ...\n\x3f\x3e";
}
function ascii_a_png($buffer){
return
"\x3c\x3fphp\n// ...\n\n".
"/* El retorno es una imagen */\n".
"\$handle_img = imagecreate(".(int)(strlen($buffer) * 9).", 30);\n".
"\$fondo = imagecolorallocate(\$handle_img, 255, 255, 255);\n".
"\$color_texto = imagecolorallocate(\$handle_img, 0, 0, 255);\n".
"imagestring(\$handle_img, 5, 0, 0, base64_decode(\"".base64_encode($buffer)."\"), \$color_texto);\n".
"header(\"Content-type: image/png\");\n".
"imagepng(\$handle_img);\n\n".
"// ...\n\x3f\x3e";
}
function sqlchr($buffer){
for($cuenta=0;$cuenta<strlen($buffer);$cuenta++){
$dump .= 'char('.ord($buffer[$cuenta]).')';
if((strlen($buffer) - 1) != $cuenta){
$dump .= ',';
}
}
return $dump;
}
function sqldword($buffer){
return 'funcion(0x'.bin2hex($buffer).')';
}
function urlencode_total($buffer){
$buffer = bin2hex($buffer);
for($cuenta=0;$cuenta<strlen($buffer);$cuenta+=2){
$dump .= '%'.$buffer[$cuenta].$buffer[$cuenta+1];
}
return $dump;
}
function unescape_javascript($buffer){
return '<SCRIPT LANGUAGE="javascript" TYPE="text/javascript">
document.write(unescape("'.urlencode_total($buffer).'"));
</SCRIPT>';
}
function php_encode($buffer){
$buffer = bin2hex(base64_encode(gzcompress($_POST['buffer'])));
$separador = 16; // Editable, separador de 16 bytes.
$separa = 0;
for($cuenta=0;$cuenta<strlen($buffer);$cuenta+=2){
if($separa == 0){
$dump .= '"';
}
$dump .= '\x'.$buffer[$cuenta].$buffer[$cuenta+1];
$separa++;
if($separa == $separador){
$dump .= '"';
if($cuenta != (strlen($buffer))-2){
$dump .= '.'."\n";
}
$separa = 0;
}
}
if($dump[strlen($dump)-1] != '"'){
$dump .= '"';
}
return
"\x3c\x3fphp\n// ...\n".
"/*\nRecuerda que no debes anteponer '\x3c\x3f' ni terminar con '\x3f\x3e'".
"Elimina este comentario.\n*/\n".
"eval(gzuncompress(base64_decode(\n$dump\n)));\n\n// ...\n\x3f\x3e";
}
function decodifica_base64_gz($buffer){
$buffer1 = str_replace('"',' ',$buffer);
$buffer1 = str_replace('.',' ',$buffer);
$buffer1 = explode('\x',$buffer);
$buffer1[0] = '';
for($cuenta=0;$cuenta<count($buffer1);$cuenta++){
if(strlen($buffer1[$cuenta]) == '2'){
$buffer2 .= ' '.$buffer1[$cuenta];
$procesando = true;
}else{
if($procesando){
$buffer2 .= ' '.$buffer1[$cuenta][0].$buffer1[$cuenta][1];
}
}
}
$buffer2 = explode(' ',$buffer2);
for($cuenta=0;$cuenta<count($buffer2);$cuenta++){
if(strlen($buffer2[$cuenta]) == '2'){
$buffer3 .= $buffer2[$cuenta];
}
}
return gzuncompress(base64_decode(hexa_a_str($buffer3)));
}
function ascii_a_sha1($buffer){
return sha1($buffer);
}
function hexa_a_str($buffer){
$buffer = preg_replace("/[^a-zA-Z0-9s]/", "", str_replace('\x',' ',$buffer));
for($cuenta=0; $cuenta<strlen($buffer); $cuenta+=2){
$dump .= chr(hexdec($buffer[$cuenta].$buffer[($cuenta+1)]));
}
return $dump;
}
function ascii_a_decimal($buffer){
for($cuenta=0;$cuenta<strlen($buffer);$cuenta++){
$dump .= ord($buffer[$cuenta]).' ';
}
return $dump;
}
function ascii_a_html_sin_s($buffer){
$buffer = bin2hex($buffer);
for($cuenta=0; $cuenta<strlen($buffer); $cuenta+=2){
$dump .= '&#'.hexdec($buffer[$cuenta].$buffer[$cuenta+1]);
}
return $dump;
}
function ascii_a_html_con_s($buffer){
$buffer = bin2hex($buffer);
for($cuenta=0; $cuenta<strlen($buffer); $cuenta+=2){
$dump .= '&#x'.$buffer[$cuenta].$buffer[$cuenta+1].';';
}
return $dump;
}
function generar_htpasswd_sha($user,$pass){
return $user.':{SHA}'.base64_encode(sha1($pass, TRUE));
}
function generar_htpasswd_md5($user,$realm,$pass){
return $user.':'.md5($user.':'.$realm.':'.$pass);
}
function hexadecimal_a_decimal($buffer){
$buffer = preg_replace("/[^a-zA-Z0-9s]/", "", str_replace('\x',' ',$buffer));
for($cuenta=0; $cuenta<strlen($buffer); $cuenta++){
if(ctype_xdigit($buffer[$cuenta].$buffer[$cuenta+1])){
$dump .= hexdec($buffer[$cuenta].$buffer[$cuenta+1]).' ';
$cuenta++;
}
}
return $dump;
}
function octal_a_decimal($buffer){
$buffer = preg_replace("/[^0-9 s]/", "", $buffer);
$buffer = explode(' ',$buffer);
for($cuenta=0; $cuenta<(count($buffer)-1); $cuenta++){
$dump .= octdec($buffer[$cuenta]).' ';
}
return $dump;
}
function ascii_a_hexadecimal($buffer){
return chunk_split(bin2hex($buffer),2,' ');
}
function ascii_a_octal($buffer){
$buffer = bin2hex($buffer);
for($cuenta=0; $cuenta<strlen($buffer); $cuenta+=2){
$dump .= hexdec($buffer[$cuenta].$buffer[$cuenta+1]).' ';
}
$dump3 = explode(' ',$dump);
for($cuenta=0; $cuenta<(count($dump3)-1); $cuenta++){
$dump2 .= decoct($dump3[$cuenta]).' ';
}
return $dump2;
}
function debugger(){
global $dump;
if($dump){
echo htmlspecialchars($dump,ENT_QUOTES);
}else{
if($_POST['buffer'] and $_POST['algoritmo']){
echo "No hay datos que devolver";
}
}
}
Uso:
<?php
// .. ..
$dump = ascii_a_png('Hola Elhacker.net'); // Procesa el String.
debugger(); // Imprime en pantalla el resultado evitando un XSS.
// .. ..
?>
Debido a una incompatibilidad de SMF con carácteres HTML como & y # las dos funciones
ascii_a_html_sin_s()
ascii_a_html_con_s()
No se ven como debieran. Deben aparecer de la siguiente manera:
function ascii_a_html_sin_s($buffer){
$buffer = bin2hex($buffer);
for($cuenta=0; $cuenta<strlen($buffer); $cuenta+=2){
$dump .= '&#'.hexdec($buffer[$cuenta].$buffer[$cuenta+1]);
}
return $dump;
}
function ascii_a_html_con_s($buffer){
$buffer = bin2hex($buffer);
for($cuenta=0; $cuenta<strlen($buffer); $cuenta+=2){
$dump .= '&#x'.$buffer[$cuenta].$buffer[$cuenta+1].';';
}
return $dump;
}
Función:
<?
// Creada por Dacan
function instalador ($archivo , $variable1, $variable2, $variable3, $variable4){
$manejador = @fopen($archivo, "w+");
$contenido = "<?\n";
$contenido .= "\$servidor = \"$variable1\";\n";
$contenido .= "\$usuario = \"$variable2\";\n";
$contenido .= "\$password = \"$variable3\";\n";
$contenido .= "\$base = \"$variable4\";\n";
$contenido .= "\$conexion = @mysql_connect(\$servidor, \$usuario, \$password) or die(mysql_error());\n";
$contenido .= "@mysql_select_db(\$base, \$conexion) or die (mysql_error());\n";
$contenido .= "?>";
if(fwrite($manejador, $contenido)){
return true;
}
else{
return false;
}
}
?>
Ejemplo de Uso:
<?
if(instalador("config.php", $_POST['servidor'], $_POST['usuario'], $_POST['password'], $_POST['base'])){
echo "Datos guardados correctamente";
}
else {
echo "Ocurrio un error!";
}
?>
Como Funciona:
function instalador ($archivo , $variable1, $variable2, $variable3, $variable4){
La variable $archivo corresponde al archivo que se va modificar, $variable 1 corresponde al host donde esta alojada la base de datos, $variable2 corresponde al usuario de la base de datos, $variable3 corresponde la password de la base de datos y $variable4 corresponde el nombre de la base de datos.
Si encuentran algún error, modifican algo, tienen dudas no duden en avisarme, si lo usan en sus scripts aunque sea dejen la parte de Creada por Dacan se les agradece.
Este tema proviene de otro foro al cual pertenezco para que no hayan confusiones: http://mixforo.com/foro/index.php/topic,61657.0.html
Saludos, Dacan :D
Me gusta, lo utilizaré para el instalador que estoy creando... ;)
Cuando pueda la mejoro con mas opciones así cuando necesiten hacer un instalador se ahorren mucho código.
Saludos, Dacan :D
Podríamos hacer un solo post en el comienzo con uno o grupos de php algo así como librerías de códigos sacados de acá mismo y usarlos en sistemas, pasar todo a funciones y aplicarlos como uno quiera, por ejemplo que todo comienze con un include a ./.class_php/includes.php y ese include que se encargue de hacer el resto y ese directorio con acceso denegado al acceso público, de esta forma si alguien necesita alguna función de acá solo descarga el sistema y le hace un include y listo.
Si es que se puede con el permiso del mod, habría que pedir permiso a los que postearon cada tema para ver si se puede incluir o no, es mas, hasta podría elegirse solo los mas funcionales para ahorrar espacioy hacer algo así como un concurso mensual y los mejores serán incluido al paquete :P, si fuera así cada persona que posteara algo acá tendría que decir que podemos incluirlo si es que quiere que se incluya.. claro nuevamente con el permiso del mod :P
Claro ;) no hay problema, nomas me avisan a que le dejo y quito chincheta ;)
Bién, gracias.. ahi va:
http://foro.elhacker.net/php/proyecto_phplibs_creado_por_los_usuarios_de_elhackernet-t239182.0.html
Como son mas de un tema de donde sacar mejor hize uno nuevo :P como fuiste el único que me ha respondido que puedo poner tus scripts en el sistema entonces solo los dos estamos integrados, si alguien mas quiere hacerlo que se haga presente en ese post que puse.
Exelente! :)
Bueno, este generador lo hice hace tiempo, es util para formularios de dominios, hosting, emails...:
<?php
// generador de dnis para formularios
// Creado por Erik#
// erik_unix@hotmail.com
function dni($dni){
$gen= (int) ($dni / 23);
$gen *= 23;
$gen= $dni - $gen;
$gen2= "TRWAGMYFPDXBNJZSQVHLCKEO";
$letra= substr ($gen2, $gen, 1);
return $dni.$letra;
}
$n1 = rand(0,9);
$n2 = rand(0,9);
$n3 = rand(0,9);
$n4 = rand(0,9);
$n5 = rand(0,9);
$n6 = rand(0,9);
$n7 = rand(0,9);
$n8 = rand(0,9);
$ndni = $n1.$n2.$n3.$n4.$n5.$n6.$n7.$n8;
echo '<b>DNI: </b>'.dni($ndni);
?>
Bueno, os dejo un captcha que cree usando sesiones, en principio iva a usar cookies, pero, me lo repense:
captchaverf.php
<?php
session_start();
if($_POST['ok']){
if($_POST['captcha'] == $_SESSION['captcha']){
echo "Captcha correcto";
}else{
echo "Captcha incorrecto";
}
}else{
echo '<img src="captcha.php"><br>
<form action="captchaverf.php" method="POST">
<input type="text" name="captcha"><br><input type="submit" name="ok" value="Verificar"></form>';
}
?>
captcha.php
<?php
session_start();
header("Content-type: image/png");
$_SESSION['captcha'] = rand(0001, 9999);
$imagen = imagecreate(50,25);
$fondo = imagecolorallocate($imagen, 0, 0, 0);
$texto = imagecolorallocate($imagen, 255, 255, 255);
imagestring($imagen, 10, 6, 5,$_SESSION['captcha'], $texto);
imagepng($imagen);
?>
Prueba: www.krews.es/captchaverf.php
Esta funcióncomo se usaría?
<?php
function addslashes__recursive($var){
if (!is_array($var))
return addslashes($var);
$new_var = array();
foreach ($var as $k => $v)$new_var[addslashes($k)]=addslashes__recursive($v);
return $new_var;
}
$_POST=addslashes__recursive($_POST);
$_GET=addslashes__recursive($_GET);
$_REQUEST=addslashes__recursive($_REQUEST);
$_SERVER=addslashes__recursive($_SERVER);
$_COOKIE=addslashes__recursive($_COOKIE);
?>
Se pone en cada archivo php y listo? no verdad? :(
Es para poner slashes del tipo (\) y se usa:
echo addslashes__recursive($tuvariable);
Aunque en ese código ya esta siendo utilizada en todas las superglobales.
Saludos, Dacan :D
Hola que tal, a mi me fastidia andar capturando captchas y explotando mi server con sesiones. sin mencionar la gestion de cookies como sesiones.
Aqui eh hecho una solución aparentemente factible. y digo aparente por que todo es hipotetico aunque supongo que funciona perfecto.
AQUI CON ESTA FUNCION.
<?php
function XSRF($s){
$ref=parse_url($_SERVER['HTTP_REFERER']);
if(($ref['host']==$_SERVER['HTTP_HOST'])&&(basename($ref['path'])==$s)) return true;
}
/* EJEMPLO */
# El argumento este que se pasa, es script donde se supone viene el vinculo por ejemplo
# en un script donde su nombre es admin_posts.php y contine algo como <a href="eliminar.php?cual=estemero">Eliminar</a>
#entonces en el script eliminar.php ponemos la siguente estructura
if(XSRF("admin_posts.php")){
#ejecuta si es legitimo -->
$gestor=fopen('correcto.txt', 'a');
fwrite($gestor, "OK\n");
fclose($gestor);
#<--
}
?>
Una pregunta, la lectura/escritura de un archivo en el server, consumemenos recursos que el uso de SESIONES?
Saludos
[quote author=nsigned link=topic=152467.msg1245631#msg1245631 date=1244007136]
Una pregunta, la lectura/escritura de un archivo en el server, consumemenos recursos que el uso de SESIONES?
Saludos
[/quote]
man no debes de postear eso aqui, y relativamente es lo mismo, mejor usa cookie es mas lijero que el proceso de sesiones.
pero no le veo mucha relacion utilitaria en una sesion y un archivo.
podrias tu sustituir el uso de una sesion con el uso de un archivo??
PD: tu firma me da miedo.
Cita de: Dacan en 25 Enero 2009, 23:19 PM
Es para poner slashes del tipo (\) y se usa:
echo addslashes__recursive($tuvariable);
Aunque en ese código ya esta siendo utilizada en todas las superglobales.
Saludos, Dacan :D
Exactirijillo xD, así es, con eso se cepilla todo lo que entra y sale a través del server/php. Aunque si tienes las magic quotes te va a poner tripe \ xD tons le cambié algo...
//----------------------------------------------+
// We claer all traffic of our server |
//----------------------------------------------+
// This function I extrac of SMF system fourum, cleared all " and ' in traffic server
function addslashes__recursive($var){
if (!is_array($var))
return addslashes($var);
$new_var = array();
foreach ($var as $k => $v)$new_var[addslashes($k)]=addslashes__recursive($v);
return $new_var;
}
//If the magic quotes are disable, aplicate the function, else, do not nothing
if(get_magic_quotes_gpc()==0){
$_POST=addslashes__recursive($_POST);
$_GET=addslashes__recursive($_GET);
$_REQUEST=addslashes__recursive($_REQUEST);
$_SERVER=addslashes__recursive($_SERVER);
$_COOKIE=addslashes__recursive($_COOKIE);
}
Y pues entrado en tema... les regalo otra!:
// With this function, we are clear the html chars to entity ascii
function clear_chars($var){
if(!is_array($var)){
return htmlspecialchars($var);
}
else{
$new_var = array();
foreach ($var as $k => $v){
$new_var[htmlspecialchars($k)]=clear_chars($v);
return $new_var;
}
}
}
if($_POST) $_POST=clear_chars($_POST);
if($_GET) $_GET=clear_chars($_GET);
if($_REQUEST) $_REQUEST=clear_chars($_REQUEST);
if($_SERVER) $_SERVER=clear_chars($_SERVER);
if($_COOKIE) $_COOKIE=clear_chars($_COOKIE);
Suerte
Cita de: дٳŦ٭ en 4 Junio 2009, 17:15 PM
Cita de: Dacan en 25 Enero 2009, 23:19 PM
Es para poner slashes del tipo (\) y se usa:
echo addslashes__recursive($tuvariable);
Aunque en ese código ya esta siendo utilizada en todas las superglobales.
Saludos, Dacan :D
Exactirijillo xD, así es, con eso se cepilla todo lo que entra y sale a través del server/php. Aunque si tienes las magic quotes te va a poner tripe \ xD tons le cambié algo...
//----------------------------------------------+
// We claer all traffic of our server |
//----------------------------------------------+
// This function I extrac of SMF system fourum, cleared all " and ' in traffic server
function addslashes__recursive($var){
if (!is_array($var))
return addslashes($var);
$new_var = array();
foreach ($var as $k => $v)$new_var[addslashes($k)]=addslashes__recursive($v);
return $new_var;
}
//If the magic quotes are disable, aplicate the function, else, do not nothing
if(get_magic_quotes_gpc()==0){
$_POST=addslashes__recursive($_POST);
$_GET=addslashes__recursive($_GET);
$_REQUEST=addslashes__recursive($_REQUEST);
$_SERVER=addslashes__recursive($_SERVER);
$_COOKIE=addslashes__recursive($_COOKIE);
}
Y pues entrado en tema... les regalo otra!:
// With this function, we are clear the html chars to entity ascii
function clear_chars($var){
if(!is_array($var)){
return htmlspecialchars($var);
}
else{
$new_var = array();
foreach ($var as $k => $v){
$new_var[htmlspecialchars($k)]=clear_chars($v);
return $new_var;
}
}
}
if($_POST) $_POST=clear_chars($_POST);
if($_GET) $_GET=clear_chars($_GET);
if($_REQUEST) $_REQUEST=clear_chars($_REQUEST);
if($_SERVER) $_SERVER=clear_chars($_SERVER);
if($_COOKIE) $_COOKIE=clear_chars($_COOKIE);
Suerte
Sigue estando el return dentro de el bucle.
¬¬ vicioso del vodka
más corto:
<?php
$_GET = stripslashses_gpc($_GET);
$_POST = stripslashses_gpc($_POST);
$_COOKIE = stripslashses_gpc($_COOKIE);
$_SERVER = stripslashses_gpc($_SERVER);
function stripslashses_gpc($buffer){
if(!function_exists('get_magic_quotes_gpc'))
return $buffer;
if(get_magic_quotes_gpc()){
if(is_array($buffer)){
foreach($buffer as $variable => $valor){
$temp[$variable] = stripslashses_gpc($valor);
}
return $temp;
}else{
return stripslashes($buffer);
}
}else{
return $buffer;
}
}
?>
Y con array_map() es más corto.
Descripcion: Bueno esto sirve de una palabra agregarle algo en cada letra.
function letras($palabra, $k){
return implode($k,str_split($palabra));
}
ejemplo:
echo letras('hola', '<br />');
//resultado:
h
o
l
a
ejemplo2:
echo letras('hola', ',');
//resultado:
h,o,l,a
Array de 80 valores contando desde el 1, útil para selector de edades:
<?php
$a = array_keys(explode(',', str_repeat(",", 80)));
print_r(array_shift($a));
?>
Por ejemplo:
<select name="edad">
<?php
$a = array_keys(explode(',', str_repeat(",", 80)));
array_shift($a);
foreach($a as $id){
echo '<option value="'.$id.'">'.$id.'</option>';
}
?>
</select>
Como podria hacer en php lo siiguiente?
Imaginamos que tengo una lista con 100 usuarios o los que sean
en un archivo de texto plano txt
en este caso cojemos un user al azahar yo mismo
http://foro.elhacker.net/profiles/escuchamusicabiz-u323186.html
Ahora bien si yo quiero que el php coja y vea el perfil de los
100 users y me guarde un archivo que me diga el rango que
tiene cada uno, como podria hacerlo?
es decir que el php lea el perfifl y donde pone escrito el rango
lo copie y lo guarde en el archivo añadiendo al usuario el rango que
tenga?
No se como hacerlo, gracias me gustaria aprender a ahacer algo asi.
Leer con php y extraer lo que desee, en este caso el rango del user
<?php
$nombreClan=$_POST['nombreClan'];
$tag=$_POST['tag'];
$miembro1=$_POST['miembro1'];
$miembro2=$_POST['miembro2'];
$miembro3=$_POST['miembro3'];
$miembro4=$_POST['miembro4'];
$miembro5=$_POST['miembro5'];
$link = mysql_connect("mysql12.000webhost.com","a6190584_data","database1");
mysql_select_db("a6190584_data",$link);
mysql_query("INSERT INTO clanes (nombreClan,tag,miembro1,miembro2,miembro3,miembro4,miembro5)
VALUES ('$nombreClan','$tag','$miembro1','$miembro2','$miembro3','$miembro4','$miembro5',$link)");
// Ahora comprobaremos que todo ha ido correctamente
$my_error = mysql_error($link);
if(!empty($my_error)) {
echo "Ha habido un error al insertar los valores. $my_error";
}
?>
error
Ha habido un error al insertar los valores. You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'id #8)' at line 2
A mi me salvo el dia hoy la de quitar saltos de linea:
$sinsalto = eregi_replace("[\n|\r|\n\r]", ' ', $consalto);
muy util cuando deseamos pasar esa variable a javascript a travez de varias ventanas. para objetos recomiendo json_encode.
eregi_replace esta obsoleta creo, o si no lo esta... es muy desaconsejable usarla.
Es mejor utlizar preg_match o preg_match_all.
Un saludo!
Retorna la conversión de números a letras.
<?php
class EnLetras
{
var $Void = "";
var $SP = " ";
var $Dot = ".";
var $Zero = "0";
var $Neg = "Menos";
function ValorEnLetras($x, $Moneda )
{
$s="";
$Ent="";
$Frc="";
$Signo="";
if(floatVal($x) < 0)
$Signo = $this->Neg . " ";
else
$Signo = "";
if(intval(number_format($x,2,'.','') )!=$x) //<- averiguar si tiene decimales
$s = number_format($x,2,'.','');
else
$s = number_format($x,0,'.','');
$Pto = strpos($s, $this->Dot);
if ($Pto === false)
{
$Ent = $s;
$Frc = $this->Void;
}
else
{
$Ent = substr($s, 0, $Pto );
$Frc = substr($s, $Pto+1);
}
if($Ent == $this->Zero || $Ent == $this->Void)
$s = "Cero ";
elseif( strlen($Ent) > 7)
{
$s = $this->SubValLetra(intval( substr($Ent, 0, strlen($Ent) - 6))) .
"Millones " . $this->SubValLetra(intval(substr($Ent,-6, 6)));
}
else
{
$s = $this->SubValLetra(intval($Ent));
}
if (substr($s,-9, 9) == "Millones " || substr($s,-7, 7) == "Millón ")
$s = $s . "de ";
$s = $s . $Moneda;
if($Frc != $this->Void)
{
$s = $s . " Con " . $this->SubValLetra(intval($Frc)) . "Centavos";
//$s = $s . " " . $Frc . "/100";
}
//return ($Signo . $s . " M.N.");
return ($Signo . $s);
}
function SubValLetra($numero)
{
$Ptr="";
$n=0;
$i=0;
$x ="";
$Rtn ="";
$Tem ="";
$x = trim("$numero");
$n = strlen($x);
$Tem = $this->Void;
$i = $n;
while( $i > 0)
{
$Tem = $this->Parte(intval(substr($x, $n - $i, 1).
str_repeat($this->Zero, $i - 1 )));
If( $Tem != "Cero" )
$Rtn .= $Tem . $this->SP;
$i = $i - 1;
}
//--------------------- GoSub FiltroMil ------------------------------
$Rtn=str_replace(" Mil Mil", " Un Mil", $Rtn );
while(1)
{
$Ptr = strpos($Rtn, "Mil ");
If(!($Ptr===false))
{
If(! (strpos($Rtn, "Mil ",$Ptr + 1) === false ))
$this->ReplaceStringFrom($Rtn, "Mil ", "", $Ptr);
Else
break;
}
else break;
}
//--------------------- GoSub FiltroCiento ------------------------------
$Ptr = -1;
do{
$Ptr = strpos($Rtn, "Cien ", $Ptr+1);
if(!($Ptr===false))
{
$Tem = substr($Rtn, $Ptr + 5 ,1);
if( $Tem == "M" || $Tem == $this->Void)
;
else
$this->ReplaceStringFrom($Rtn, "Cien", "Ciento", $Ptr);
}
}while(!($Ptr === false));
//--------------------- FiltroEspeciales ------------------------------
$Rtn=str_replace("Diez Un", "Once", $Rtn );
$Rtn=str_replace("Diez Dos", "Doce", $Rtn );
$Rtn=str_replace("Diez Tres", "Trece", $Rtn );
$Rtn=str_replace("Diez Cuatro", "Catorce", $Rtn );
$Rtn=str_replace("Diez Cinco", "Quince", $Rtn );
$Rtn=str_replace("Diez Seis", "Dieciseis", $Rtn );
$Rtn=str_replace("Diez Siete", "Diecisiete", $Rtn );
$Rtn=str_replace("Diez Ocho", "Dieciocho", $Rtn );
$Rtn=str_replace("Diez Nueve", "Diecinueve", $Rtn );
$Rtn=str_replace("Veinte Un", "Veintiun", $Rtn );
$Rtn=str_replace("Veinte Dos", "Veintidos", $Rtn );
$Rtn=str_replace("Veinte Tres", "Veintitres", $Rtn );
$Rtn=str_replace("Veinte Cuatro", "Veinticuatro", $Rtn );
$Rtn=str_replace("Veinte Cinco", "Veinticinco", $Rtn );
$Rtn=str_replace("Veinte Seis", "Veintiseís", $Rtn );
$Rtn=str_replace("Veinte Siete", "Veintisiete", $Rtn );
$Rtn=str_replace("Veinte Ocho", "Veintiocho", $Rtn );
$Rtn=str_replace("Veinte Nueve", "Veintinueve", $Rtn );
//--------------------- FiltroUn ------------------------------
If(substr($Rtn,0,1) == "M") $Rtn = "Un " . $Rtn;
//--------------------- Adicionar Y ------------------------------
for($i=65; $i<=88; $i++)
{
If($i != 77)
$Rtn=str_replace("a " . Chr($i), "* y " . Chr($i), $Rtn);
}
$Rtn=str_replace("*", "a" , $Rtn);
return($Rtn);
}
function ReplaceStringFrom(&$x, $OldWrd, $NewWrd, $Ptr)
{
$x = substr($x, 0, $Ptr) . $NewWrd . substr($x, strlen($OldWrd) + $Ptr);
}
function Parte($x)
{
$Rtn='';
$t='';
$i='';
Do
{
switch($x)
{
Case 0: $t = "Cero";break;
Case 1: $t = "Un";break;
Case 2: $t = "Dos";break;
Case 3: $t = "Tres";break;
Case 4: $t = "Cuatro";break;
Case 5: $t = "Cinco";break;
Case 6: $t = "Seis";break;
Case 7: $t = "Siete";break;
Case 8: $t = "Ocho";break;
Case 9: $t = "Nueve";break;
Case 10: $t = "Diez";break;
Case 20: $t = "Veinte";break;
Case 30: $t = "Treinta";break;
Case 40: $t = "Cuarenta";break;
Case 50: $t = "Cincuenta";break;
Case 60: $t = "Sesenta";break;
Case 70: $t = "Setenta";break;
Case 80: $t = "Ochenta";break;
Case 90: $t = "Noventa";break;
Case 100: $t = "Cien";break;
Case 200: $t = "Doscientos";break;
Case 300: $t = "Trescientos";break;
Case 400: $t = "Cuatrocientos";break;
Case 500: $t = "Quinientos";break;
Case 600: $t = "Seiscientos";break;
Case 700: $t = "Setecientos";break;
Case 800: $t = "Ochocientos";break;
Case 900: $t = "Novecientos";break;
Case 1000: $t = "Mil";break;
Case 1000000: $t = "Millón";break;
}
If($t == $this->Void)
{
$i = $i + 1;
$x = $x / 1000;
If($x== 0) $i = 0;
}
else
break;
}while($i != 0);
$Rtn = $t;
Switch($i)
{
Case 0: $t = $this->Void;break;
Case 1: $t = " Mil";break;
Case 2: $t = " Millones";break;
Case 3: $t = " Billones";break;
}
return($Rtn . $t);
}
}
?>
Forma de uso:
La funcion ValorEnLetras nos exige 2 parámetros entre ellos las siglas de la moneda y el valor.
$num = 1200;
$valor=new EnLetras();
$literal = $valor->ValorEnLetras($num,"$USD");
echo $literal;
La función ValorEnLetras también puede enviar su segundo parámetro en blanco.
$literal = $valor->ValorEnLetras($num,"");
Saludos