pb生成json源碼,pb代替json

本文目錄一覽:

PB怎麼獲取json返回的值

pb本身是不能處理json數據的,你這數據來自哪裡?如果是瀏覽器,你可以用js處理成字元串通過pb與瀏覽器的介面返回給pb

怎麼生成json文件???急!!!!

json說白了只是一串長得像js對象字元串,不是一個後綴名或者一種文件形式,所以只要將這個字元串傳給前端js處理就行了,json本身就是一個對象,所以你可以直接賦值給一個對象就行。

請教,有用pb解析JSON的方法例子么

C#的請求其實不用那麼麻煩的。直接url改成一個一般處理程序,在一般處理程序里把數據response

在裡面把一個參數修改 一下

context.Response.ContentType = “application/json”;

在post的回調函數里就可以直接調用

$.post(“../getData.aspx”,{}

,function (data){

alert(data[0].filedName+data[0].filedValue);

})

如何用python把protobuf轉化json

直接利用python提供的json包,在django model的定義中增加一個方法toJSON,利用django model 能訪問 _meta.fields 得到相關屬性而得到,例子如下:

class Category(models.Model):

autoid = models.AutoField(primary_key=True)

email=models.CharField(max_length=150,blank=False)

comtype=models.CharField(max_length=20,blank=False)

catname=models.CharField(max_length=150,blank=False)

def __unicode__(self):

return ‘%s’ % (self.catname)

def toJSON(self):

import json

return json.dumps(dict([(attr, getattr(self, attr)) for attr in [f.name for f in self._meta.fields]]))

然後用django查出數據,並轉換成json,代碼如下:

row=models.Category.objects.get(autoid=23)

print row.toJSON()

如何生成optional.json文件

1、前端new一個domain實體,把Option類型的改成對應的非Optional類型

2、soa提供DzpList和DzpNoOptional,借用工具類生成,前端使用DzpNoOptional類型的list接受,接著遍歷list數據並把EtradeList類型逐一轉成DzpNoOptional,再add到DzpNoOptional類型的list返回json到前端。

3、抽取一個工具類方法,用於遍歷處理步驟2在每個方法中都重複進行的操作。

4、在pagingBean的json數據返回前端的一些列數據轉換過程中下手,關鍵在於該在什麼處理方法中找到切入點。

Soa—List(TDzpSpecial)Soa—List(TDzpSpecial)Admin—List(TDzpSpecial)Admin—List(TDzpSpecial)List(TDzpSpecialNoOptional)List(TDzpSpecialNoOptional)js(json接收)js(json接收)調用soa返回數據集合遍歷轉換List集合TDzpSpecialpagingBean.getRows

extra1:方法2的處理方式:

案例

@RequestMapping(value = “querySpecials”, method = RequestMethod.GET)

@ResponseBody

public KsPagingBeanTDzpSpecialNoOptional, TDzpSpecialNoOptional querySpecials(QuerySpecialRequestNoOptional querySpecialRequestNoOptional, KsPagingBeanTDzpSpecialNoOptional, TDzpSpecialNoOptional pagingBean) throws Exception {

DzpServiceClient dzpBidService = new DzpServiceClient();

QuerySpecialRequest querySpecialRequest=ThriftBeanConverter.copy(querySpecialRequestNoOptional, QuerySpecialRequest.class);

QuerySpecialResponse specialList = dzpBidService.getDzpSpecial(querySpecialRequest);

ListTDzpSpecialNoOptional specialNoOptionals = new ArrayList();

/*

if (!CollectionUtils.isEmpty(specialList.getSpecial())) {

for (TDzpSpecial special: specialList.getSpecial()) {

TDzpSpecialNoOptional specialNoOptional = TDzpSpecialNoOptional.copy(special);

specialNoOptionals.add(specialNoOptional);

}

}

pagingBean.setResults(specialList.getPageResponse().get().getResults());

*/

pagingBean.setRows(specialShowNoOptionals);

return pagingBean;

}1234567891011121314151617181920

extra2:方法4的處理方式:

a、引入jackson升級包

!– Jackson JSON Processor使用2.6.3。jdk8Module —

dependency

groupIdcom.fasterxml.jackson.datatype/groupId

artifactIdjackson-datatype-jdk8/artifactId

version${com.fasterxml.jackson.version}/version

/dependency

dependency

groupIdcom.fasterxml.jackson.core/groupId

artifactIdjackson-databind/artifactId

version${com.fasterxml.jackson.version}/version

/dependency1234567891011

b、jackson2.6.3成功解析option的原因

//Jdk8Module

context.addSerializers(new Jdk8Serializers());

context.addDeserializers(new Jdk8Deserializers());

context.addTypeModifier(new Jdk8TypeModifier());

//com.fasterxml.jackson.datatype.jdk8

//Jdk8Serializers

//OptionalSerializer

