如何从Xamarin.Forms中的服务器接收响应

问题描述 投票:2回答:3

我创建了一个将数据发送到服务器的HTTP客户端。此数据将查询将返回JSON对象的服务器。如何从服务器接收JSON对象响应并将其插入我的数据库?

下面的代码将向我的服务器发送一个ContactID,我的服务器将返回一个JSON对象如何从我的服务器获取JSON对象?我将添加到我的代码中?我已经添加了

var data = await response.Content.ReadAsStringAsync();

但我不知道该怎么办。

try
        {
            var db = DependencyService.Get<ISQLiteDB>();
            var conn = db.GetConnection();

            var sql = "SELECT * FROM tblUser WHERE ContactID = '" + contact + "'";
            var getUser = conn.QueryAsync<UserTable>(sql);
            var resultCount = getUser.Result.Count;

            //Check if the user has been sync
            if (resultCount < 1)
            {
                try
                {
                    syncStatus.Text = "Syncing user to server...";

                    var link = Constants.requestUrl + "Host=" + host + "&Database=" + database + "&Contact=" + contact + "&Request=8qApc8";
                    string contentType = "application/json";
                    JObject json = new JObject
                    {
                        { "ContactID", contact }
                    };

                    HttpClient client = new HttpClient();
                    var response = await client.PostAsync(link, new StringContent(json.ToString(), Encoding.UTF8, contentType));
                    var data = await response.Content.ReadAsStringAsync();

                    if (response.IsSuccessStatusCode)
                    {
                        var content = await response.Content.ReadAsStringAsync();
                        var userresult = JsonConvert.DeserializeObject<IList<UserData>>(content);
                        var count = userresult.Count;

                        for (int i = 0; i < count; i++)
                        {
                            try
                            {
                                syncStatus.Text = "Syncing user to server...";

                                var item = userresult[i];
                                var contactID = item.ContactID;
                                var userID = item.UserID;
                                var userPassword = item.UserPassword;
                                var userType = item.UserType;
                                var userStatus = item.UserStatus;
                                var lastSync = item.LastSync;
                                var serverUpdate = item.ServerUpdate;
                                var mobileUpdate = item.MobileUpdate;

                                var user = new UserTable
                                {
                                    ContactID = Convert.ToInt32(contactID),
                                    UserID = userID,
                                    UserPassword = userPassword,
                                    UserType = userType,
                                    UserStatus = userStatus,
                                    LastSync = lastSync,
                                    ServerUpdate = serverUpdate,
                                    MobileUpdate = mobileUpdate
                                };

                                await conn.InsertAsync(user);
                            }
                            catch (Exception ex)
                            {
                                Console.Write("Syncing user error " + ex.Message);
                            }
                        }
                    }
                }
                catch (Exception ex)
                {
                    Console.Write("Syncing User Error " + ex.Message);
                }
            }

我的PHP代码将使用从Xamarin HTTP Client收到的ContactID查询我的数据库。

$json_str = file_get_contents('php://input');
    $json_obj = json_decode($json_str);

    $ContactID = $json_obj->ContactID;

    $sql = "SELECT * FROM tblUser WHERE ContactID = '$ContactID'";
    $result = mysqli_query($conn, $sql);
    $count = mysqli_num_rows($result);

    if($count > 0){
        while ($row = @mysqli_fetch_array($result)) {
            $decr = CryptRC4(FromHexDump($row['UserPassword']), $key);

            $ar[] = array(
                'ContactID' => $row['ContactID'],
                'UserID' => $row['UserID'],
                'UserPassword' => $decr,
                'UserType' => $row['UserType'],
                'UserStatus' => $row['UserStatus'],
                'LastSync' => $sync,
                'ServerUpdate' => $row['ServerUpdate'],
                'MobileUpdate' => $row['MobileUpdate']
            );

            print json_encode($ar);

            //Update LastSync DateTime
            $sql = "UPDATE tblUser SET LastSync = '$sync' WHERE ContactID = '$ContactID'";
            mysqli_query($conn, $sql);
        }
    }    
xamarin xamarin.forms
3个回答
3
投票

上例中的最后一条语句给出了字符串格式的json对象列表。

var data = await response.Content.ReadAsStringAsync();

您需要将其转换回对象列表。要让您的项目了解对象的定义,请创建一个包含公共属性的普通类(如下所示)

public class UserLog
{
    public int ContactId { get; set; }
    public string Log { get; set; }
    public DateTime LogDate { get; set; }
}

添加Newtonsoft.Json(由James Newton-King创建)Nuget包到您的项目中,以便您可以使用json。

要将变量'data'的内容转换为UserLog对象列表,请编写类似的代码

var list = NewtonsoftUtil<IList<UserLog>>.DeserializeObject(data);

(在文件顶部添加using Newtonsoft.Json;

请让我知道这可不可以帮你。


1
投票

假设你已经完成了所有事情。换句话说,您可以发送您的contactID并返回一个json。

假设您的json结构类似于: {"firstname" : "Doe", "lastname" : "foo" "age" : "27"}

检索数据的一种可能方法如下:

using Newtonsoft.Json;

//after PostAsync()
if (response.IsSuccessStatusCode)
{
    var content = await response.Content.ReadAsStringAsync();
    JObject jContent = (JObject)JsonConvert.DeserializeObject(content);
    string firstName = (string)jContent.GetValue("firstname")
    string lastName = (string)jContent.GetValue("lastname");
    int age = (int)jContent.GetValue("age");
}

Newtonsoft可在Nuget上找到。如果你还没有安装它,你需要安装它。

Improved solution

如果你的json有很多键/值对,如下所示:

{ key1 : value1, key2 : value2, key3 : value3, ... key10 : value10}

那么这样做不是一个好主意:

string foo1 = (string)jContent.GetValue("key1");
string foo2 = (string)jContent.GetValue("key2");
//...
string foo10 = (string)jContent.GetValue("key10");

要处理这种情况,您可以创建一个类:

public class Foo
{
    public string Foo1 {get;set;}
    public string Foo2 {get;set;}
    //...
    public string Foo2 {get;set;}
}

然后,您可以像下面这样简单:

if (response.IsSuccessStatusCode)
{
    var content = await response.Content.ReadAsStringAsync();
    Foo foo = JsonConvert.DeserializeObject<Foo>(content);
}

改进的解决方案来自www.newtonsoft.com。去那里看看使用该库的其他方法。


1
投票

上面的答案缺少一个重点 - > efficiency

无需在内存中分配字符串,尤其是在JSON很大的情况下。 Streams可以做得比strings好得多:

// Read the response as stream
var stream = await response.Content.ReadAsStreamAsync();

// Use the next method for deserialization
T DeserializeJsonFromStream<T>(Stream stream)
{
    if (stream == null || stream.CanRead == false)
        return default(T);

    using (var sr = new StreamReader(stream))
    using (var jtr = new JsonTextReader(sr))
    {
        var js = new JsonSerializer();
        return js.Deserialize<T>(jtr);
    }
}

P.S。:代码示例基于Json.NET。 P.S.S。:关于这个主题有很多好文章,我建议你熟悉下一个one

© www.soinside.com 2019 - 2024. All rights reserved.