2.Rest Server提供数据库的Json字符串

 Delphi最大的特点是数据库操作便捷。为了能够给App提供数据,这里采用Rest Server后台,然后在用Json文件发送到APP前台。

    1.后台的dataset转换为json。

       这里百度后就可以找到相应的代码,直接可以参考:

function DataSetToJson(ADataset: TDataSet): string;
// [{"CityId":"18","CityName":"西安"},{"CityId":"53","CityName":"广州"}]
var
  LRecord: string;
  LField: TField;
  i: integer;
begin
  Result := '[';
  if (not ADataset.Active) or (ADataset.IsEmpty) then
    Exit;
  //Result := '';  //2018.4.10
  ADataset.DisableControls;
  ADataset.First;
  while not ADataset.Eof do
  begin
    for i := 0 to ADataset.FieldCount - 1 do
    begin
      LField := ADataset.Fields[i];
      if LRecord = '' then
        LRecord := '{"' + LField.FieldName + '":"' + LField.Text + '"'
      else
        LRecord := LRecord + ',"' + LField.FieldName + '":"' + LField.Text + '"';
      if i = ADataset.FieldCount - 1 then
      begin
        LRecord := LRecord + '}';
        if Result = '[' then
          Result := Result + LRecord
        else
          Result := Result + ',' + LRecord;
        LRecord := '';
      end;
    end;
    ADataset.Next;
  end;
  ADataset.EnableControls;
  Result := Result+']';//rightstr(Result,length(result)-1) ;  //2018.4.10
end;

    2.为App提供Json函数

      (1).函数定义:

function GetJsonAccess:string;

       (2)函数的具体代码:

function TServerMethods1.GetJsonAccess: string;
begin
  result:=DataSetToJson(ADOQuery1) ;
end;

        注意事项:这里函数的返回值,可以用TJSONArray,也可以直接用string。我这里用string到是更简洁一些。

        后台运行后,通过浏览器可以访问json结果,如后台地址为:

   http://192.168.3.2:8080/datasnap/rest/TServerMethods1/GetJsonAccess/  ,结果为:

{"result":["[{\"memID\":\"1\",\"username\":\"zs\",\"password\":\"111111\",\"name\":\"\u5F20\u4E09\"},{\"memID\":\"2\",\"username\":\"ls\",\"password\":\"222222\",\"name\":\"\u674E\u56DB\"},{\"memID\":\"3\",\"username\":\"ww\",\"password\":\"333333\",\"name\":\"\u738B\u4E94\"}]"]}

通过对json的分析,我们可以看到最外层是result字段,内容为一个json数组,然后最里面是数据表中的字段和相对于应的值。通过对该json数据的分析,以便于我们在app中进行遍历。

posted @ 2018-04-11 20:49  A·DONG  阅读(454)  评论(0编辑  收藏  举报