Ip

Valida que un valor es una dirección IP válida. Por omisión, este lo valida como IPv4, pero hay una serie de diferentes opciones para validarlo como IPv6 y muchas otras combinaciones.

Aplica a propiedad o método
Opciones
Clase Symfony\Component\Validator\Constraints\Ip
Validador Symfony\Component\Validator\Constraints\IpValidator

Uso básico

  • YAML
    # src/BlogBundle/Resources/config/validation.yml
    Acme\BlogBundle\Entity\Author:
        properties:
            ipAddress:
                - Ip:
    
  • Annotations
    // src/Acme/BlogBundle/Entity/Author.php
    namespace Acme\BlogBundle\Entity;
    
    use Symfony\Component\Validator\Constraints as Assert;
    
    class Autor
    {
        /**
         * @Assert\Ip
         */
         protected $ipAddress;
    }
    
  • XML
    <!-- src/Acme/BlogBundle/Resources/config/validation.xml -->
    <class name="Acme\BlogBundle\Entity\Author">
        <property name="ipAddress">
            <constraint name="Ip" />
        </property>
    </class>
    
  • PHP
    // src/Acme/BlogBundle/Entity/Author.php
    namespace Acme\BlogBundle\Entity;
    
    use Symfony\Component\Validator\Mapping\ClassMetadata;
    use Symfony\Component\Validator\Constraints as Assert;
    
    class Autor
    {
        public static function loadValidatorMetadata(ClassMetadata $metadata)
        {
            $metadata->addPropertyConstraint('ipAddress', new Assert\Ip());
        }
    }
    

Opciones

version

tipo: string predefinido: 4

Esta determina exactamente cómo se valida la dirección IP y puede tomar uno de una serie de diferentes valores:

Todos los rangos

  • 4 — Valida direcciones IPv4
  • 6 — Valida direcciones IPv6
  • all — Valida todos los formatos IP

No hay rangos privados

  • 4_no_priv — Valida por IPv4, pero sin rangos IP privados
  • 6_no_priv — Valida por IPv6, pero sin rangos IP privados
  • all_no_priv — Valida todos los formatos IP, pero sin rangos IP privados

No hay rangos reservados

  • 4_no_res — Valida por IPv4, pero sin rangos IP reservados
  • 6_no_res — Valida por IPv6, pero sin rangos IP reservados
  • all_no_priv — Valida todos los formatos IP, pero sin rangos IP reservados

Sólo rangos públicos

  • 4_public — Valida por IPv4, pero sin rangos IP privados y reservados
  • 6_public — Valida por IPv6, pero sin rangos IP privados y reservados
  • all_public — Valida todos los formatos IP, pero sin rangos IP privados y reservados

message

tipo: string predefinido: This is not a valid IP address (Esta no es una dirección IP válida)

Este mensaje se muestra si la cadena no es una dirección IP válida.

Bifúrcame en GitHub