Como empaquetar un directorio de un enlace simbólico

in Linux

Si queremos empaquetar un directorio usando un enlace simbólico que apunta a él, por ejemplo webmail -> webmail_20120430 :


tar cvfz webmail.tar.gz webmail

Sucederá que se empaquetará el enlace, no el directorio. Para que se empaquete el directorio hay que usar la opción “-h”:


tar cvfz webmail.tar.gz webmail -h

0 Comments

Como evitar los cierres continuos en sesiones SSH por inactividad

in Linux

Si al dejar una sesión sin actividad un rato y de repente se queda como bloqueada y esto es de manera continua.

Hay una forma de mantenerla activa para que no la cierre.

Hay que editar el fichero:

/etc/ssh/ssh_config

Y añadirle la siguiente linea:

ServerAliveInterval 5

Con el “5″ le estamos diciendo que mande una señal de actividad cada 5 segundos.

0 Comments

Como extraer los ficheros de un RPM o de un DEB

in Linux

Para los RPMs se necesitan dos utilidades de linea de comandos: rpm2cpio y cpio.

Los contenidos se extraen asi:

rpm2cpio mipaquete.rpm | cpio -vid

Para ver los ficheros contenidos sin extraerlos, se usa lo siguiente:

rpm2cpio mypackage.rpm | cpio -vt

Para los ficheros DEB, hay que aclarar que contienen 3 ficheros:

debian-binary
control.tar.gz
data.tar.gz

Los ficheros que se extraen estan en el “data.tar.gz”

El proceso se hace con dos pasos:


ar vx mipaquete.deb
tar -xzvf data.tar.gz

O si solo se quieren ver los ficheros:


ar vx mipaquete.deb
tar -tzvf data.tar.gz

0 Comments

Arrancar JBoss en el puerto 80 sin ser root ni usar apache

in JBoss, Linux

-Arrancar en puertos por debajo del 1024 sólo lo pueden hacer usuarios privilegiados, y no se quiere usar un usuario privilegiado porque si se toma el control de este proceso se tendran los mismos privilegios que dicho usuario.

-Se puede usa Apache con mod_proxy, mod_jk, mod_cluster,… esto esta muy bien para balancear o para ofrecer recursos con Apache, pero si lo único que queremos es cambiar el puerto es demasiado.

-Para hacer lo que dice el título vamos a usar IPTABLES para hacer redireccionamiento de puertos (80 -> 8080, 443 -> 8443).

Hay que ejecutar los siguientes comandos:

iptables -F
iptables -X
iptables -t nat -A OUTPUT -d localhost -p tcp --dport 80 -j REDIRECT --to-ports 8080
iptables -t nat -A OUTPUT -d -p tcp --dport 80 -j REDIRECT --to-ports 8080
iptables -t nat -A PREROUTING -d -p tcp --dport 80 -j REDIRECT --to-ports 8080
iptables -t nat -A OUTPUT -d localhost -p tcp --dport 443 -j REDIRECT --to-ports 8443
iptables -t nat -A OUTPUT -d -p tcp --dport 443 -j REDIRECT --to-ports 8443
iptables -t nat -A PREROUTING -d -p tcp --dport 443 -j REDIRECT --to-ports 8443
/etc/init.d/iptables save
/etc/init.d/iptables restart

Para que funcione del todo hay que añadir lo siguiente al “server.xml” del jbossweb:



0 Comments

Android: No veo en el file explorer los archivos del dispositivo

in Android

Si se tiene una rom basada en CyanogenMod y no se ven los ficheros del dispositivo con el “File Explorer” del ADT con Eclipse.

Hay que cambiar el fichero “/system/bin/toolbox” del dispositivo por el que viene en el emulador del SDK de la misma version de android que la del dispositivo. Se hace de la siguiente manera:

1.- Hay que sacar el fichero del emulador:

adb pull /system/bin/toolbox .

2.- Hay que reiniciar el dispositivo en modo recovery y montar desde ahi el “/system”.

3.- Hay que poner el fichero del emulador en el dispositivo:

adb push ./toolbox /system/bin/toolbox

4.- Entrar en el dispositivo, cambiarle los permisos y crear un link para el “ls”

adb shell
# cd /system/bin
# chmod +x toolbox
# ln -s toolbox ls

5.- Reiniciar el dispositivo

6.- Comprobar entrando al “File Explorer” del ADT que ya se ve el arbol de directorios.

0 Comments

Android: Como enviar emails sin pedirle al usuario que interactue

in Android

Para enviar emails en Android se lanzan Intents que piden la interacción del usuario. Pero si queremos enviar emails en aplicaciones empresariales para temas de debug y control de errores. No se le puede estar al usuario pidiendo que este enviando emails todo el rato.

Esto no se puede hacer directamente con las librerias que vienen con Android. Para poder hacer esto se puede usar un port que hay de las JavaMail para Android.

Para ello es necesario descargar los jar que salen aqui:

Y añadirlos como librerias a nuestro proyecto.

