Page MenuHomePhabricator

Add a setup warning for "always_populate_raw_post_data"
ClosedPublic

Authored by epriestley on Aug 25 2016, 10:49 PM.
Tags
None
Referenced Files
F18751542: D16454.id39585.diff
Sat, Oct 4, 11:35 AM
F18684915: D16454.id.diff
Fri, Sep 26, 10:08 AM
F18636161: D16454.diff
Sep 17 2025, 3:35 AM
F18123797: D16454.id39585.diff
Aug 13 2025, 12:26 PM
F18123794: D16454.id39580.diff
Aug 13 2025, 12:26 PM
F18123787: D16454.id.diff
Aug 13 2025, 12:26 PM
F18112065: D16454.diff
Aug 12 2025, 3:57 PM
F18075568: D16454.id39580.diff
Aug 4 2025, 6:10 PM
Subscribers
None

Details

Summary

Fixes T9235. When the stars align, PHP 5.6 or newer emits a deprecation warning on startup about "always_populate_raw_post_data" which occurs too early for us to intercept and can break responses by adding garbage to the output.

These settings appear to be sufficient:

always_populate_raw_post_data = 1
display_errors = 1
display_startup_errors = 1
error_reporting = -1

Then make a request with an unusual content type:

$ curl -X POST -H "Content-Type: application/json" -d "{foo: bar}" http://phabricator.example.com/

This triggers the warning:

<br />
<b>Deprecated</b>:  Automatically populating $HTTP_RAW_POST_DATA is deprecated and will be removed in a future version. To avoid this warning set 'always_populate_raw_post_data' to '-1' in php.ini and use the php://input stream instead. in <b>Unknown</b> on line <b>0</b><br />
<br />
...

To avoid this, just instruct administrators to set this value to "-1", which completely disables the feature and silences the warning.

Test Plan
  • Reproduced this issue by following the instructions above.
  • Triggered the setup issue locally and read all the captivating prose:

Screen Shot 2016-08-25 at 3.42.37 PM.png (1×1 px, 196 KB)

  • Made the configuration change it directed me to, saw the setup issue resolve.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

epriestley retitled this revision from to Add a setup warning for "always_populate_raw_post_data".
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: jcox.
jcox edited edge metadata.
This revision is now accepted and ready to land.Aug 26 2016, 1:28 PM
This revision was automatically updated to reflect the committed changes.