forked from neoxic/php-amf3
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
112 lines (82 loc) · 3.5 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
AMF3 encoding/decoding extension for PHP
========================================
Description
-----------
The PHP AMF3 extension provides two functions to use in PHP scripts:
string amf3_encode(mixed $value [, $options = 0 ])
- Encodes $value into an AMF3 byte-stream.
- On success, returns an AMF3 representation of the value.
- On error, returns FALSE and issues a warning message (the only error case is
wrong argument count).
- The $options argument is a bitmask of options. The following bit constants
are available in a PHP script:
AMF3_FORCE_OBJECT
Force encoding non-indexed arrays as anonymous objects.
mixed amf3_decode(string $amf3 [, int &$count [, $options = 0 ]])
- Decodes $amf3 (AMF3 byte-stream) into a PHP value.
- On success, returns a resulting PHP value.
- On error, returns NULL and issues a warning message.
- If $count is provided, the number of bytes actually read from the string
will be stored in it (the value of -1 indicates an error).
- The $options argument is a bitmask of options. The following bit constants
are available in a PHP script:
AMF3_CLASS_MAP
Enable class mapping (see the usage constrains below).
AMF3_CLASS_AUTOLOAD
Enable the PHP class autoloading mechanism in the class mapping mode.
AMF3_CLASS_CONSTRUCT
Call the default constructor of a decoded object's class in the class
mapping mode.
WARNING! Class mapping should be used with great care since it can
potentially lead to a breach in security.
Installation
------------
To install the extension, type the following in the source directory:
phpize
./configure
make
make install
This should install the extension to your default PHP extension directory.
If it doesn't work as expected, manually put the target amf3.so library to
what the 'extension_dir' variable in your php.ini points to.
Add the following line to the corresponding extension section in your php.ini:
extension=amf3.so
To run tests, type:
make test
Usage constraints
-----------------
- PHP NULL, boolean, integer, float (double), string, array, and object values
are fully convertible back and forth to their corresponding AMF3 types.
- AMF3 Date becomes a float value whereas XML, XMLDocument, and ByteArray
become strings.
- In a special case, PHP integers are converted into AMF3 doubles according
to the specification (see the link below).
- A PHP array is encoded as an indexed array when it has ascending integer keys
that start with zero and have no gaps. An empty array adheres to this rule.
In all other cases, an array is considered non-indexed and encoded as a purely
associative array to avoid ambiguity.
- When class mapping is disabled (the default), AMF3 objects are returned as
associative arrays; otherwise, they are returned as objects.
Links
-----
Project homepage: http://neoxic.me/php-amf3/
Official Adobe AMF3 specification: http://www.adobe.com/go/amfspec
History
-------
Version 1.2.3 [2014-10-19]
+ Support for previously unsupported AMF3 types
+ Error reporting fixes
Version 1.2.2 [2013-08-31]
+ Minor error reporting fixes
Version 1.2.1 [2013-03-18]
+ Important security fixes
+ Minor fixes (build files, tests, README)
Version 1.2.0 [2013-03-03]
+ Option to force encoding non-dense arrays as anonymous objects.
+ Option to perform automatic class mapping in the decoder.
Version 1.1.0 [2013-02-20]
+ Support for previously unsupported AMF3 types.
+ Major code revision.
+ License changed from GPL to MIT.
Version 1.0.0 [2010-02-03]
+ Encoding/decoding of basic PHP/AMF3 values.