public void serialize(Optional? opt, JsonGenerator gen, SerializerProvider provider) throws IOException {

if(opt.isPresent()) {

Object value = opt.get();

JsonSerializer ser = this._valueSerializer;

if(ser == null) {

ser = this._findCachedSerializer(provider, value.getClass());

}

ser.serialize(value, gen, provider);

} else {

provider.defaultSerializeNull(gen);

}

1234567891011121314151617181920

case2.

以網站部分同樣對於Optional類型的返回不友好場景分兩種

1. responseBody返回json數據到js中

2. request.setAttribute(「pageResponse」, response)返回數據到jsp中,jsp通過c:forEach、c:out標籤遍歷顯示數據

extra1:對於場景1的mind

案例:

@RequestMapping(value = “listtest”, method = RequestMethod.GET)

@ResponseBody

public void listtest(PagingBeanPerson pb, Person claim,HttpServletResponse response) {

ListPerson personList=new ArrayListPerson();

Person person1=new Person();

Person person2=new Person();

person1.setName(Optional.of(“luosan”));

person1.setHobby(“乒乓球”);

person1.setId(1);

person2.setName(Optional.of(“lufei”));

person2.setHobby(“白雲機場”);

person2.setId(2);

personList.add(person1);

personList.add(person2);

pb.setRows(personList);

HttpServletHelper.writeJsonToResponse(response, pb);

}1234567891011121314151617

thinking:

1、對於現有HttpServletHelper的json處理方式改裝

try {

//原有方式

response.getWriter().print(new Gson().toJson(responseData));

//改裝方式

ObjectMapper mapper = new ObjectMapper();

mapper.registerModule(new Jdk8Module());

String withEmailJson = mapper.writeValueAsString(responseData);

response.getWriter().print(withEmailJson);

} catch (IOException e) {

LOGGER.error(e.getMessage(), e);

}

123456789101112131415

2、對於每次Registering module需要重新封裝

3、在其他的返回數據處理層進行處理?

extra2:對於場景2的mind

thinking

因為jsp中的jstl標籤直接對java中的對象操作,所以這個時候並未在返回jsp的過程中進行json序列化之類的處理,可以理解為此時的對象與control層的對象基本一致。

問題在於c:out標籤解析的時候不支持optional的類型,效果如上圖

於是我試圖通過更改jstl標籤實現支持

package org.apache.taglibs.standard.tag.el.core;

public class OutTag extends OutSupport {

// Accessors

// for tag attribute

public void setValue(Object value) {

//原有方式

this.value =value

//改裝方式

this.value =value instanceof Optional? ((Optional) value).get():value;

}

public void setDefault(String def) {

this.def = def;

}

public void setEscapeXml(boolean escapeXml) {

this.escapeXml = escapeXml;

}

}1234567891011121314151617

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/239011.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:14
下一篇 2024-12-12 12:14

相關推薦

  • 雲智直聘 源碼分析

    本文將會對雲智直聘的源碼進行分析,包括前端頁面和後端代碼,幫助讀者了解其架構、技術實現以及對一些常見的問題進行解決。通過本文的閱讀,讀者將會了解到雲智直聘的特點、優勢以及不足之處,…

    編程 2025-04-29
  • JSON的MD5

    在Web開發過程中,JSON(JavaScript Object Notation)是最常用的數據格式之一。MD5(Message-Digest Algorithm 5)是一種常用…

    編程 2025-04-29
  • 使用Java將JSON寫入HDFS

    本篇文章將從以下幾個方面詳細闡述Java將JSON寫入HDFS的方法: 一、HDFS簡介 首先,先來了解一下Hadoop分散式文件系統(HDFS)。HDFS是一個可擴展性高的分散式…

    編程 2025-04-29
  • Python網站源碼解析

    本文將從多個方面對Python網站源碼進行詳細解析,包括搭建網站、數據處理、安全性等內容。 一、搭建網站 Python是一種高級編程語言,適用於多種領域。它也可以用於搭建網站。最常…

    編程 2025-04-28
  • 如何使用Newtonsoft datatable轉Json

    Newtonsoft DataTable 是一個基於.NET的JSON框架,也是一個用於序列化和反序列化JSON的強大工具。 在本文中,我們將學習如何使用Newtonsoft Da…

    編程 2025-04-28
  • 源碼是什麼

    源碼是一段計算機程序的原始代碼,它是程序員所編寫的可讀性高、理解性強的文本。在計算機中,源碼是指編寫的程序代碼,這些代碼按照一定規則排列,被計算機識別並執行。 一、源碼的組成 源碼…

    編程 2025-04-27
  • JPRC – 輕鬆創建可讀性強的 JSON API

    本文將介紹一個全新的 JSON API 框架 JPRC,通過該框架,您可以輕鬆創建可讀性強的 JSON API,提高您的項目開發效率和代碼可維護性。接下來將從以下幾個方面對 JPR…

    編程 2025-04-27
  • Go源碼閱讀

    Go語言是Google推出的一門靜態類型、編譯型、並髮型、語法簡單的編程語言。它因具有簡潔高效,內置GC等優秀特性,被越來越多的開發者所鍾愛。在這篇文章中,我們將介紹如何從多個方面…

    編程 2025-04-27
  • 使用Python獲取JSON並解析

    本文將介紹如何使用Python獲取JSON數據並解析相關內容。通過使用Python的第三方庫,我們可以輕鬆地處理JSON數據,包括讀取、提取和操作JSON數據。 一、獲取JSON數…

    編程 2025-04-27
  • Python存為JSON的方法及實例

    本文將從以下多個方面對Python存為JSON做詳細的闡述。 一、JSON簡介 JSON(JavaScript Object Notation)是一種輕量級的數據交換格式,易於人閱…

    編程 2025-04-27

發表回復

登錄後才能評論