jsondeserializer(jsondeserializer get set c#)

http://www.itjxue.com  2023-01-27 21:22  来源:未知  点击次数: 

Unable to execute dex: Multiple dex files defineLcom/google/gson/JsonDeserializer;

这个错误是由于错误的添加了不必要的core library或重复添加了同一个library jar包产生冲突造成的。

我之前也试过,我是多添加了Android.jar之后报错,把不要用掉的包给去掉就好了。我本来把android.jar已经单独弄成了一个User Library了,最后还用add extenerl jar

的方式添加了它,所以错了,删除多余的android.jar就ok。下面是一些解决办法,我开始弄了一会,不行。

另外,android低版本工程(如2.2)放到高版本环境中(如4.0)可能会上述错误,解决方法如下:

1。 如果不修改android sdk版本,则使用project clean 命令作用于某工程即可。

(该处理方式只是在高版本中兼容了低版本工程,未真正意义上的升级)

2。 如果修改android sdk版本,则需要以下几个步骤:

1)修改SDK 选择工程,build path -- configure build path --- library 删除引用的低版本SDK, 然后add External JARs,选择高版本SDK,OK,保存

2)修改classpath文件该文件可能存在该项: classpathentry kind="lib" path ="你所指定的高版本的地址"把她修改成classpathentry kind="con" path="com.android.ide.eclipse.adt.ANDROID_FRAMEWORK" /

3) 修改AndroidManifest.xml在AndroidManifest.xml文件中,application标签后添加uses-sdk android:minSdkVersion="3"/uses-sdk

