當前位置: 首頁>>代碼示例>>Java>>正文


Java PickleSerializer類代碼示例

本文整理匯總了Java中net.razorvine.pyro.serializer.PickleSerializer的典型用法代碼示例。如果您正苦於以下問題:Java PickleSerializer類的具體用法?Java PickleSerializer怎麽用?Java PickleSerializer使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


PickleSerializer類屬於net.razorvine.pyro.serializer包,在下文中一共展示了PickleSerializer類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testUnpickleMemo

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testUnpickleMemo() throws PickleException, IOException {
	// the pickle is of the following list: [65, 'hello', 'hello', {'recurse': [...]}, 'hello']
	// i.e. the 4th element is a dict referring back to the list itself and the 'hello' strings are reused
	byte[] pickle = new byte[]
		{(byte) 128, 2, 93, 113, 0, 40, 75, 65, 85, 5, 104, 101, 108, 108, 111, 113, 1, 104, 1, 125, 113, 2,
		85, 7, 114, 101, 99, 117, 114, 115, 101, 113, 3, 104, 0, 115, 104, 1, 101, 46};
	PyroSerializer ser = new PickleSerializer();
	ArrayList<Object> a = (ArrayList<Object>) ser.deserializeData(pickle);
	assertEquals(5, a.size());
	assertEquals(65, a.get(0));
	assertEquals("hello", a.get(1));
	assertSame(a.get(1), a.get(2));
	assertSame(a.get(1), a.get(4));
	HashMap<String, Object> h = (HashMap<String,Object>) a.get(3);
	assertSame(a, h.get("recurse"));
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:18,代碼來源:UnpicklerComplexTest.java

示例2: testUnpickleUnsupportedClass

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testUnpickleUnsupportedClass() throws IOException {
	// an unsupported class is mapped to a dictionary containing the class's attributes, and a __class__ attribute with the name of the class
	byte[] pickled = new byte[] {
			(byte)128, 2, 99, 95, 95, 109, 97, 105, 110, 95, 95, 10, 67, 117, 115, 116, 111, 109, 67, 108,
			97, 115, 115, 10, 113, 0, 41, (byte)129, 113, 1, 125, 113, 2, 40, 85, 3, 97, 103, 101, 113, 3,
			75, 34, 85, 6, 118, 97, 108, 117, 101, 115, 113, 4, 93, 113, 5, 40, 75, 1, 75, 2, 75, 3,
			101, 85, 4, 110, 97, 109, 101, 113, 6, 85, 5, 72, 97, 114, 114, 121, 113, 7, 117, 98, 46};

	PyroSerializer ser = new PickleSerializer();
	Map<String, Object> o = (Map<String, Object>) ser.deserializeData(pickled);
	assertEquals(4, o.size());
	assertEquals("Harry", o.get("name"));
	assertEquals(34, o.get("age"));
	ArrayList<Object> expected = new ArrayList<Object>() {{
		add(1);
		add(2);
		add(3);
	}};
	assertEquals(expected, o.get("values"));
	assertEquals("__main__.CustomClass", o.get("__class__"));
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:23,代碼來源:UnpicklerComplexTest.java

示例3: testUnpickleCustomClassAsClassDict

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testUnpickleCustomClassAsClassDict() throws IOException {
	byte[] pickled = new byte[] {
			(byte)128, 2, 99, 95, 95, 109, 97, 105, 110, 95, 95, 10, 67, 117, 115, 115, 115, 115, 115, 115,
			97, 122, 122, 10, 113, 0, 41, (byte)129, 113, 1, 125, 113, 2, 40, 85, 3, 97, 103, 101, 113, 3,
			75, 34, 85, 6, 118, 97, 108, 117, 101, 115, 113, 4, 93, 113, 5, 40, 75, 1, 75, 2, 75, 3,
			101, 85, 4, 110, 97, 109, 101, 113, 6, 85, 5, 72, 97, 114, 114, 121, 113, 7, 117, 98, 46};
	
	PyroSerializer ser = new PickleSerializer();
	ClassDict cd = (ClassDict) ser.deserializeData(pickled);
	assertEquals("__main__.Cussssssazz", cd.get("__class__"));
	assertEquals("Harry", cd.get("name"));
	assertEquals(34, cd.get("age"));
	ArrayList<Object> expected = new ArrayList<Object>() {{
		add(1);
		add(2);
		add(3);
	}};
	assertEquals(expected, cd.get("values"));
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:21,代碼來源:UnpicklerComplexTest.java

示例4: testUnpickleCustomClass

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testUnpickleCustomClass() throws IOException {
	byte[] pickled = new byte[] {
			(byte)128, 2, 99, 95, 95, 109, 97, 105, 110, 95, 95, 10, 67, 117, 115, 116, 111, 109, 67, 108,
			97, 122, 122, 10, 113, 0, 41, (byte)129, 113, 1, 125, 113, 2, 40, 85, 3, 97, 103, 101, 113, 3,
			75, 34, 85, 6, 118, 97, 108, 117, 101, 115, 113, 4, 93, 113, 5, 40, 75, 1, 75, 2, 75, 3,
			101, 85, 4, 110, 97, 109, 101, 113, 6, 85, 5, 72, 97, 114, 114, 121, 113, 7, 117, 98, 46};
	
	Unpickler.registerConstructor("__main__","CustomClazz", new CustomClazzConstructor());
	PyroSerializer ser = new PickleSerializer();
	CustomClazz o = (CustomClazz) ser.deserializeData(pickled);
	assertEquals("Harry" ,o.name);
	assertEquals(34 ,o.age);
	ArrayList<Object> expected = new ArrayList<Object>() {{
		add(1);
		add(2);
		add(3);
	}};
	assertEquals(expected, o.values);
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:21,代碼來源:UnpicklerComplexTest.java

示例5: testUnpickleException

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testUnpickleException() throws IOException {
	PyroSerializer ser = new PickleSerializer();

	// python 2.x
	PythonException x = (PythonException) ser.deserializeData("cexceptions\nZeroDivisionError\np0\n(S'hello'\np1\ntp2\nRp3\n.".getBytes());
	assertEquals("hello", x.getMessage());
	// python 3.x
	x = (PythonException) ser.deserializeData("c__builtin__\nZeroDivisionError\np0\n(Vhello\np1\ntp2\nRp3\n.".getBytes());
	assertEquals("hello", x.getMessage());
	x = (PythonException) ser.deserializeData("cbuiltins\nZeroDivisionError\np0\n(Vhello\np1\ntp2\nRp3\n.".getBytes());
	assertEquals("hello", x.getMessage());

	// python 2.x
	x = (PythonException) ser.deserializeData("cexceptions\nGeneratorExit\np0\n(tRp1\n.".getBytes());
	assertNull(x.getMessage());
	// python 3.x
	x = (PythonException) ser.deserializeData("c__builtin__\nGeneratorExit\np0\n(tRp1\n.".getBytes());
	assertNull(x.getMessage());
	x = (PythonException) ser.deserializeData("cbuiltins\nGeneratorExit\np0\n(tRp1\n.".getBytes());
	assertNull(x.getMessage());
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:23,代碼來源:UnpicklerComplexTest.java

示例6: apply

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Override
public Object apply(WarpScriptStack stack) throws WarpScriptException {
  Object o = stack.pop();
  
  if (!(o instanceof byte[])) {
    throw new WarpScriptException(getName() + " expects a byte array on top of the stack.");
  }
  
  try {
    PickleSerializer serializer = new PickleSerializer();
    Object out = serializer.deserializeData((byte[]) o);
    stack.push(out);
  } catch (IOException ioe) {
    throw new WarpScriptException(ioe);
  }
  
  return stack;
}
 
開發者ID:cityzendata,項目名稱:warp10-platform,代碼行數:19,代碼來源:PICKLETO.java

示例7: testUnpickleProto0Bytes

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testUnpickleProto0Bytes() throws IOException, NoSuchAlgorithmException {
	InputStream is = this.getClass().getResourceAsStream("pickled_bytes_level0.dat");
	ByteArrayOutputStream bos = new ByteArrayOutputStream();
	int c;
	while((c = is.read())>=0) bos.write(c);
	is.close();
	byte[] pickle = bos.toByteArray();

	PickleSerializer ser = new PickleSerializer();
	String x = (String)ser.deserializeData(pickle);
	assertEquals(2496, x.length());
	
	// validate that the bytes in the string are what we expect (based on md5 hash)
	MessageDigest m = MessageDigest.getInstance("SHA1");
	m.update(x.getBytes("utf-8"));
	BigInteger digest = new BigInteger(1, m.digest());
	assertEquals("22f45b876383c91b1cb20afe51ee3b30f5a85d4c", digest.toString(16));
}
 
開發者ID:irmen,項目名稱:Pyrolite,代碼行數:20,代碼來源:UnpicklerComplexTest.java

示例8: testPyroClassesPickle

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testPyroClassesPickle() throws IOException
{
	PickleSerializer pickler = new PickleSerializer();
	PyroURI uri = new PyroURI("PYRO:[email protected]:4444");
	byte[] s = pickler.serializeData(uri);
	Object x = pickler.deserializeData(s);
	assertEquals(uri, x);

	PyroProxy proxy = new PyroProxy(uri);
	proxy.correlation_id = UUID.randomUUID();
	proxy.pyroHmacKey = "secret".getBytes();
	proxy.pyroHandshake = "apples";
	proxy.pyroAttrs = new HashSet<String>();
	proxy.pyroAttrs.add("attr1");
	proxy.pyroAttrs.add("attr2");
	s = pickler.serializeData(proxy);
	x = pickler.deserializeData(s);
	PyroProxy proxy2 = (PyroProxy) x;
	assertEquals(uri.host, proxy2.hostname);
	assertEquals(uri.objectid, proxy2.objectid);
	assertEquals(uri.port, proxy2.port);
	assertNull(proxy2.correlation_id); // correlation_id is not serialized on the proxy object")
	assertEquals(proxy.pyroHandshake, proxy2.pyroHandshake);
	assertArrayEquals(proxy.pyroHmacKey, proxy2.pyroHmacKey);
	assertEquals(2, proxy2.pyroAttrs.size());
	assertEquals(proxy.pyroAttrs, proxy2.pyroAttrs);
	
	PyroException ex = new PyroException("error");
	ex._pyroTraceback = "traceback";
	s = pickler.serializeData(ex);
	x = pickler.deserializeData(s);
	PyroException ex2 = (PyroException) x;
	assertEquals(ex.getMessage(), ex2.getMessage());
	assertEquals("traceback", ex2._pyroTraceback);
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:37,代碼來源:SerializePyroTest.java

示例9: testCompareLibVersions

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testCompareLibVersions()
{
	assertEquals(-1, PickleSerializer.compareLibraryVersions("1.2", "2"));
	assertEquals(-1, PickleSerializer.compareLibraryVersions("1.2", "2.5.6"));
	assertEquals(0, PickleSerializer.compareLibraryVersions("1.2", "1.2"));
	assertEquals(1, PickleSerializer.compareLibraryVersions("2", "1.2"));
	assertEquals(1, PickleSerializer.compareLibraryVersions("2.54.66", "1.2.3.4.99"));
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:10,代碼來源:SerializePyroTest.java

示例10: testPickleUnpickleProxy

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testPickleUnpickleProxy() throws IOException {
	PyroProxy proxy=new PyroProxy("hostname",9999,"objectid");
	proxy.pyroHmacKey = "secret".getBytes();
	PyroSerializer ser = new PickleSerializer();
	byte[] pickled_proxy=ser.serializeData(proxy);
	PyroProxy result = (PyroProxy) ser.deserializeData(pickled_proxy);
	assertEquals(proxy.hostname, result.hostname);
	assertEquals(proxy.objectid, result.objectid);
	assertEquals(proxy.port, result.port);
	assertArrayEquals("secret".getBytes(), result.pyroHmacKey);
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:13,代碼來源:UnpicklerComplexTest.java

示例11: unpickleRealProxy

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
private void unpickleRealProxy(String pickle_name) throws IOException
{
	InputStream is = this.getClass().getResourceAsStream(pickle_name);
	ByteArrayOutputStream bos = new ByteArrayOutputStream();
	int c;
	while((c = is.read())>=0) bos.write(c);
	is.close();
	byte[] pickled_proxy = bos.toByteArray();
	PyroSerializer ser = new PickleSerializer();
	PyroProxy proxy=(PyroProxy)ser.deserializeData(pickled_proxy);
	assertEquals("Pyro.NameServer",proxy.objectid);
	assertEquals("localhost",proxy.hostname);
	assertEquals(9090,proxy.port);
	assertEquals("hello", proxy.pyroHandshake);
	assertArrayEquals("secret".getBytes(), proxy.pyroHmacKey);
	
	Set<String> expectedSet = new HashSet<String>();
	assertEquals(expectedSet, proxy.pyroAttrs);
	expectedSet.clear();
	expectedSet.add("lookup");
	expectedSet.add("ping");
	expectedSet.add("register");
	expectedSet.add("remove");
	expectedSet.add("list");
	expectedSet.add("count");
	assertEquals(expectedSet, proxy.pyroMethods);
	expectedSet = new HashSet<String>();
	assertEquals(expectedSet, proxy.pyroOneway);
}
 
開發者ID:yncxcw,項目名稱:big-c,代碼行數:30,代碼來源:UnpicklerComplexTest.java

示例12: apply

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Override
public Object apply(WarpScriptStack stack) throws WarpScriptException {
  Object o = stack.pop();
  
  try {
    PickleSerializer serializer = new PickleSerializer();
    byte[] data = serializer.serializeData(o);
    stack.push(data);
  } catch (IOException ioe) {
    throw new WarpScriptException(ioe);
  }
  
  return stack;
}
 
開發者ID:cityzendata,項目名稱:warp10-platform,代碼行數:15,代碼來源:TOPICKLE.java

示例13: testPyroClassesPickle

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testPyroClassesPickle() throws IOException
{
	PickleSerializer pickler = new PickleSerializer();
	PyroURI uri = new PyroURI("PYRO:[email protected]:4444");
	byte[] s = pickler.serializeData(uri);
	Object x = pickler.deserializeData(s);
	assertEquals(uri, x);

	PyroProxy proxy = new PyroProxy(uri);
	proxy.correlation_id = UUID.randomUUID();
	proxy.pyroHmacKey = "secret".getBytes();
	proxy.pyroHandshake = "apples";
	proxy.pyroAttrs = new HashSet<String>();
	proxy.pyroAttrs.add("attr1");
	proxy.pyroAttrs.add("attr2");
	s = pickler.serializeData(proxy);
	x = pickler.deserializeData(s);
	PyroProxy proxy2 = (PyroProxy) x;
	assertEquals(uri.host, proxy2.hostname);
	assertEquals(uri.objectid, proxy2.objectid);
	assertEquals(uri.port, proxy2.port);
	assertNull(proxy2.correlation_id); // correlation_id is not serialized on the proxy object")
	assertEquals(proxy.pyroHandshake, proxy2.pyroHandshake);
	assertArrayEquals(proxy.pyroHmacKey, proxy2.pyroHmacKey);
	assertEquals(2, proxy2.pyroAttrs.size());
	assertEquals(proxy.pyroAttrs, proxy2.pyroAttrs);
	
	PyroException ex = new PyroException("error");
	ex._pyroTraceback = "traceback";
	s = pickler.serializeData(ex);
	x = pickler.deserializeData(s);
	PyroException ex2 = (PyroException) x;
	assertEquals("[Pyro4.errors.PyroError] error", ex2.getMessage());
	assertEquals("traceback", ex2._pyroTraceback);
}
 
開發者ID:irmen,項目名稱:Pyrolite,代碼行數:37,代碼來源:SerializePyroTest.java

示例14: unpickleRealProxy

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
private void unpickleRealProxy(String pickle_name) throws IOException
{
	InputStream is = this.getClass().getResourceAsStream(pickle_name);
	ByteArrayOutputStream bos = new ByteArrayOutputStream();
	int c;
	while((c = is.read())>=0) bos.write(c);
	is.close();
	byte[] pickled_proxy = bos.toByteArray();
	PyroSerializer ser = new PickleSerializer();
	PyroProxy proxy=(PyroProxy)ser.deserializeData(pickled_proxy);
	assertEquals("Pyro.NameServer",proxy.objectid);
	assertEquals("localhost",proxy.hostname);
	assertEquals(9090,proxy.port);
	assertEquals("hello", proxy.pyroHandshake);
	assertArrayEquals("secret".getBytes(), proxy.pyroHmacKey);
	
	Set<String> expectedSet = new HashSet<String>();
	assertEquals(expectedSet, proxy.pyroAttrs);
	expectedSet.clear();
	expectedSet.add("lookup");
	expectedSet.add("ping");
	expectedSet.add("register");
	expectedSet.add("remove");
	expectedSet.add("list");
	expectedSet.add("count");
	expectedSet.add("set_metadata");
	proxy.pyroMethods.removeAll(expectedSet);
	
	assertEquals(0, proxy.pyroMethods.size());
	expectedSet = new HashSet<String>();
	assertEquals(expectedSet, proxy.pyroOneway);
}
 
開發者ID:irmen,項目名稱:Pyrolite,代碼行數:33,代碼來源:UnpicklerComplexTest.java

示例15: testUnpickleException

import net.razorvine.pyro.serializer.PickleSerializer; //導入依賴的package包/類
@Test
public void testUnpickleException() throws IOException {
	PyroSerializer ser = new PickleSerializer();

	// python 2.x
	PythonException x = (PythonException) ser.deserializeData("cexceptions\nZeroDivisionError\np0\n(S'hello'\np1\ntp2\nRp3\n.".getBytes());
	assertEquals("[exceptions.ZeroDivisionError] hello", x.getMessage());
	assertEquals("exceptions.ZeroDivisionError", x.pythonExceptionType);

	// python 3.x
	x = (PythonException) ser.deserializeData("c__builtin__\nZeroDivisionError\np0\n(Vhello\np1\ntp2\nRp3\n.".getBytes());
	assertEquals("[__builtin__.ZeroDivisionError] hello", x.getMessage());
	assertEquals("__builtin__.ZeroDivisionError", x.pythonExceptionType);
	x = (PythonException) ser.deserializeData("cbuiltins\nZeroDivisionError\np0\n(Vhello\np1\ntp2\nRp3\n.".getBytes());
	assertEquals("[builtins.ZeroDivisionError] hello", x.getMessage());
	assertEquals("builtins.ZeroDivisionError", x.pythonExceptionType);

	// python 2.x
	x = (PythonException) ser.deserializeData("cexceptions\nGeneratorExit\np0\n(tRp1\n.".getBytes());
	assertEquals("[exceptions.GeneratorExit]", x.getMessage());
	assertEquals("exceptions.GeneratorExit", x.pythonExceptionType);
	// python 3.x
	x = (PythonException) ser.deserializeData("c__builtin__\nGeneratorExit\np0\n(tRp1\n.".getBytes());
	assertEquals("[__builtin__.GeneratorExit]", x.getMessage());
	assertEquals("__builtin__.GeneratorExit", x.pythonExceptionType);
	x = (PythonException) ser.deserializeData("cbuiltins\nGeneratorExit\np0\n(tRp1\n.".getBytes());
	assertEquals("[builtins.GeneratorExit]", x.getMessage());
	assertEquals("builtins.GeneratorExit", x.pythonExceptionType);
}
 
開發者ID:irmen,項目名稱:Pyrolite,代碼行數:30,代碼來源:UnpicklerComplexTest.java


注:本文中的net.razorvine.pyro.serializer.PickleSerializer類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。