本文目錄一覽:
- 1、PB怎麼獲取json返回的值
- 2、怎麼生成json文件???急!!!!
- 3、請教,有用pb解析JSON的方法例子么
- 4、如何用python把protobuf轉化json
- 5、如何生成optional.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-hant/n/239011.html