[Unity3d]u3d请求json数据并解析

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: unity3d在跟.net进行http通信的时候,最常见的就是表单数据的提交请求了,但服务器端会返回一坨json数据,这就要求我们在unity中进行json数据的处理了,一般unity中处理json个数数据用的最多的就是LitJSON(它是.net平台下处理SON数据库的类库)。

unity3d在跟.net进行http通信的时候,最常见的就是表单数据的提交请求了,但服务器端会返回一坨json数据,这就要求我们在unity中进行json数据的处理了,一般unity中处理json个数数据用的最多的就是LitJSON(它是.net平台下处理SON数据库的类库)。下面我就贴出源码,仅供学习参考!

关于LitJSON的安装和使用,请参考:http://www.360doc.com/content/13/0117/11/10941785_260686840.shtml

或者参考:http://blog.csdn.net/dingxiaowei2013/article/details/17115665


将LitJson.dll放在assets目录下的plugins文件下,如果没有plugins文件就手动创建一个


Client:

using UnityEngine;
using System.Collections;
using LitJson;

public class GetPhotoList : MonoBehaviour {

    // Use this for initialization
    void Start () {
        StartCoroutine(GetPhotos());
    }
    
    // Update is called once per frame
    IEnumerator GetPhotos(){    
        WWWForm    form = new WWWForm();
        form.AddField("id","123");
        WWW w = new WWW("http://localhost:36944/GetPhotoList.ashx",form);
        while (!w.isDone){yield return new WaitForEndOfFrame();}
        if (w.error != null){Debug.LogError(w.error);}
        Debug.Log(w.text);        
        JsonData jd = JsonMapper.ToObject(w.text);
        for (int i = 0; i < jd.Count; i++)
        {            
            Debug.Log("id=" + jd[i]["id"]);
            Debug.Log("name=" + jd[i]["name"]);
        }
        
    }
}

Server:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Runtime.Serialization.Json;
using System.ServiceModel;
using System.ServiceModel.Web;
using System.IO;

namespace UpdatePhoto
{
    /// <summary>
    /// GetPhotoList 的摘要说明
    /// </summary>
    public class GetPhotoList : IHttpHandler
    {

        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            string id = context.Request.Form["id"];
            string path = context.Request.PhysicalApplicationPath;
            //context.Response.Write("Hello World");
            List<Photo> photos = GetPhotos(id,path);
            DataContractJsonSerializer djson = new DataContractJsonSerializer(photos.GetType());
            djson.WriteObject(context.Response.OutputStream, photos);
        }

        public List<Photo> GetPhotos(string id,string path)
        {
            //获取目录
            string localPath = path+id + "\\"; 
            //读取目录下的文件
            if (!Directory.Exists(localPath)) return null;
            string[] files = Directory.GetFiles(localPath);
            List<Photo> photos = new List<Photo>();
            foreach (string file in files)
            {
                string filename = file.Substring(file.LastIndexOf('\\')+1);
                Photo p = new Photo();
                p.name = filename;
                p.id = id;
                photos.Add(p);
            }


            return photos;
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }

    public class Photo
    {
        public string id;
        public string name;
    }
}


==================== 迂者 丁小未 CSDN博客专栏=================

MyBlog:http://blog.csdn.net/dingxiaowei2013              MyQQ:1213250243

MyTel:13262983383 

====================== 相互学习,共同进步 ===================


相关文章
|
4月前
|
存储 JSON API
Python编程:解析HTTP请求返回的JSON数据
使用Python处理HTTP请求和解析JSON数据既直接又高效。`requests`库的简洁性和强大功能使得发送请求、接收和解析响应变得异常简单。以上步骤和示例提供了一个基础的框架,可以根据你的具体需求进行调整和扩展。通过合适的异常处理,你的代码将更加健壮和可靠,为用户提供更加流畅的体验。
263 0
|
8月前
|
XML 机器学习/深度学习 JSON
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
91 0
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
|
JSON 小程序 JavaScript
微信小程序调用json数据接口并解析
微信小程序调用json数据接口并解析
485 0
|
存储 JSON JavaScript
常用的"小脚本"-json数据处理
常用的"小脚本"-json数据处理
178 0
|
8月前
|
JSON 前端开发 数据格式
Ajax传递json数据
Ajax传递json数据
|
JSON 前端开发 数据格式
ajax请求解析json数据渲染在前端界面
ajax请求解析json数据渲染在前端界面
63 0
|
JSON 前端开发 数据处理
Echarts请求不同格式的json数据处理
Echarts请求不同格式的json数据处理
83 0
|
XML 前端开发 JavaScript
教你怎么用最原始的ajax发送post请求和get请求
教你怎么用最原始的ajax发送post请求和get请求
455 0
|
JSON 数据格式 Python
如何使用Request方法发送Post请求、JSON文件介绍、Python中的JSON数据以及获取到的JSON数据的解析。
如何使用Request方法发送Post请求、JSON文件介绍、Python中的JSON数据以及获取到的JSON数据的解析。
|
JSON 数据格式
调用后端接口时响应的json数据里面中文变成问号
调用后端接口时响应的json数据里面中文变成问号
221 0
调用后端接口时响应的json数据里面中文变成问号