redis保存对象

来源:互联网 发布:网络摄影机app 编辑:程序博客网 时间:2024/06/14 04:42

在Jedis开发中,我们很多时候希望直接把一个对象放到Redis中,然后在需要的时候取出来。Redis的key和value都支持二进制安全的字符串,存储Java对象不是问题,下面我们看一下如何来实现。

1要存储的对象
现在写一个很土的Java Bean,包含两个字段,id和name,类名叫做Person。为了实现序列化需求,该类实现Serializable接口。

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. public class Person implements Serializable {  
  2. private int id;  
  3. private String name;  
  4.   
  5. public Person(int id, String name) {  
  6.   this.id = id;  
  7.   this.name = name;  
  8. }  
  9.   
  10. public int getId() {  
  11.   return id;  
  12. }  
  13.   
  14. public String getName() {  
  15.   return name;  
  16. }  
  17.   
  18. }  

2序列化、反序列化
写一个序列化工具类,来提供对象的序列化和饭序列化的工作。代码如下:

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. public class SerializeUtil {  
  2. public static byte[] serialize(Object object) {  
  3. ObjectOutputStream oos = null;  
  4. ByteArrayOutputStream baos = null;  
  5. try {  
  6. //序列化  
  7. baos = new ByteArrayOutputStream();  
  8. oos = new ObjectOutputStream(baos);  
  9. oos.writeObject(object);  
  10. byte[] bytes = baos.toByteArray();  
  11. return bytes;  
  12. catch (Exception e) {  
  13. }  
  14. return null;  
  15. }  
  16.   
  17. public static Object unserialize(byte[] bytes) {  
  18. ByteArrayInputStream bais = null;  
  19. try {  
  20. //反序列化  
  21. bais = new ByteArrayInputStream(bytes);  
  22. ObjectInputStream ois = new ObjectInputStream(bais);  
  23. return ois.readObject();  
  24. catch (Exception e) {  
  25. }  
  26. return null;  
  27. }  
  28. }  


3写对象
将Person对象写入Redis中:

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. public void setObject() {  
  2. Person person = new Person(100"alan");  
  3. jedis.set("person:100".getBytes(), SerializeUtil.serialize(person));  
  4. person = new Person(101"bruce");  
  5. jedis.set("person:101".getBytes(), SerializeUtil.serialize(person));  
  6. }  

运行上面代码之后,我们到命令行窗口中读取该对象,看看有没有写入成功:

[sql] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. redis 127.0.0.1:6379> get person:100  
  2. "\xac\xed\x00\x05sr\x00\x15alanland.redis.Person\x05\xf4\x8d9A\xf4`\xb0\x02\x00\x02I\x00\x02idL\x00\x04namet\x00\x12Ljava/lang/String;xp\x00\x00\x00dt\x00\x04alan"  

可以取到序列化之后的值。

4取对象
用Jedis获取对象:

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. public Person getObject(int id) {  
  2. byte[] person = jedis.get(("person:" + id).getBytes());  
  3. return (Person) SerializeUtil.unserialize(person);  
  4. }  

测试一下上一步存入的两个对象:

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. Person person = test.getObject(100);  
  2. System.out.println(person.getId());  
  3. System.out.println(person.getName());  
  4. person = test.getObject(101);  
  5. System.out.println(person.getId());  
  6. System.out.println(person.getName());  

Java控制台输入:

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. 100  
  2. alan  
  3. 101  
  4. bruce  

由此可见,序列化对象在Redis中存取正确。

阅读全文
0 0
原创粉丝点击