JS物件和Java物件轉成JSON
阿新 • • 發佈:2018-12-03
一.Json物件與Json字串的轉化
1.jQuery外掛支援的轉換方式:
$.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以將json字串轉換成json物件
2.瀏覽器支援的轉換方式(Firefox,chrome,opera,safari,ie9,ie8)等瀏覽器:
JSON.stringify(obj)將js物件轉為JSON。JSON.parse(string)將字串轉為JSON格式;
var a={"name":"tom","sex":"男","age":"24"};
var b='{"name":"Mike","sex":"女","age":"29"}';
var aToStr=JSON.stringify(a);
var bToObj=JSON.parse(b);
alert(typeof(aToStr)); //string
alert(typeof(bToObj));//object
3.Javascript支援的轉換方式:
eval('(' + jsonstr + ')'); //可以將json字串轉換成json物件,注意需要在json字元外包裹一對小括號
注:ie8(相容模式),ie7和ie6也可以使用eval()將字串轉為JSON物件,但不推薦這些方式,這種方式不安全eval會執行json串中的表示式。
4.JSON官方的轉換方式:
http://www.json.org/提供了一個json.js,這樣ie8(相容模式),ie7和ie6就可以支援JSON物件以及其stringify()和parse()方法;
可以在https://github.com/douglascrockford/JSON-js上獲取到這個js,一般現在用json2.js。
二、JSON 字串 與 java 物件的轉換
1. 把java 物件列表轉換為json物件陣列,並轉為字串
JSONArray array = JSONArray.fromObject(list);
String jsonstr = array.toString();
2. 把java物件轉換成json物件,並轉化為字串
JSONObject object = JSONObject.fromObject(user);
Log4jInit.ysulogger.debug(object.toString());
3.把JSON字串轉換為JAVA 物件陣列
JSONArray json = JSONArray.fromObject(userStr);//userStr是json字串
List<User> users= (List<User>)JSONArray.toCollection(json, User.class);
4.把JSON字串轉換為JAVA 物件
JSONObject jsonobject = JSONObject.fromObject(jsonStr);
User user= (User)JSONObject.toBean(object,User.class);
儲存過程
DROP PROCEDURE if EXISTS getData;
CREATE PROCEDURE getData()
BEGIN
DECLARE str VARCHAR(50);
SET str = 'AX_1415';
set @sqlstr=concat('select 1234 ',str,' from jc_yg_82600 WHERE JCD_id=100000002 AND DataDate = ''20170713''');
-- select 123 AX_1415 from jc_yg_82600 WHERE JCD_id=100000002 AND DataDate = '20170713'
PREPARE cmd from @sqlstr;
EXECUTE cmd;
END
PREPARE cmd from @sqlstr;
EXECUTE cmd;
與?java原生sql相似
' 轉譯字元
1.jQuery外掛支援的轉換方式:
$.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以將json字串轉換成json物件
2.瀏覽器支援的轉換方式(Firefox,chrome,opera,safari,ie9,ie8)等瀏覽器:
JSON.stringify(obj)將js物件轉為JSON。JSON.parse(string)將字串轉為JSON格式;
var a={"name":"tom","sex":"男","age":"24"};
var b='{"name":"Mike","sex":"女","age":"29"}';
var aToStr=JSON.stringify(a);
var bToObj=JSON.parse(b);
alert(typeof(aToStr)); //string
alert(typeof(bToObj));//object
3.Javascript支援的轉換方式:
eval('(' + jsonstr + ')'); //可以將json字串轉換成json物件,注意需要在json字元外包裹一對小括號
注:ie8(相容模式),ie7和ie6也可以使用eval()將字串轉為JSON物件,但不推薦這些方式,這種方式不安全eval會執行json串中的表示式。
4.JSON官方的轉換方式:
http://www.json.org/提供了一個json.js,這樣ie8(相容模式),ie7和ie6就可以支援JSON物件以及其stringify()和parse()方法;
可以在https://github.com/douglascrockford/JSON-js上獲取到這個js,一般現在用json2.js。
二、JSON 字串 與 java 物件的轉換
1. 把java 物件列表轉換為json物件陣列,並轉為字串
JSONArray array = JSONArray.fromObject(list);
String jsonstr = array.toString();
2. 把java物件轉換成json物件,並轉化為字串
JSONObject object = JSONObject.fromObject(user);
Log4jInit.ysulogger.debug(object.toString());
3.把JSON字串轉換為JAVA 物件陣列
JSONArray json = JSONArray.fromObject(userStr);//userStr是json字串
List<User> users= (List<User>)JSONArray.toCollection(json, User.class);
4.把JSON字串轉換為JAVA 物件
JSONObject jsonobject = JSONObject.fromObject(jsonStr);
User user= (User)JSONObject.toBean(object,User.class);
儲存過程
DROP PROCEDURE if EXISTS getData;
CREATE PROCEDURE getData()
BEGIN
SET str = 'AX_1415';
set @sqlstr=concat('select 1234 ',str,' from jc_yg_82600 WHERE JCD_id=100000002 AND DataDate = ''20170713''');
-- select 123 AX_1415 from jc_yg_82600 WHERE JCD_id=100000002 AND DataDate = '20170713'
PREPARE cmd from @sqlstr;
EXECUTE cmd;
END
PREPARE cmd from @sqlstr;
EXECUTE cmd;
與?java原生sql相似
' 轉譯字元