猿问

Java InetAddress 到 PostgreSQL inet,反之亦然

我想使用 PSQL inet 数据类型,但它不接受字符串 (getRemoteAddr()) 或 byte[] (InetAddress)。

有没有办法使用 Java 正确转换它?


白猪掌柜的
浏览 130回答 3
3回答

红颜莎娜

面临同样的问题。我能够使用 InetAddress 读取 Inet Postgres 类型,但在将相同的 InetAddress 类型插入具有 inet 类型的 postgres 时遇到错误。通过定义自定义休眠类型解决了它PgInet->    public class PgInet implements Serializable {    private InetAddress address;    public PgInet() {}    public PgInet(InetAddress address) {        this.address = address;    }    public InetAddress getAddress() {        return address;    }    @Override    public int hashCode() {        final int prime = 31;        int result = 1;        result = prime * result + ((address == null) ? 0 : address.hashCode());        return result;    }    @Override    public boolean equals(Object obj) {        if (this == obj) {            return true;        }        if (obj == null) {            return false;        }        if (!(obj instanceof PgInet)) {            return false;        }        PgInet other = (PgInet) obj;        if (address == null) {            if (other.address != null) {                return false;            }        } else if (!address.equals(other.address)) {            return false;        }        return true;    }    @Override    public String toString() {        StringBuilder builder = new StringBuilder();        builder.append("PgInet [address=");        builder.append(address);        builder.append("]");        return builder.toString();    }}PGInetType ->    public class PgInetType implements UserType {    public PgInetType() {}    @Override    public Object assemble(Serializable cached, Object owner) {        return deepCopy(cached);    }    @Override    public Object deepCopy(Object value) {        if (value != null) {            return new PgInet(((PgInet) value).getAddress());        }        return null;    }    @Override    public Serializable disassemble(Object value) {        return (value != null) ? (Serializable) deepCopy(value) : null;    }    @Override    public boolean equals(Object x, Object y) {        return x == y || ( x != null && y != null && x.equals( y ) );    }    @Override    public int hashCode(Object x) {        return (x != null) ? x.hashCode() : 0;    }    @Override    public boolean isMutable() {        return false;    }    @Override    public Object nullSafeGet(ResultSet rs, String[] names,                              SharedSessionContractImplementor session, Object owner) throws SQLException {        PgInet address = null;        String ipStr = rs.getString(names[0]);        if (ipStr != null) {            try {                address = new PgInet(InetAddress.getByName(ipStr));            } catch (UnknownHostException e) {                throw new HibernateException(e);            }        }        return address;    }    @Override    public void nullSafeSet(PreparedStatement st, Object value, int index,                            SharedSessionContractImplementor session) throws SQLException {        if (value == null) {            st.setNull(index, Types.VARCHAR);        }        else {            PGobject pgObj = new PGobject();            pgObj.setType("inet");            pgObj.setValue(((PgInet) value).getAddress().getHostAddress());            st.setObject(index, pgObj);        }    }    @Override    public Object replace(Object original, Object target, Object owner) {        return deepCopy(original);    }    @SuppressWarnings("rawtypes")    @Override    public Class returnedClass() {        return PgInet.class;    }    @Override    public int[] sqlTypes() {        return new int[] {Types.OTHER};    }}用法->@TypeDefs({        @TypeDef(name="pgInet", typeClass=PgInetType.class)})public class Test{    @Column(name = "ip")    @Type(type="pgInet")    private PgInet ip;}

互换的青春

只需调用 InetAddress.getByName(String host) 并传入您的文本 IP 地址。来自 JavaDoc:主机名可以是机器名,例如“java.sun.com”,也可以是其 IP 地址的文本表示。~ InetAddress javadoc如果你问的是从 IP 获取字符串:String getHostAddress() 以文本形式返回 IP 地址字符串。String getHostName() 获取此 IP 地址的主机名。

九州编程

我认为这与How to get inet in entity class in spring using hibernate是同一个问题。经过几天的研究,我发现 2022 年不需要重新发明轮子。有一个 lib vladmihalcea/hibernate-types implement Inet column type& Inet Hibernate Type。资源mvn 回购协议:https ://search.maven.org/search?q=g:com.vladmihalcea教程:https ://vladmihalcea.com/postgresql-inet-type-hibernate/GitHub:https ://github.com/vladmihalcea/hibernate-types教程中的示例@Entity(name = "Event")@Table(name = "event")@TypeDef(    name = "ipv4",    typeClass = PostgreSQLInetType.class,    defaultForType = Inet.class)public class Event {    @Id    @GeneratedValue    private Long id;     @Column(        name = "ip",        columnDefinition = "inet"    )    private Inet ip;     public Long getId() {        return id;    }     public Inet getIp() {        return ip;    }     public void setIp(String address) {        this.ip = new Inet(address);    }}spring-boot 2.7.1在,中按预期工作hibernate 5.6.9。
随时随地看视频慕课网APP

相关分类

Java
我要回答