4) 修改default.properties(很重要)该文件最后一行(前面没用#的)target=android-8 该成target=android-18(这个是你最新SDK的版本号,4.0好像就是18吧),保存。

再看看你的工程和新建的android 4.0的工程结构就一样了。

获取json数据单个字段数据

、、、

TYPES:BEGIN?OF?gty_data1,

index?TYPE?i,

pernrTYPE?pa0001-pernr,

nameTYPE?pa0002-nachn,

sexTYPE?char2,

phoneTYPE?usrid,

END?OF?gty_data1,

BEGIN?OF?gty_data2,

index?TYPE?i,

pernrTYPE?pa0001-pernr,

phoneTYPE?usrid,

END?OF?gty_data2,

BEGIN?OF?gty_data3,

index?TYPE?string,

pernrTYPE?string,

nameTYPE?string,

sexTYPE?string,

phoneTYPE?string,

END?OF?gty_data3.

DATA:gt_data1TYPE?TABLE?OF?gty_data1,

gt_data2TYPE?TABLE?OF?gty_data2,

gt_data3TYPE?TABLE?OF?gty_data3,

gt_fcatTYPE?lvc_t_fcat.

DATA:gs_data1TYPE?gty_data1,

gs_data2TYPE?gty_data2,

gs_data3TYPE?gty_data3,

gs_fcatTYPE?lvc_s_fcat.

DATA:serializerTYPE?REF?TO?cl_trex_json_serializer,

deserializerTYPE?REF?TO?cl_trex_json_deserializer,

ref_descrTYPE?REF?TO?cl_abap_structdescr.

DATA:gv_jsonTYPE?string.

FIELD-SYMBOLS:TYPE?STANDARD?TABLE.

START-OF-SELECTION.

PERFORM?frm_sc_data."生产数据

PERFORM?frm_sc_json."生产json数据

PERFORM?frm_get_data."生成动态内表,

PERFORM?frm_display_data."获取想要数据,显示数据

END-OF-SELECTION.

*---------------------------------------------------------------------*

*??????Form??FRM_SC_DATA

*---------------------------------------------------------------------*

*???????text

*----------------------------------------------------------------------*

*??--??p1????????text

*??--??p2????????text

*----------------------------------------------------------------------*

FORM?frm_sc_data.

gs_data1-index?=?'2'.

gs_data1-pernr=?'10000002'.

gs_data1-name=?'男2号'.

gs_data1-sex=?'男'.

gs_data1-phone=?'12568956892'.

APPEND?gs_data1TO?gt_data1.

gs_data1-index?=?'3'.

gs_data1-pernr=?'10000003'.

gs_data1-name=?'女3号'.

gs_data1-sex=?'女'.

gs_data1-phone=?'12568956893'.

APPEND?gs_data1TO?gt_data1.

gs_data1-index?=?'4'.

gs_data1-pernr=?'10000004'.

gs_data1-name=?'女1号'.

gs_data1-sex=?'女'.

gs_data1-phone=?'12568956894'.

APPEND?gs_data1TO?gt_data1.

gs_data1-index?=?'5'.

gs_data1-pernr=?'10000005'.

gs_data1-name=?'男5号'.

gs_data1-sex=?'男'.

gs_data1-phone=?'12568956895'.

APPEND?gs_data1TO?gt_data1.

gs_data1-index?=?'6'.

gs_data1-pernr=?'10000006'.

gs_data1-name=?'男6号'.

gs_data1-sex=?'男'.

gs_data1-phone=?'12568956896'.

APPEND?gs_data1TO?gt_data1.

ENDFORM.

*---------------------------------------------------------------------*

*??????Form??FRM_SC_DYN_TAB

*---------------------------------------------------------------------*

*???????text

*----------------------------------------------------------------------*

*??--??p1????????text

*??--??p2????????text

*----------------------------------------------------------------------*

FORM?frm_sc_json.

CREATE?OBJECT?serializer

EXPORTING

data?=?gt_data1[].

serializer-serialize(?).

gv_json=?serializer-get_data(?).

WRITE:?/?gv_json.

ENDFORM.

*---------------------------------------------------------------------*

*??????Form??FRM_GET_DATA

*---------------------------------------------------------------------*

*???????text

*----------------------------------------------------------------------*

*??--??p1????????text

*??--??p2????????text

*----------------------------------------------------------------------*

FORM?frm_get_data.

DATA:dyn_tableTYPE?REF?TO?data.

DATA:lv_p1TYPE?i,

lv_p2TYPE?i,

lv_lTYPE?i,

lv_textTYPE?string,

lv_text1TYPE?string,

lv_lenTYPE?i,

lv_fieldTYPE?string,

lv_indexTYPE?i.

SEARCH?gv_jsonFOR?'{'.

IF?sy-subrc=?0.

lv_p1=?sy-fdpos?+1.

ENDIF.

SEARCH?gv_jsonFOR?'}'.

IF?sy-subrc=?0.

lv_p2=?sy-fdpos.

ENDIF.

lv_l=?lv_p2-?lv_p1.

lv_text=?gv_json+lv_p1(lv_l).

WRITE:/?lv_text.

DO.

CLEAR:lv_p1,lv_p2,lv_len.

lv_len=?strlen(?lv_text).

SEARCH?lv_textFOR?'"'.

IF?sy-subrc=?0.

lv_p1=?sy-fdpos.

ENDIF.

SEARCH?lv_textFOR?','.

IF?sy-subrc=?0.

lv_p2=?sy-fdpos.

ENDIF.

IF?lv_p2IS?INITIAL.

lv_l=?lv_len-?lv_p1.

ELSE.

lv_l=?lv_p2-?lv_p1?+1.

ENDIF.

IF?lv_p1IS?INITIAL.

EXIT.

ENDIF.

lv_text1=?lv_text+lv_p1(lv_l).

REPLACE?lv_text1WITH?''?INTO?lv_text.

ENDDO.

WRITE:/?lv_text.

CONDENSE?lv_textNO-GAPS.

DO.

lv_index=?sy-index.

SPLIT?lv_textAT?':'?INTO?lv_field?lv_text.

IF?sy-subrc=?0.

gs_fcat-fieldname=?lv_field.

gs_fcat-col_pos=?lv_index.

gs_fcat-inttype=?'g'.

*????gs_fcat-intlen????=?8.

*??????gs_fcat-scrtext_l?=?'描述'."加上以后可直接用于ALV显示所需结构

APPEND?gs_fcatTO?gt_fcat.

ELSE.

EXIT.

ENDIF.

IF?lv_textIS?INITIAL."当字符串为空时,拆分字符sy-subrc=?0

EXIT.

ENDIF.

ENDDO.

CALL?METHOD?cl_alv_table_create=create_dynamic_table

EXPORTING

it_fieldcatalog=?gt_fcat

IMPORTING

ep_table=?dyn_table.

ASSIGN?dyn_table-*TO?.

*??CREATE?DATA?dyn_line?LIKE?LINE?OF?dyn_tab."可生产结构

*????ASSIGN?dyn_line-*?TO?dyn_line.

ENDFORM.

*---------------------------------------------------------------------*

*??????Form??FRM_DISPLAY_DATA

*---------------------------------------------------------------------*

*???????text

*----------------------------------------------------------------------*

*??--??p1????????text

*??--??p2????????text

*----------------------------------------------------------------------*

FORM?frm_display_data.

CREATE?OBJECT?deserializer.

deserializer-deserialize(

EXPORTING?json=?gv_json

IMPORTING?abap=?).

MOVE-CORRESPONDING?TO?gt_data2.

LOOP?AT?gt_data2INTO?gs_data2.

WRITE:/?gs_data2-index,'-',gs_data2-pernr,'-',gs_data2-phone.

ENDLOOP.

ENDFORM.

、、、

怎么生成和解析iOS开发JSON格式数据

导语:JSON作为数据包格式传输的时候具有更高的效率,这是因为JSON不像XML那样需要有严格的闭合标签,这就让有效数据量与总数据包比大大提升,从而减少同等数据流量的情况下,网络的传输压力。JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序。这个字符串看起来有点儿古怪,但是JavaScript很容易解释它,而且 JSON 可以表示比"名称 / 值对"更复杂的结构。例如,可以表示数组和复杂的对象,而不仅仅是键和值的简单列表。

怎么生成和解析iOS开发JSON格式数据?

一、如何生成JSON格式的'数据?

1、利用字典NSDictionary转换为键/值格式的数据。

// 如果数组或者字典中存储了 NSString, NSNumber, NSArray, NSDictionary, or NSNull 之外的其他对象,就不能直接保存成文件了.也不能序列化成 JSON 数据.

NSDictionary *dict = @{@"name" : @"me", @"do" : @"something", @"with" : @"her", @"address" : @"home"};

// 1.判断当前对象是否能够转换成JSON数据.

// YES if obj can be converted to JSON data, otherwise NO

BOOL isYes = [NSJSONSerialization isValidJSONObject:dict];

if (isYes) {

NSLog(@"可以转换");

/* JSON data for obj, or nil if an internal error occurs. The resulting data is a encoded in UTF-8.

*/

NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dict options:0 error:NULL];

/*

Writes the bytes in the receiver to the file specified by a given path.

YES if the operation succeeds, otherwise NO

*/

// 将JSON数据写成文件

// 文件添加后缀名: 告诉别人当前文件的类型.

// 注意: AFN是通过文件类型来确定数据类型的!如果不添加类型,有可能识别不了! 自己最好添加文件类型.

[jsonData writeToFile:@"/Users/SunnyBoy/Sites/JSON_XML/dict.json" atomically:YES];

NSLog(@"%@", [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding]);

} else {

NSLog(@"JSON数据生成失败,请检查数据格式");

}

