elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: AIO elhacker.NET 2021 Compilación herramientas análisis y desinfección malware


  Mostrar Temas
Páginas: [1]
1  Programación / Java / Configuración Service Provider SAML2 en Java en: 19 Julio 2016, 15:58 pm
Buenas gente,

Estoy un poco perdido en el tema de SAML y necesito que me iluminéis :(

Supongamos que tengo un método de una clase al cual le llega un String y me gustaría mandar este String a un IdP para que me diga si es correcto o no sin más. Simplemente tendría que configurar la parte SP para enviar este String mediante SAML a la URL del IdP....pues bien, estoy leyendo miles de cosas y no me queda muy claro el tema xD

He encontrado este código.
Código
  1. import java.io.StringReader;
  2. import java.text.SimpleDateFormat;
  3. import java.util.*;
  4. import javax.xml.parsers.*;
  5. import org.w3c.dom.*;
  6. import org.xml.sax.InputSource;
  7.  
  8. public class Example2 {
  9. private static final String reqMsg =
  10. "<samlp:AttributeQuery " +
  11. " xmlns:samlp='urn:oasis:names:tc:SAML:2.0:protocol' " +
  12. " ID='%%ID%%' IssueInstant='%%ISSUEINST%%' Version='2.0'>" +
  13. " <saml:Issuer xmlns:saml='urn:oasis:names:tc:SAML:2.0:assertion'>"
  14. +
  15. "%%ISSUER%%" +
  16. " </saml:Issuer>" +
  17. " <saml:Subject xmlns:saml='urn:oasis:names:tc:SAML:2.0:assertion'>"
  18. +
  19. " <saml:NameID Format='urn:oasis:names:tc:SAML:2.0:nameid-format:
  20. unspecified'" +
  21. " xmlns:saml='urn:oasis:names:tc:SAML:2.0:assertion'> " +
  22. "%%SUBJECT%%" +
  23. " </saml:NameID>" +
  24. " </saml:Subject>" +
  25. "</samlp:AttributeQuery>";
  26.  
  27. public static String getAttributeRequest(String id, String issuer, String subject) {
  28.  
  29. Calendar cal = Calendar.getInstance(TimeZone.getTimeZone("US/Arizona"));
  30. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  31. SimpleDateFormat sdfTime = new SimpleDateFormat("HH:mm:ss");
  32. String res = Example2.reqMsg
  33. res = res.replaceAll("%%ID%%", id);
  34. res = res.replaceAll("%%ISSUEINST%%", sdf.format(cal.getTime()) +
  35. "T" +
  36. sdfTime.format(cal.getTime()) + "Z");
  37. res = res.replaceAll("%%ISSUER%%", issuer);
  38. res = res.replaceAll("%%SUBJECT%%", subject);
  39. return res;
  40. }
  41.  
  42. public static Element getElementFromString(String s) throws Exception {
  43. DocumentBuilderFactory factory = DocumentBuilderFactory.
  44. newInstance();
  45. factory.setNamespaceAware(true);
  46. DocumentBuilder builder = factory.newDocumentBuilder();
  47. InputSource is = new InputSource(new StringReader(s));
  48. Document d = builder.parse(is);
  49. return d.getDocumentElement();
  50. }
  51. public static void main(String[] args) throws Exception {
  52. String id = UUID.randomUUID().toString();
  53. String issuer = "http://www.prise.es/uoc-book/example2";
  54. String subject = "cr01";
  55. String reqMsg = getAttributeRequest(id, issuer, subject);
  56. System.out.println(reqMsg);
  57. Element req = getElementFromString(reqMsg);
  58. }
  59. }

Yo me había metido la librería OpenSAML2.6.0 para trastear pero bueno, en este código como lo pone todo en un String no hace falta (no sé cómo se haría más fácil).

Entiendo que en el ISSUER debo poner la URL de mi IdP, pero no me queda claro varias cosas:

  • ¿Mi String dónde lo meto?
  • ¿Dónde recojo la respuesta? Porque he leído que para recoger las respuestas se hacen mediante Assertion, pero no sé si tengo que configurar algo o puedo hacerlo todo en la misma clase

Seguramente esté diciendo alguna burrada o algo por el estilo y pido disculpas por ello, pero es que me está costando más de lo que pensaba.

Un saludo y gracias de antemano!
2  Programación / Java / Unificar código en clase abstracta en: 14 Enero 2015, 16:04 pm
Buenas tardes,

Tengo un problemilla con un tema y creo que es porque no tengo claro algunos conceptos.

Lo que tengo que hacer es unificar el código idéntico de 2 clases en otra clase abstracta para evitar duplicar el código.

Suponiendo que en Class1 y en Class2 hay 2 métodos (Metodo1 y Metodo2) que comparten código, sería meter ese código en una tercera clase abstracta (AbstractClass) para unificar el código y así cuando haya que modificar algo sólo se modifique en un sitio. El problema que tengo es que no se cómo tengo que llamar a los métodos de la clase abstracta desde las otras clases ya que yo tenía entendido que en la clase abstracta sólo se ponía el método (sin implementar código) y desde cada clase se controlaba el comportamiento.

Pues bien...yo he pensado en esto (de forma resumida):

AbstractClass
Código:
public abstract class AbstractClass{
              public boolean Metodo1 {
                    bla bla bla bla......
                    return true;
              }
              public boolean Metodo2 {
                    bla bla bla bla......
                    return false;
              }
}

Class1
Código:
public class Class1 extends AbstractClass{
              public boolean Metodo1();
              public boolean Metodo2();
}

Class2
Código:
public  Class2 extends AbstractClass{
              public boolean Metodo1();
              public boolean Metodo2();
}

¿Cómo debería hacerlo?

Muchas gracias de antemano!
3  Programación / Java / Desplegar proyectos relacionados en: 27 Octubre 2014, 12:30 pm
Buenos días,

Ahora mismo tengo 2 proyectos Maven (Proyecto A y Proyecto B). En el pom.xml del Proyecto A tengo añadida la dependencia del Proyecto B. Con esta situación me gustaría crear un .war para meterlo en Tomcat y poder probar la aplicación.

Si genero el .war del Proyecto A desde Maven (mvn package) y lo pruebo, me dice que no encuentra la clase que hace referencia a la que hay en Proyecto B.

¿Qué debería de hacer para generar un .war que contenga todo lo del Proyecto A y Proyecto B?

Muchas gracias por la ayuda.
4  Programación / Programación General / Petición JSON en Java en: 29 Septiembre 2014, 15:49 pm
Buenas,

Antes de nada decir que no pido una solución, sino simplemente una idea de lo que debería de hacer, ya que estoy un poco verde en este tema.

Mi problema es el siguiente:

Tengo que mostrar en el navegador una tabla (esto no hay problema xD), y que al cargar la tabla se invoque una URL mediante JSON que recupere los datos de una Base de Datos y los muestres en la tabla.

Probablemente sea una tontería pero ahora mismo no se por donde agarrarlo.

¿Alguien me podría guiar en los pasos que debo seguir para conseguir esto?

Muchas gracias de antemano.

Edit: Perdón, lo quería poner en el foro de Java y sin querer lo he puesto en Programación General.
5  Programación / Java / Configurar Hibernate con BBDD DerbyEmbedded en: 29 Septiembre 2014, 12:25 pm
Buenos días a todos

Mi problema es el siguiente. Estoy intentando configurar Hibernate con una BBDD Derby Embedded pero no lo consigo. En el momento en el que ejecuto el buildSessionFactory del sessionFactory me salta una excepción.

http://imgur.com/SKNQJit

Según he leído este error puede ser ocasionado por el Dialecto del archivo de configuración de Hibernate, pero he probado DerbyTenFiveDialect, DerbyTenSixDialect y DerbyTenSevenDialect y el problema continua.

Actualmente mi archivo Hibernate.cfg.xml está así:

<property name="connection.driver_class">org.apache.derby.jdbc.EmbeddedDriver</property>
<property name="connection.url">jdbc:derby:MyDB</property>
<property name="connection.username">master</property>
<property name="connection.password">master</property>
<property name="hibernate.default_schema">my_application</property>
<property name="connection.pool_size">1</property>
<property name="dialect">org.hibernate.dialect.DerbyTenSixDialect</property>
<property name="show_sql">true</property>
<property name="hbm2ddl.auto">update</property>
<mapping resource="com/configuracion/hibernate/catalogos.hbm.xml" />

¿Alguien sabría a qué puede ser debido?

Muchas gracias de antemano.
Páginas: [1]
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines