摘要:前言對于從其他服務器的獲得數(shù)據(jù),我們一般都為數(shù)據(jù)傳輸,比如服務器要從服務器的獲得分頁信息,得到字符后如果可以方便快捷操作要轉為自己的對象。第二種是的,這種就是無報錯,但是對象的值一直為空。把值傳進去去除報頭測試結果是成給對象賦值了
前言
對于從其他服務器的url獲得數(shù)據(jù),我們一般都為json數(shù)據(jù)傳輸,比如服務器B要從服務器A的url獲得分頁信息,得到json字符后如果可以方便快捷操作要轉為自己的java對象。
在此我試過三種轉json的第三方,一種google的gson,這種好像無法轉成功,一直報json格式錯誤,但校驗一直通過正確,嘗試失敗。第二種是net.sf.json的,這種就是無報錯,但是對象的值一直為空。只有json-simple可以成功轉對象
首先,我們要解析json,查看json是否為標準的json格式,我們可以在網(wǎng)上的很多在線格式化查看json,解析json為對象一般都換湯不換藥。
第一:就是要知道json結構,這里我先開啟服務器A從他的url得到一串json數(shù)據(jù)。
把復制json數(shù)據(jù)把它扔在格式化工具可以很清楚的看出結構:
{ "eventList": [ { "id": 1030, "eventId": "1508779115818499700", "createTime": 1508779115000, "endTime": 1508865480000, "eventContent": "123", "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, { "id": 1029, "eventId": "1508382907251660498", "createTime": 1508382906000, "endTime": 1508383020000, "eventContent": "ahhhhh", "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, { "id": 1028, "eventId": "1508308708414580378", "createTime": 1508308721000, "endTime": 1508309040000, "eventContent": "30", "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, { "id": 1027, "eventId": "1508308463330664814", "createTime": 1508308480000, "endTime": 1508308560000, "eventContent": "28", "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, { "id": 1026, "eventId": "1508308463017144213", "createTime": 1508308479000, "endTime": 1508308560000, "eventContent": "27", "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" } ], "page": "1", "size": "5", "isHasPage": "1" }
第二:根據(jù)結構創(chuàng)建對應的實體類
import com.yhn.consumer.entity.Event; import lombok.Data; import org.json.simple.JSONObject; import java.io.Serializable; import java.util.List; @Data public class EventVO implements Serializable{ private ListeventList; private String page; private String size; private String isHasPage; public EventVO(JSONObject object){ //構造器方法給對象賦值 eventList = (List )object.get("eventList"); page = (String)object.get("page"); size = (String)object.get("size"); isHasPage = (String)object.get("isHasPage"); } }
因為是內(nèi)嵌結構,下面這個是private List<Event> eventList中的Event類;
import lombok.Data; import org.hibernate.annotations.DynamicUpdate; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import java.io.Serializable; import java.util.Date; @Entity @Data @DynamicUpdate //自動更新時間字段 public class Event implements Serializable { //這是EventVO里List中的Event @Id @GeneratedValue private Integer id; //排序作用 private String eventId; //事件id private Date createTime; //創(chuàng)建時間 private Date endTime; //更新時間 private String eventContent; //提醒事件內(nèi)容 private String openid; //用戶id }測試類
接下來結構也寫好了,將在服務器B寫單元測試看看是否能夠成功賦值
@Test public void clientDemo()throws Exception { StringBuilder json = new StringBuilder(); URL urlObject = new URL("http://127.0.0.1/meetingSign/test/server?openid=o4eWZ06xzHW6mc2gMZMYVDEtx1zk&page=2&size=5"); //指定URL HttpURLConnection uc = (HttpURLConnection) urlObject .openConnection(); //開啟連接 BufferedReader in = new BufferedReader(new InputStreamReader(uc.getInputStream(), "utf-8")); String inputLine = null; while ((inputLine = in.readLine()) != null) { json.append(inputLine); //拼接json } in.close(); uc.disconnect(); System.out.println(json); //查看是否拿到。 //去除可能含編碼UTF-8等,因為可能含有Bom頭文件。 String result = formatString(json.toString()); JSONParser parser=new JSONParser(); org.json.simple.JSONObject data = new org.json.simple.JSONObject(); data = (org.json.simple.JSONObject) parser.parse(result); EventVO eventVO = new EventVO(data); //把值傳進去 log.info("eventVO={}",eventVO); } /** * 去除bom報頭 */ public static String formatString(String s) { if (s != null) { s = s.replaceAll("ufeff", ""); } return s; }測試結果
是成給對象賦值了
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/70639.html
摘要:微信接入采用的第三方接入微信,具體功能接入還是要看微信公眾號開發(fā)文檔,架構則是上面所說的。吐槽一下,騰訊包括微信,他們的文檔確實沒有阿里做得好。人臉融合結尾這一塊騰訊人工智能接入已解釋完畢。 要想騎自行車,首先不是要學會如何造自行車,而是學會如何騎行 前言 結合騰訊AI開放平臺群里的demo解析,QQ群號:581197347。這個項目是我只花費兩天時間做完的,采用的技術是SpringB...
摘要:是一種協(xié)議,為了解決客戶端請求服務器跨域的問題,但是并非是正式的傳輸協(xié)議。結果明明請求回來數(shù)據(jù),結果還是報錯。是一種使用數(shù)據(jù)的方式,返回的不是對象,是包含對象的腳本。 1、什么是JSONP 一般來說位于 server1.example.com 的網(wǎng)頁無法與不是 server1.example.com的服務器溝通,而 HTML 的 元素是一個例外。利用 元素的這個開放策略,網(wǎng)頁可以得到...
摘要:面向對象編程對象的原生方法分成兩類自身的方法靜態(tài)方法和的實例方法。的靜態(tài)方法方法與,參數(shù)是對象,返回一個數(shù)組,數(shù)組的值是改對象自身的所有屬性名區(qū)別在于返回可枚舉的屬性,返回不可枚舉的屬性值。 面向對象編程 Objects對象的原生方法分成兩類:Object自身的方法(靜態(tài)方法)和Object的實例方法。注意Object是JavaScript的原生對象,所有的其他對象都是繼承自Objec...
摘要:請求服務器數(shù)據(jù)并規(guī)定回調函數(shù)為上面代碼通過動態(tài)添加元素,向服務器發(fā)出請求。另外假設向服務發(fā)送的請求是這樣的在這種情況下,是表示請求的請求參數(shù),而是應用程序的回調函數(shù)的名稱。清單調用回調服務注意,我們使用作為回調函數(shù)名,而非真實的函數(shù)名。 同源策略 同源策略(Same origin policy),它是由Netscape提出的一個著名的安全策略?,F(xiàn)在所有支持JavaScript的瀏覽器都...
閱讀 3947·2021-11-16 11:44
閱讀 3128·2021-11-12 10:36
閱讀 3383·2021-10-08 10:04
閱讀 1270·2021-09-03 10:29
閱讀 409·2019-08-30 13:50
閱讀 2623·2019-08-29 17:14
閱讀 1745·2019-08-29 15:32
閱讀 1090·2019-08-29 11:27