2、通过JSON序列化可以转换数组,但转换结果不是标准化的JSON格式。

NSArray *array = @[@"qn", @18, @"ya", @"wj"];

BOOL isYes = [NSJSONSerialization isValidJSONObject:array];

if (isYes) {

NSLog(@"可以转换");

NSData *data = [NSJSONSerialization dataWithJSONObject:array options:0 error:NULL];

[data writeToFile:@"/Users/SunnyBoy/Sites/JSON_XML/base" atomically:YES];

} else {

NSLog(@"JSON数据生成失败,请检查数据格式");

}

二、如何解析JSON格式的数据?

1、使用TouchJSon解析方法:(需导入包:#import "TouchJson/JSON/CJSONDeserializer.h")

//使用TouchJson来解析北京的天气

//获取API接口

NSURL *url = [NSURL URLWithString:@""];

//定义一个NSError对象,用于捕获错误信息

NSError *error;

NSString *jsonString = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:error];

NSLog(@"jsonString---%@",jsonString);

//将解析得到的内容存放字典中,编码格式为UTF8,防止取值的时候发生乱码

NSDictionary *rootDic = [[CJSONDeserializer deserializer] deserialize:[jsonString dataUsingEncoding:NSUTF8StringEncoding] error:error];

//因为返回的Json文件有两层,去第二层内容放到字典中去