Despues necesitamos implementar una clase que use las javamail para enviar emails como en cualquier otra aplicación Java.

Aqui voy a poner un ejemplo de una clase con la que se pueden enviar email con ficheros adjuntos:
(Como regalo o modificación los adjuntos se envian comprimidos en zip)

package mypackage;

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.util.Date;
import java.util.Properties;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;

import javax.activation.CommandMap;
import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.activation.FileDataSource;
import javax.activation.MailcapCommandMap;
import javax.mail.BodyPart;
import javax.mail.Multipart;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;

/**
 * Clase para el envio email
 *
 */

public class Mail extends javax.mail.Authenticator {
	private String _user;
	private String _pass; 

	private String[] _to;
	private String _from; 

	private String _port;
	private String _sport; 

	private String _host; 

	private String _subject;
	private String _body; 

	private boolean _auth; 

	private boolean _debuggable; 

	private Multipart _multipart; 

	public Mail() {
		_host = "smtp.gmail.com"; // default smtp server
		_port = "465"; // default smtp port
		_sport = "465"; // default socketfactory port 

		_user = ""; // username
		_pass = ""; // password
		_from = ""; // email sent from
		_subject = ""; // email subject
		_body = ""; // email body 

		_debuggable = false; // debug mode on or off - default off
		_auth = true; // smtp authentication - default on 

		_multipart = new MimeMultipart(); 

		// There is something wrong with MailCap, javamail can not find a handler for the multipart/mixed part, so this bit needs to be added.
		MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap();
		mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html");
		mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml");
		mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain");
		mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed");
		mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822");
		CommandMap.setDefaultCommandMap(mc);
	} 

	public Mail(String user, String pass) {
		this(); 

		_user = user;
		_pass = pass;
	} 

	public boolean send() throws Exception {
		Properties props = _setProperties(); 

		if(!_user.equals("") && !_pass.equals("") && _to.length > 0 && !_from.equals("") && !_subject.equals("") && !_body.equals("")) {
			Session session = Session.getInstance(props, this); 

			MimeMessage msg = new MimeMessage(session); 

			msg.setFrom(new InternetAddress(_from)); 

			InternetAddress[] addressTo = new InternetAddress[_to.length];
			for (int i = 0; i < _to.length; i++) {
				addressTo[i] = new InternetAddress(_to[i]);
			}
			msg.setRecipients(MimeMessage.RecipientType.TO, addressTo); 

			msg.setSubject(_subject);
			msg.setSentDate(new Date()); 

			// setup message body
			BodyPart messageBodyPart = new MimeBodyPart();
			messageBodyPart.setText(_body);
			_multipart.addBodyPart(messageBodyPart); 

			// Put parts in message
			msg.setContent(_multipart); 

			// send email
			Transport.send(msg); 

			return true;
		} else {
			return false;
		}
	} 

	public void addAttachment(String filename) throws Exception { 

		// Antes de adjuntar el fichero se comprime en zip
		String outputFilename = filename+".zip";
		File outputFile = new File(outputFilename);
		FileOutputStream fos = new FileOutputStream(outputFile);
		File inputFile = new File(filename);
		BufferedInputStream fis =  new BufferedInputStream(new FileInputStream(inputFile)); 

		ZipOutputStream zos = new ZipOutputStream(new BufferedOutputStream(fos));
		try {

			byte[] buffer = new byte[1024];
			ByteArrayOutputStream stream = new ByteArrayOutputStream();
			int len1 = 0;
			while ((len1 = fis.read(buffer)) != -1) {
				stream.write(buffer, 0, len1);
			}				        

			byte[] bytes = stream.toByteArray();
			ZipEntry entry = new ZipEntry(outputFilename);
			zos.putNextEntry(entry);
			zos.write(bytes);
			zos.closeEntry();
		} finally {
			zos.close();
			fos.close();
			fis.close();
		}		

		// Se adjunta el zip
		BodyPart messageBodyPart = new MimeBodyPart();
		DataSource source = new FileDataSource(outputFilename);
		messageBodyPart.setDataHandler(new DataHandler(source));
		messageBodyPart.setFileName(filename); 

		_multipart.addBodyPart(messageBodyPart);
	} 

	@Override
	public PasswordAuthentication getPasswordAuthentication() {
		return new PasswordAuthentication(_user, _pass);
	} 

	private Properties _setProperties() {
		Properties props = new Properties(); 

		props.put("mail.smtp.host", _host); 

		if(_debuggable) {
			props.put("mail.debug", "true");
		} 

		if(_auth) {
			props.put("mail.smtp.auth", "true");
		} 

		props.put("mail.smtp.port", _port);
		props.put("mail.smtp.socketFactory.port", _sport);
		props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
		props.put("mail.smtp.socketFactory.fallback", "false"); 

		return props;
	} 

	// the getters and setters
	public String getBody() {
		return _body;
	} 

	public void setBody(String _body) {
		this._body = _body;
	} 

	public String getFrom() {
		return _from;
	} 

	public void setFrom(String _from) {
		this._from = _from;
	} 

