wwJsonSerializer::Serialize

This class can serialize FoxPro objects, values, collections and cursors to JSON and deserialize JSON strings into FoxPro objects, values or collections. Arrays are supported only as members of objects - all lists should be expressed preferably as Collections.

Here's an example that demonstrates how wwJsonSerializer works when round-tripping data:

foxpro
foxpro
lcJson = '{ "id": 50445, "message": "Whooo hooo", ' +; ' "status": 10 , "entered": "2018-11-21T23:10:10Z", ' +; ' "address": { "street": "123 Timber Ln", "number": 32 } }' loSer = CREATEOBJECT("wwJsonSerializer") loResult = loSer.DeserializeJson(lcJson) ? loResult.Id ? loResult.entered ? loSer.Serialize(loResult,.T.)

The serializer supports complex nested structures and can also serialize (but not deserialize) FoxPro tables and cursors by way of a custom string syntax (cursor:AliasName). Objects returned are created dynamically on the fly with all arrays parsed into FoxPro collections.

To serialize:

foxpro
foxpro
do wwJsonSerializer loSer = CREATEOBJECT("wwJsonSerializer") lcJson = loSer.Serialize(loObject) && Objects, Values, Collections

To de-serialize:

foxpro
foxpro
loObject = loSer.DeserializeJson(lcJson) && JSON Objects, Values, Arrays ? loObject.Value

You can also serialize FoxPro Cursors and Tables using the cursor:cursorName syntax:

foxpro
foxpro
select * from customers into TCustomers lcJson = loSer.Serialize("cursor:TCustomers") && Tables/Cursors

You can cannot directly deserialize cursors, but you can use CollectionToCursor() to turn the returned collection into a cursor.

o.Serialize(lvValue, llFormat)

Serialized JSON string

Parameters

lvValue
The value to serialize

llFormat
Pretty formats the JSON output. Alternately you can also use the FormattedOutput=.T.

Remarks

Json is created as continuous text on a single line. If you would like formatted output pass llFormat as .T.. Note there's some overhead in formatting, as the JSON is generated as continuous text in FoxPro first, then passed back to JSON.NET for formatting which deserializes and reserializes the object.

See also

Class wwJsonSerialize
wwJsonSerializer::DeserializeJson
wwJsonSerializer::PropertyNameOverrides

© West Wind Technologies, 2025 • Updated: 2025-03-12
Comment or report problem with topic