Difference between revisions of "Receive JSON POST Data"

From Michael's Information Zone
Jump to navigation Jump to search
 
(3 intermediate revisions by the same user not shown)
Line 43: Line 43:
 
file_put_contents($myFile,$data);
 
file_put_contents($myFile,$data);
 
?>
 
?>
 +
</pre>
 +
Another way of doing this would be the following<ref>https://gist.github.com/techslides/5df05f62f2a034ee537c</ref>
 +
<pre>
 +
<?php
 +
$today = date("mdY_His");
 +
$file = "file_$today";
 +
$dir = '/var/www/html/recevied/';
 +
$full = $dir.$file.'.txt';
 +
echo $full;
 +
$data = file_get_contents('php://input');
 +
$forwriting = fopen($full, "w");
 +
fwrite($forwriting, $data);
 +
fclose($forwriting);
 +
?>
 +
 
</pre>
 
</pre>
  
Line 50: Line 65:
 
curl -X POST -H "Content-Type: application/json" --data '{"test":"1"}' http://localhost
 
curl -X POST -H "Content-Type: application/json" --data '{"test":"1"}' http://localhost
 
</pre>
 
</pre>
Again, but with a username/password
+
Again, but with a username/password<ref>https://stackoverflow.com/questions/3044315/how-to-set-the-authorization-header-using-curl</ref>
 
<pre>
 
<pre>
 
curl --user test:test -X POST -H "Content-Type: application/json" --data '{"test":"1"}' http://localhost
 
curl --user test:test -X POST -H "Content-Type: application/json" --data '{"test":"1"}' http://localhost
 +
</pre>
 +
==Final Config==
 +
Not finished, for reference.
 +
<pre>
 +
yum install httpd php python2-certbot-apache
 +
htpasswd -Bc /etc/httpd/password user
 +
 +
cat << EOF >> /etc/httpd/conf.d/vhost.conf
 +
<VirtualHost *:80>
 +
DocumentRoot /var/www/html/
 +
<Directory /var/www/html/>
 +
AuthType Basic
 +
AuthName "Restricted"
 +
AuthBasicProvider file
 +
AuthUserFile "/etc/httpd/password"
 +
Require valid-user
 +
</Directory>
 +
</VirtualHost>
 +
EOF
 +
 +
certbot --apache
 +
 +
mv /etc/httpd/conf.d/ssl.conf ./
 +
touch /etc/httpd/conf.d/ssl.conf
 +
echo "Listen 443" >> /etc/httpd/conf.d/vhost-le-ssl.conf
 +
systemctl restart httpd
 
</pre>
 
</pre>

Latest revision as of 09:20, 1 August 2018

Purpose

Request came across my desk for a web server to receive JSON POST data, providing web hooks for another system to parse. On my end things were simple enough.

  1. Simple Apache server to receive requests.
  2. Basic Authentication
  3. Save the POST data to file (For now, but I feel this will be expanded in the near future)

Process

Apache Config

Very simple and clean vhost.

<VirtualHost *:80>
DocumentRoot /var/www/html/
<Directory /var/www/html/>
AuthType Basic
AuthName "Restricted"
AuthBasicProvider file
AuthUserFile "/etc/httpd/password"
Require valid-user
</Directory>
</VirtualHost>

Quick and dirty password file

htpasswd -bc /etc/httpd/password test test

PHP Script

[1][2]This example will echo the posted data back to the client during testing, as well as save the file to disk.

<?php
$myFile = "testFile.txt";
$data = file_get_contents('php://input');
echo $data;
file_put_contents($myFile,$data);
?>

To further build on this, and to keep track of the received hooks, I wanted to add a date/time stamp to the file[3].

<?php
$today = date("mdY_His");
$myFile = "testFile_$today.txt";
$data = file_get_contents('php://input');
file_put_contents($myFile,$data);
?>

Another way of doing this would be the following[4]

<?php
$today = date("mdY_His");
$file = "file_$today";
$dir = '/var/www/html/recevied/';
$full = $dir.$file.'.txt';
echo $full;
$data = file_get_contents('php://input');
$forwriting = fopen($full, "w");
fwrite($forwriting, $data);
fclose($forwriting);
?>

Testing

Used the following POST method with curl to test with.

curl -X POST -H "Content-Type: application/json" --data '{"test":"1"}' http://localhost

Again, but with a username/password[5]

curl --user test:test -X POST -H "Content-Type: application/json" --data '{"test":"1"}' http://localhost

Final Config

Not finished, for reference.

yum install httpd php python2-certbot-apache
htpasswd -Bc /etc/httpd/password user

cat << EOF >> /etc/httpd/conf.d/vhost.conf
<VirtualHost *:80>
DocumentRoot /var/www/html/
<Directory /var/www/html/>
AuthType Basic
AuthName "Restricted"
AuthBasicProvider file
AuthUserFile "/etc/httpd/password"
Require valid-user
</Directory>
</VirtualHost>
EOF

certbot --apache

mv /etc/httpd/conf.d/ssl.conf ./
touch /etc/httpd/conf.d/ssl.conf
echo "Listen 443" >> /etc/httpd/conf.d/vhost-le-ssl.conf
systemctl restart httpd