Java中的serialize接口与transient关键字

  1. package com.jd;

  2. import java.io.FileInputStream;
  3. import java.io.FileOutputStream;
  4. import java.io.ObjectInputStream;
  5. import java.io.ObjectOutputStream;
  6. import java.util.Date;

  7. public class App {
  8. public static void main(String[] args) {
  9. //现在我们创建一个类的实例,并且串行化(serialize)它,然后将这个串行化对象写入磁盘

  10. LoggingInfo logInfo = new LoggingInfo("MIKE", "MECHANICS");
  11. System.out.println(logInfo.toString());
  12. try {
  13. ObjectOutputStream o = new ObjectOutputStream(new FileOutputStream("logInfo.out"));
  14. o.writeObject(logInfo);
  15. o.close();
  16. } catch (Exception e) {
  17. }
  18. //读出上面写入文件中的串行化对像,发现transient标识的pwd属性值并不会被存储

  19. try {
  20. ObjectInputStream in = new ObjectInputStream(
  21. new FileInputStream("logInfo.out"));
  22. logInfo = (LoggingInfo) in.readObject();
  23. System.out.println(logInfo.toString());
  24. }
  25. catch (Exception e) {
  26. }
  27. }

  28. static class LoggingInfo implements java.io.Serializable {
  29. private Date loggingDate = new Date();
  30. private String uid;
  31. private transient String pwd;

  32. LoggingInfo(String user, String password) {
  33. uid = user;
  34. pwd = password;
  35. }

  36. public String toString() {
  37. String password = null;
  38. if (pwd == null) {
  39. password = "NOT SET";
  40. } else {
  41. password = pwd;
  42. }
  43. return "logon info: " + "user: " + uid +
  44. " logging date : " + loggingDate.toString() +
  45. " password: " + password;
  46. }
  47. }
  48. }
总之,transient关键字是为了安全性,防止这种类型的数据在IO中存储(例如网络传输或本地存盘)
阅读(1614) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~
评论热议
原文地址:https://www.cnblogs.com/black/p/5171865.html