NSDictionary *weatherInfo = [rootDic objectForKey:@"weatherinfo"];

NSLog(@"weatherInfo---%@",weatherInfo);

//取值打印

NSLog(@"%@",[NSString stringWithFormat:@"今天是 %@ %@ %@ 的天气状况是:%@ %@ ",[weatherInfo objectForKey:@"date_y"],[weatherInfo objectForKey:@"week"],[weatherInfo objectForKey:@"city"], [weatherInfo objectForKey:@"weather1"], [weatherInfo objectForKey:@"temp1"]]);

2、使用SBJson解析方法:(需导入包:#import "SBJson/SBJson.h")

//使用SBJson解析北京的天气

NSURL *url = [NSURL URLWithString:@""];

NSError *error = nil;

NSString *jsonString = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:error];

SBJsonParser *parser = [[SBJsonParser alloc] init];

NSDictionary *rootDic = [parser objectWithString:jsonString error:error];

NSDictionary *weatherInfo = [rootDic objectForKey:@"weatherinfo"];

NSLog(@"%@", [NSString stringWithFormat:@"今天是 %@ %@ %@ 的天气状况是:%@ %@ ",[weatherInfo objectForKey:@"date_y"],[weatherInfo objectForKey:@"week"],[weatherInfo objectForKey:@"city"], [weatherInfo objectForKey:@"weather1"], [weatherInfo objectForKey:@"temp1"]]);

3、使用IOS5自带解析类NSJSONSerialization方法解析:(无需导入包,IOS5支持,低版本IOS不支持)

// 从中国天气预报网请求数据

NSURL *url = [ NSURL URLWithString:@""];

// 创建请求

NSURLRequest *request = [NSURLRequest requestWithURL:url];

[[[NSURLSession sharedSession] dataTaskWithRequest:request completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {

// 在网络完成的 Block 回调中,要增加错误机制.

// 失败机制处理: 错误的状态码!

// 最简单的错误处理机制:

if (data !error) {

// JSON格式转换成字典,IOS5中自带解析类NSJSONSerialization从response中解析出数据放到字典中

id obj = [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];

NSDictionary *dict = obj[@"weatherinfo"];

NSLog(@"%@---%@", dict, dict[@"city"]);

}

}] resume];

