本篇文章给大家谈谈json的api接口,以及json的api接口防止被调用对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
今天给各位分享json的api接口的知识,其中也会对json的api接口防止被调用进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
查询ip的api接口(json等格式)
官网有更完整详细的介绍,做相关测试很方便
API URI Response Type Sample Output (IPv4)
https://api.ipify.org text 98.207.254.136
https://api.ipify.org?format=json json {"ip":"98.207.254.136"}
https://api.ipify.org?format=jsonp jsonp callback({"ip":"98.207.254.136"});
https://api.ipify.org?format=jsonpcallback=getip jsonp getip({"ip":"98.207.254.136"});
从API接口获取的json数据怎么存到对象的List集合中
1. 简单的手动放置 键值对 到JSONObject
json的api接口,然后在put到JSONArray对象里
List<Article al = articleMng.find(f);
System.out.println(al.size());
HttpServletResponse hsr = ServletActionContext.getResponse();
if(null == al){
return ;
}
for(Article a : al){
System.out.println(a.getId()+a.getDescription()+a.getTitle());
}
JSONArray json = new JSONArray();
for(Article a : al){
JSONObject jo = new JSONObject();
jo.put("id", a.getId());
jo.put("title", a.getTitle());
jo.put("desc", a.getDescription());
json.put(jo);
}
try {
System.out.println(json.toString());
hsr.setCharacterEncoding("UTF-8");
hsr.getWriter().write(json.toString());
} catch (IOException e) {
e.printStackTrace();
}
复制代码
上述代码JSONArray是引入的org.json.JSONArray包
而用net.sf.json包下JSONArray的静态方法:fromObject(list) 这是网上大多是都是直接用此方法快捷转换JSON
json的api接口,但是对于Hibernate级联操作关联的对象,这个方法就会报错,如果将映射文件中的级联配置去掉就行
json的api接口了。
另外对于list的要求就是其中的元素是字符串或对象,否则JSON不知道你想要的是什么数据。
<many-to-one name="cmsent" column="comment_tid" class="com.fcms.cms.entity.CmsComment"
not-null="false" cascade="delete"
但是级联操作毕竟还是得存在,否则以后数据冗余、多余。
解决方法就是:JSONArray subMsgs = JSONArray.fromObject(object, config);
JsonConfig config = new JsonConfig();
config.setJsonPropertyFilter(new PropertyFilter() {
public boolean apply(Object arg0, String arg1, Object arg2) {
if (arg1.equals("article") ||arg1.equals("fans")) {
return true;
} else {
return false;
}
}
});
复制代码
说明:提供了一个过滤作用,如果遇到关联的对象时
json的api接口他会自动过滤掉,不去执行关联关联所关联的对象。这里我贴出我hibernate中的配置关系映射的代码帮助理解:
<!-- 配置话题和团体之间的关系 --
<many-to-one name="article" class="com.fcms.nubb.article" column="article_id"/
<!-- 配置主题帖与回复的帖子之间的关系 --
<set name="subMessages" table="sub_message" inverse="true" cascade="all" lazy="false" order-by="date asc"
<key column="theme_id" /
<one-to-many class="bbs.po.SubMessage" /
</set
总结:
1. JSONArray subMsgs = JSONArray.fromObject(subMessages, config);其中config是可选的,当出现上面的情况是可以配置config参数,如果没有上面的那种需求就可以直接使用fromObject(obj)方法,它转换出来的就是标准的json对象格式的数据,如下:
{["attr", "content", ...}, ...]}
2. JSONObject jTmsg = JSONObject.fromObject(themeMessage, config);这是专门用来解析标准的pojo,或者map对象的,pojo对象的格式就不用说了,map的形式是这样的{"str", "str"}。
package com.nubb.bean;
import java.io.Serializable;
public class Person implements Serializable{
private static final long serialVersionUID = 1L;
private String name;
private int age;
private String address;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
package com.nubb.test;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.StandardOpenOption;
import java.util.ArrayList;
import java.util.List;
import com.alibaba.fastjson.JSON;
import com.nubb.bean.Person;
public class JSONSerializer {
private static final String DEFAULT_CHARSET_NAME = "UTF-8";
public static <T String serialize(T object) {
return JSON.toJSONString(object);
}
public static <T T deserialize(String string, Class<T clz) {
return JSON.parseObject(string, clz);
}
public static <T T load(Path path, Class<T clz) throws IOException {
return deserialize(
new String(Files.readAllBytes(path), DEFAULT_CHARSET_NAME), clz);
}
public static <T void save(Path path, T object) throws IOException {
if (Files.notExists(path.getParent())) {
Files.createDirectories(path.getParent());
}
Files.write(path,
serialize(object).getBytes(DEFAULT_CHARSET_NAME),
StandardOpenOption.WRITE,
StandardOpenOption.CREATE,
StandardOpenOption.TRUNCATE_EXISTING);
}
public static void main(String[] args) {
Person person1 = new Person();
person1.setAddress("address");
person1.setAge(11);
person1.setName("amao");
Person person2 = new Person();
person2.setAddress("address");
person2.setAge(11);
person2.setName("amao");
List<Person lp = new ArrayList<Person();
lp.add(person1);
lp.add(person2);
System.out.println(serialize(lp));
}
}
输出:
[{"address":"address","age":11,"name":"amao"},{"address":"address","age":11,"name":"amao"}]
api接口转换成json格式了 怎么给前端
一般不存在前端给后端接口的情况,几乎都是后端给前端接口,所谓接口就是可以通过服务端部署的机器提供出来的URL地址进行动态的数据交互。通常的工作流是后端跟前端协商定义数据接口格式(一般就是JSON格式)形成文档,后端实现接口,前端做静态的mock(可以是直接在页面的JS拼假数据或者通过JSON server按照真实调用服务的方式集成),后端实现服务接口,两边都完成后集成联调。现在有swagger 或者 apiairy 等工具可以更简化这个过程
关于json的api接口和json的api接口防止被调用的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
json的api接口的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于json的api接口防止被调用、json的api接口的信息别忘了在本站进行查找喔。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
暂时没有评论,来抢沙发吧~