	public String[] getTo() {
		return _to;
	} 

	public void setTo(String[] _to) {
		this._to = _to;
	} 

	public String getHost() {
		return _host;
	} 

	public void setHost(String _host) {
		this._host = _host;
	}   

	public String getPort() {
		return _port;
	} 

	public void setPort(String _port) {
		this._port = _port;
	}   

	public String getSport() {
		return _sport;
	} 

	public void setSport(String _sport) {
		this._sport = _sport;
	}   

	public String getSubject() {
		return _body;
	} 

	public void setSubject(String _subject) {
		this._subject = _subject;
	}
}

Un ejemplo de uso de esta clase podria ser el siguiente:

	/**
	 * Enviar un email con fichero adjunto
	 * */
	public static void send(String emailTo, String nameTo, String emailFrom, String nameFrom,
			String subject, String body, String fileName){

		Log.d("Mail","Enviando email con los datos: "+emailTo +" / "+nameTo +" / "+emailFrom +
				" / "+nameFrom +" / "+subject +" / "+body +" / "+fileName +" / ");

		Mail m = new Mail(); 

		String[] toArr = {emailTo};
		m.setTo(toArr);
		m.setFrom(emailFrom);
		m.setSubject(subject);
		m.setBody(body); 

		try { 

			m.addAttachment(fileName); 

			if(m.send()) {
				Log.i("Mail","Se ha enviado el email con los datos: "+emailTo +" / "+nameTo +" / "+emailFrom +
						" / "+nameFrom +" / "+subject +" / "+body +" / "+fileName +" / ");
			} else {
				Log.e("Mail","No se ha podido enviar el email con los datos: "+emailTo +" / "+nameTo +" / "+emailFrom +
						" / "+nameFrom +" / "+subject +" / "+body +" / "+fileName +" / ");
			}
		} catch(Exception e) {
			Log.e("Mail",("Ha habido algun problema con el email con los datos: "+emailTo +" / "+nameTo +" / "+emailFrom +
					" / "+nameFrom +" / "+subject +" / "+body +" / "+fileName +" / ");
		}     	

	}
0 Comments

Android: Como comprimir un archivo a Zip

in Android

	public void comprimirFichero(String filename) throws Exception {
		String outputFilename = filename+".zip";
		File outputFile = new File(outputFilename);
		FileOutputStream fos = new FileOutputStream(outputFile);
		File inputFile = new File(filename);
		BufferedInputStream fis =  new BufferedInputStream(new FileInputStream(inputFile)); 

		ZipOutputStream zos = new ZipOutputStream(new BufferedOutputStream(fos));
		try {

			byte[] buffer = new byte[1024];
			ByteArrayOutputStream stream = new ByteArrayOutputStream();
			int len1 = 0;
			while ((len1 = fis.read(buffer)) != -1) {
				stream.write(buffer, 0, len1);
			}				        

			byte[] bytes = stream.toByteArray();
			ZipEntry entry = new ZipEntry(outputFilename);
			zos.putNextEntry(entry);
			zos.write(bytes);
			zos.closeEntry();
		} finally {
			zos.close();
			fos.close();
			fis.close();
		}

          return outputFilename;
      }
0 Comments

“ADT requires ‘org.eclipse.wst.sse.core 0.0.0′ but it could not be found”

in Android

Si da este error al intentar instalar el plugin ADT en Eclipse, es porque no esta activo el repositorio necesario para encontrar esa dependencia. En el caso de Eclipse Indigo el siguiente:

http://download.eclipse.org/releases/indigo

Añadirlo en “Install software…” o activarlos en “Available Software” si ya estaba añadido.

0 Comments

Android Error : ‘Debug Certificate expired. Unknown Android Packaging Problem’

in Android

Si sale el siguiente error en Eclipse o si se trabaja directamente en linea de comandos:

"Error generating final archive: Debug Certificate expired on xx/xx/xxxx  XX:XX  Unknown Android Packaging Problem"

Este error da porque el SDK genera un certificado para para desarrollo que tiene una caducidad de 365 dias.

La solución es muy sencilla, ir a “~/.android” y eliminar el archivo “debug.keystore” el SDK generará uno nuevo.

0 Comments

Error: “Root contexts can not be deployed when the virtual host configuration has the welcome root enabled, disable it and redeploy”

in JBoss

Este error da cuando se intenta hacer el deploy de “ROOT.WAR” en un JBoss 7.

Para poder desactivar lo que nos indica hay que hacer lo siguiente.

Modificar en el sigiente fichero:

$JBOSS_HOME/standalone/configuration/standalone.xml

Cambiar la propiedad  enable-welcome-root=false en :

<subsystem xmlns=”urn:jboss:domain:web:1.0″ default-virtual-server=”default-host”>
<connector name=”http” scheme=”http” protocol=”HTTP/1.1″ socket-binding=”http”/>
<virtual-server name=”default-host” enable-welcome-root=”false”>
<alias name=”localhost” />
<alias name=”example.com” />
</virtual-server>
</subsystem>

0 Comments