4、使用JSONKit的解析方法:(需导入包:#import "JSONKit/JSONKit.h")

//如果json是“单层”的,即value都是字符串、数字,可以使用objectFromJSONString

NSString *json1 = @"{\"a\":123, \"b\":\"abc\"}";

NSLog(@"json1:%@",json1);

NSDictionary *data1 = [json1 objectFromJSONString];

NSLog(@"json1.a:%@",[data1 objectForKey:@"a"]);

NSLog(@"json1.b:%@",[data1 objectForKey:@"b"]);

//如果json有嵌套,即value里有array、object,如果再使用objectFromJSONString,程序可能会报错(测试结果表明:使用由网络或得到的php/json_encode生成的json时会报错,但使用NSString定义的json字符串时,解析成功),最好使用objectFromJSONStringWithParseOptions:

NSString *json2 = @"{\"a\":123, \"b\":\"abc\", \"c\":[456, \"hello\"], \"d\":{\"name\":\"张三\", \"age\":\"32\"}}";

NSLog(@"json2:%@", json2);

NSDictionary *data2 = [json2 objectFromJSONStringWithParseOptions:JKParseOptionLooseUnicode];

NSLog(@"json2.c:%@", [data2 objectForKey:@"c"]);

NSLog(@"json2.d:%@", [data2 objectForKey:@"d"]);

如何实现实体与json的转化

在开发的过程中,会遇到实体与json格式转化以便符合微信接口需要的json格式以及请求接口获取的json转化为实体。我把一些公用的方法总结如下(特别说明:解析是用的flexJson):

import java.util.ArrayList;

import java.util.List;

import flexjson.JSONDeserializer;

import flexjson.JSONSerializer;

public class JsonUtil {

/**

* 对象转化为字符串

* @param obj 要转化为json字符串的实体

*/

public static String getJsonStrFromObj(Object obj) {

JSONSerializer serializer = new JSONSerializer();

return serializer.serialize(obj);

}

/**

* 对象转化为json字符串

* @param obj 实体

* @param inParams 包含的字段数组

* @param exparams 不需要包含的字段

*/

public static String getJsonStrFromObj(Object obj, String[] inParams,String[] exParams) {

JSONSerializer serializer = new JSONSerializer();

serializer = serializer.include(inParams).exclude(exParams);

return serializer.serialize(obj);

}

/**

* 将对象转化为json字符串

* @param obj 实体

* @param exParams 不要包括的字段

*/

public static String getJsonStrFromObj(Object obj,String[] exParams) {

JSONSerializer serializer = new JSONSerializer();

serializer = serializer.exclude(exParams);

return serializer.serialize(obj);

}

/**

* 将List转化为json字符串

* @param objs list对象

* @return

*/

public static String getJsonStrFromList(ListObject objs){

return new JSONSerializer().exclude("class").serialize(objs);

}

/**

* 将List转化为json字符串

* @param objs list对象

* @param rootName 根名

* @param params 包括的字段

* @return

*/

public static String getJsonStrFromList(ListObject objs, String rootName,

String[] params) {

JSONSerializer serializer = new JSONSerializer();

serializer = serializer.include(params).exclude("class");

serializer.rootName(rootName);

return serializer.serialize(objs);

}

/**

* 将List转化为json字符串

* @param objs list对象

* @param rootName 根名

* @param params 包括的字段

* @return

*/

public static String getJsonStrFromList(ListObject objs, String rootName) {

JSONSerializer serializer = new JSONSerializer();

// serializer = serializer.exclude("class");

serializer.rootName(rootName);

return serializer.serialize(objs);

}

/**

* 将List转化为json字符串

* @param objs list对象

* @param rootName 根名

* @param params 包括的字段

* @return

*/

public static String getJsonStrFromList(ListObject objs, String[] params) {

JSONSerializer serializer = new JSONSerializer();

serializer = serializer.include(params).exclude("class");

return serializer.serialize(objs);

}

/**

* 将List转化为json字符串

* @param objs list对象

* @param rootName 根名

* @param params 包括的字段

* @return

*/

public static String getJsonStrFromList(ListObject objs, String[] inParams,String[] exParams) {

JSONSerializer serializer = new JSONSerializer();

serializer = serializer.include(inParams).exclude("class").exclude(exParams);

return serializer.serialize(objs);

}

/**

* 将字符串转化为实体

* @param T 实体

* @param source 要解析的字符串

* @param bean 要转化为的对象

* @return

*/

public static T T getObjFromJsonStr(String source, ClassT bean) {

return new JSONDeserializerT().deserialize(source, bean);

}

/**

* 将json中包含的class属性去除

* @param json 要转化的json

* @return

*/

public static String changeJson(String json){

int i = json.indexOf("\"class\":");

if(i!=-1){

int j = json.indexOf(",", i+1);

char c = json.charAt(j);

String subString="";

if((c+"").equals(",")){//第一个属性或者中间的属性出现

subString = json.substring(i, j+1);

}else if((c+"").equals("}")) {//在结尾的属性出现

subString = json.substring(i-1, j);

}

return json.replaceAll(subString, "");

}

return json;

}

}

(责任编辑:IT教学网)

更多

推荐网络媒体文章