RPC、Http、TCP/IP、Socket之间的关系及定义
目的:
1、以某种存储形式使自定义对象持久化;
2、将对象从一个地方传递到另一个地方。
3、使程序更具维护性。
序列化:让其变成字符串等类型冻结
通俗讲,就是将代码数据冻结起来,打好包,使其不发生变化,数据持久化,所谓持久化,就是将代码数据以某种方式存储起来,常见的硬盘等,网络的传输过程也需要将数据序列化,写成字节流, 序列化:让其变成字符串等类型冻结
最常见举例:
JSON.stringify()将对象、数组转换成字符串 JSON.stristring(Object) 变成字符串
反序列化:将字符串变为对象,然后拿到相关的方法和属性等变量数据。
最常见举例:
JSON.parse()【从一个字符串中解析出json对象】,就是以 key 和 value 形式出现
JSON.parse(Object)
是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。之后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。
字节流是由字节组成的,字符流是由字符组成的. Java里字符由两个字节组成.字节流是最基本的,所有的InputStream和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化。在从字节流转化为字符流时,实际上就是byte[]转化为String时,public String(byte bytes[], String charsetName)有一个关键的参数字符集编码,通常我们都省略了,那系统就用操作系统默认的long
把一个Java对象写入到硬盘或者传输到网络上面的其它计算机,这时我们就需要自己去通过java把相应的对象写成转换成字节流。对于这种通用的操作,我们为什么不使用统一的格式呢?没错,这里就出现了java的序列化的概念。在Java的OutputStream类下面的子类ObjectOutputStream类就有对应的WriteObject(Object object) 其中要求对应的object实现了java的序列化的接口。
在使用tomcat开发JavaEE相关项目的时候,我们关闭tomcat后,相应的session中的对象就存储在了硬盘上,如果我们想要在tomcat重启的时能够从tomcat上面读取对应session中的内容,那么保存在session中的内容就必须实现相关的序列化操作,还有jdbc加载驱动用的就是反序列化,将字符串变为对象。
类某些属性不需要序列化,序列化和反序列化实现了的对象序列化,但是可以发现,操作时是将整个对象的所有属性序列化,那么transient关键字可以将某些内容不需要保存,就可以通过transient关键字来定义:private transient String title;此时title属性无法被序列化
public class Book implements Serializable{//序列化类:java.ioObjectOutputStream讲对象变为指定的二进制数据private static final long serialVersionUID = 1L;private String title;private double price;public Book(String tit,double pri){this.title=tit;this.price=pri;}public String toString() {Map hashMap = new HashMap();hashMap.put("Computer base", "6.2");hashMap.put("Computer webpage", "45.2");hashMap.put("Java", "105.2");hashMap.put("Andriod", "89.2");//第一种:使用keySet()方法遍历哈希表hashMap中的一些元素System.out.println("通过keySet()方法遍历key和value:");Set keys = hashMap.keySet();for (String key : keys) {String value= hashMap.get(key);System.out.println("BookName:"+ key + " ,BookPrice:" + value);}return "BookName:"+this.title+" ,BookPrice:"+this.price;}
}
将二进制数据换回原对象,构造方法:ObjectInputStream(InputStream in),方法: Object readObject() 从 ObjectInputStream 读取对象
public class Serialization {public static File file = null;public static void main(String[] args) throws Exception, IOException {file = new File("serialize.doc");//序列化到指定的文本ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream(file));oos.writeObject(new Book("Java Development",45.3)); oos.flush();oos.close();file = new File("serialize.doc");//反序列化到指定的文本ObjectInputStream ois=new ObjectInputStream(new FileInputStream(file));Object obj=ois.readObject();Book book=(Book) obj;System.out.println("\n By using the byte stream serialization operation, "+ "we can see the following information:\n"+book);ois.close();}}
1.使用Spring注解@ResponseBody
2.使用JSON框架(jackson、Gson、fastjson)等给前端返回json数据。
JSON
我们在后端将需要返回的数据通过json处理成json字符串后转为二进制在网络中传输,浏览器会解析为json字符串,进而我们可以再通过json将json字符串转换为对象。
json 是种很简洁的协议,但可惜的是,它只能传递基本的数型(int,long,string等)但不能传递byte类型
JSON(JavaScript Object Notation, JS对象简谱)是一种轻量级的数据交换格式。易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。它和xml一样都是一种数据交换格式。
将结果进行String 序列化传给前台或者远程发送
import com.alibaba.fastjson.JSONObject;
某个接口的实现方法内JSONObject jObject = new JSONObject();jObject.put("result", "fail");。。。。。。
return jObject.toJSONString();
json.stringify()和json.parse()