org.crazycake.shiro.serializer.StringSerializer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of shiro-redis Show documentation
Show all versions of shiro-redis Show documentation
shiro only provide the support of ehcache and concurrentHashMap. Here is an implement of redis cache can be used by shiro. Hope it will help you!
package org.crazycake.shiro.serializer;
import org.crazycake.shiro.exception.SerializationException;
import java.io.UnsupportedEncodingException;
public class StringSerializer implements RedisSerializer {
private static final String DEFAULT_CHARSET = "UTF-8";
/**
* Refer to https://docs.oracle.com/javase/8/docs/technotes/guides/intl/encoding.doc.html
* UTF-8, UTF-16, UTF-32, ISO-8859-1, GBK, Big5, etc
*/
private String charset = DEFAULT_CHARSET;
@Override
public byte[] serialize(String s) throws SerializationException {
try {
return (s == null ? null : s.getBytes(charset));
} catch (UnsupportedEncodingException e) {
throw new SerializationException("serialize error, string=" + s, e);
}
}
@Override
public String deserialize(byte[] bytes) throws SerializationException {
try {
return (bytes == null ? null : new String(bytes, charset));
} catch (UnsupportedEncodingException e) {
throw new SerializationException("deserialize error", e);
}
}
public String getCharset() {
return charset;
}
public void setCharset(String charset) {
this.charset = charset;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy