blob: a3d1f7ae250c05ed59147dca5e8cbcc0b1f7a54e (
plain)
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
|
--TEST--
Test json_encode() function : JSON_THROW_ON_ERROR flag
--SKIPIF--
<?php if(!extension_loaded('json')) die('skip json extension not loaded') ?>
--FILE--
<?php
try {
var_dump(json_encode("\x80", JSON_THROW_ON_ERROR));
} catch (JsonException $e) {
var_dump($e);
}
// JSON_PARTIAL_OUTPUT_ON_ERROR is incompatible with exceptions
// So it overrides it for the sake of working with wrappers that add the
// JSON_THROW_ON_ERROR flag
var_dump(json_encode("\x80", JSON_THROW_ON_ERROR | JSON_PARTIAL_OUTPUT_ON_ERROR));
var_dump(json_last_error());
var_dump(json_last_error_msg());
?>
--EXPECTF--
object(JsonException)#1 (7) {
["message":protected]=>
string(56) "Malformed UTF-8 characters, possibly incorrectly encoded"
["string":"Exception":private]=>
string(0) ""
["code":protected]=>
int(5)
["file":protected]=>
string(%d) "%s"
["line":protected]=>
int(%d)
["trace":"Exception":private]=>
array(1) {
[0]=>
array(4) {
["file"]=>
string(%d) "%s"
["line"]=>
int(%d)
["function"]=>
string(11) "json_encode"
["args"]=>
array(2) {
[0]=>
string(1) "%s"
[1]=>
int(4194304)
}
}
}
["previous":"Exception":private]=>
NULL
}
string(4) "null"
int(5)
string(56) "Malformed UTF-8 characters, possibly incorrectly encoded"
|