android: JsonObject getString 一个神奇的问题

2016-05-06 23:01:14 +08:00
 vik0313

JsonObject data = { "id" : 123 }

打包签名 APK : data.getString("id") = null

eclipse 直接跑真机: data.getString("id") = “ 123 ”

为什么会有这样的区别呢?

。。。。 。。。 。。 。 坑

2184 次点击
所在节点    问与答
7 条回复
hinkal
2016-05-07 00:53:44 +08:00
你应该学会用 google “ android release apk null gson ”第一个结果 stackoverflow 就是,我提问的。 http://stackoverflow.com/questions/30001674/gson-deserialize-null-pointer-in-released-apk
hinkal
2016-05-07 00:55:22 +08:00
直接说下吧,因为代码混淆后 json 解析库中反射会失败,解决方法就是加 annotation
vik0313
2016-05-07 11:55:11 +08:00
@hinkal 这个问题再怎么 google 也不会想到 “ android release apk null gson ”,一开始是怀疑混淆的问题的,但后来觉得不大可能是混淆的原因,是因为在另一个项目,也是一样的代码,没有出现这种问题。
public static String V(JSONObject data, String key) {
try {
return "null".equals(data.getString(key)) ? "" : data
.getString(key);
} catch (Exception e) {
return "";
}
}
我有一个 Helper 的类写了一个这样的方法去 V, 然后就
String id = Helper.V(data, "id"),请教下这种情况怎么加 annotation 呢?谢谢!
vik0313
2016-05-07 12:01:39 +08:00
@hinkal 另外,我用的 eclipse 开发的,不知道会不会有不一样的地方?
hinkal
2016-05-07 12:51:10 +08:00
是我搞错了,你用的是 org.json 的 JsonObject 啊, fastjson 也有一个同名类,你直接获取属性理论上不会出错(我试了你相同代码打包 apk 没有出错),因为都没有解析成对象,和反射没有关系。因此我就不知道为什么了。
vik0313
2016-05-07 18:29:03 +08:00
@hinkal 后来再对比了之前的项目,猛然想起,会不会是编译环境不一样,然后看了下, java compiler 是 1.7 ,我之前的项目是 1.6 的,改成 1.6 就好了
vik0313
2016-05-08 23:04:40 +08:00
@hinkal 更正下,跟 1.6 还是 1.7 是没关的,都不知啥时候引用了一个 java-json.jar 的 lib ,把这个 lib 删了再打包就好了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/276870

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX