Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
嗝屁小孩纸
guide-rpc-framework
提交
914bbad9
G
guide-rpc-framework
项目概览
嗝屁小孩纸
/
guide-rpc-framework
与 Fork 源项目一致
从无法访问的项目Fork
通知
3
Star
1
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
guide-rpc-framework
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
914bbad9
编写于
11月 11, 2020
作者:
S
SnailClimb
提交者:
GitHub
11月 11, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #27 from TangMinXuan/master
[add] Add support for protostuff
上级
341ed955
11b4c987
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
56 addition
and
0 deletion
+56
-0
pom.xml
pom.xml
+2
-0
rpc-framework-simple/pom.xml
rpc-framework-simple/pom.xml
+11
-0
rpc-framework-simple/src/main/java/github/javaguide/serialize/protostuff/ProtostuffSerializer.java
.../javaguide/serialize/protostuff/ProtostuffSerializer.java
+42
-0
rpc-framework-simple/src/main/resources/META-INF/extensions/github.javaguide.serialize.Serializer
...META-INF/extensions/github.javaguide.serialize.Serializer
+1
-0
未找到文件。
pom.xml
浏览文件 @
914bbad9
...
...
@@ -23,6 +23,8 @@
<junit.platform.version>
1.5.2
</junit.platform.version>
<!--logging-->
<slf4j.version>
1.7.25
</slf4j.version>
<!-- protostuff -->
<protostuff.version>
1.7.2
</protostuff.version>
</properties>
<modules>
<module>
rpc-framework-simple
</module>
...
...
rpc-framework-simple/pom.xml
浏览文件 @
914bbad9
...
...
@@ -41,5 +41,16 @@
<artifactId>
spring-context
</artifactId>
<version>
${spring.version}
</version>
</dependency>
<!-- protostuff -->
<dependency>
<groupId>
io.protostuff
</groupId>
<artifactId>
protostuff-core
</artifactId>
<version>
${protostuff.version}
</version>
</dependency>
<dependency>
<groupId>
io.protostuff
</groupId>
<artifactId>
protostuff-runtime
</artifactId>
<version>
${protostuff.version}
</version>
</dependency>
</dependencies>
</project>
rpc-framework-simple/src/main/java/github/javaguide/serialize/protostuff/ProtostuffSerializer.java
0 → 100644
浏览文件 @
914bbad9
package
github.javaguide.serialize.protostuff
;
import
github.javaguide.remoting.dto.RpcMessage
;
import
github.javaguide.serialize.Serializer
;
import
io.protostuff.LinkedBuffer
;
import
io.protostuff.ProtostuffIOUtil
;
import
io.protostuff.Schema
;
import
io.protostuff.runtime.RuntimeSchema
;
/**
* @author TangMinXuan
* @createTime 2020年11月09日 20:13
*/
public
class
ProtostuffSerializer
implements
Serializer
{
/**
* Avoid re applying buffer space every time serialization
*/
private
static
LinkedBuffer
buffer
=
LinkedBuffer
.
allocate
(
LinkedBuffer
.
DEFAULT_BUFFER_SIZE
);
@SuppressWarnings
(
"unchecked"
)
@Override
public
byte
[]
serialize
(
Object
obj
)
{
Class
<?>
clazz
=
obj
.
getClass
();
Schema
schema
=
RuntimeSchema
.
getSchema
(
clazz
);
byte
[]
bytes
;
try
{
bytes
=
ProtostuffIOUtil
.
toByteArray
(
obj
,
schema
,
buffer
);
}
finally
{
buffer
.
clear
();
}
return
bytes
;
}
@Override
public
<
T
>
T
deserialize
(
byte
[]
bytes
,
Class
<
T
>
clazz
)
{
Schema
<
T
>
schema
=
RuntimeSchema
.
getSchema
(
clazz
);
T
obj
=
schema
.
newMessage
();
ProtostuffIOUtil
.
mergeFrom
(
bytes
,
obj
,
schema
);
return
obj
;
}
}
rpc-framework-simple/src/main/resources/META-INF/extensions/github.javaguide.serialize.Serializer
浏览文件 @
914bbad9
kyro=github.javaguide.serialize.kyro.KryoSerializer
protostuff=github.javaguide.serialize.protostuff.ProtostuffSerializer
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录