首页 > 编程知识 正文

pb生成json源码,pb代替json

时间:2023-12-27 22:27:59 阅读:327077 作者:AVYJ

本文目录一览:

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

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。