У меня есть эта функция в php для загрузки файла, файл будет зашифрован данными, а затем загружен
Класс: соединение - это просто подключение к базе данных
class License extends Connect {
function __construct() {
parent::__construct();
}
public function getLicense($vars){
// file_put_contents( "/var/log/datapost/clientinfo.log", date('r'). " ". var_export($vars,true) . PHP_EOL, FILE_APPEND );
$sql = "select * from License where license_id={$vars->data->license_id}";
$res = $vars->db->query( $sql );
if($obj=$res->fetch_object()){
$filename = "License".$vars->data->license_id.".json";
// get the private key
$pk = file_get_contents("/var/www/datapost/clientinfo/keys/key1.pem");
// // private key
$res = openssl_get_privatekey($pk,"passsword");
// // encrypt it
$x=openssl_private_encrypt( json_encode($obj),$crypttext,$res);
// save the encryption
//
file_put_contents("/var/www/datapost/clientinfo/license/license{$vars->data->license_id}}.json",$crypttext);
// header('Content-Description: File Transfer');
header('Content-Type: text/plain');
header('Content-Disposition: attachment; filename="' . $filename . '"');
// header('Expires: 0');
// header('Cache-Control: must-revalidate');
// header('Pragma: public');
// header('Content-Length: ' . strlen($crypttext));
echo $crypttext;
file_put_contents("/var/log/datapost/{$filename}", $crypttext, fopen("http://192.168.200.114/var/log/datapost/{$filename}", 'r' ));
flush();
file_put_contents( "/var/log/datapost/clientinfo.log", date('r'). " WOOHOO! $crypttext" . PHP_EOL, FILE_APPEND );
}
else {
file_put_contents( "/var/log/datapost/clientinfo.log", date('r'). " AAARG SHIT ".var_export($res,true) . PHP_EOL, FILE_APPEND );
}
}
}
но по какой-то причине он не работает, данные отправляются в HTTP-запросе, но файл не загружается с данными, любая помощь оценивается
Вот запрос ajax в приложении extjs, (при нажатии кнопки)
onButtonClick7: function(button, e, eOpts) {
Ext.Ajax.request({
url: 'system/index.php',
method: 'POST',
params: {
class: 'License',
method: 'getLicense',
data: Ext.encode({
license_id: Ext.getCmp('overviewGrid').selection.data.license_id
})
},
success: function( response ){
var object = Ext.decode( response.responseText, true );
//Ext.getStore('LicenseAllStore').reload();
// window.open('http://192.168.200.114/datapost/clientinfo/license/BLAH_BLAGH3.json');
},
failure: function( response ){
var object = Ext.decode( response.responseText, true );
Ext.MessageBox.alert( 'Status', object.message );
}
});
},
Здесь это можно сделать следующим образом:
ИСПОЛЬЗУЯ CURL:
$ch = curl_init();
$source = "http://someurl.com/afile.zip";
curl_setopt($ch, CURLOPT_URL, $source);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$data = curl_exec ($ch);
curl_close ($ch);
$destination = "/asubfolder/afile.zip";
$file = fopen($destination, "w+");
fputs($file, $data);
fclose($file);
ИСПОЛЬЗОВАНИЕ file_put_contents()
:
Поскольку PHP 5.1.0, file_put_contents()
поддерживает запись по частям путем передачи дескриптора потока в качестве параметра $data
:
file_put_contents("Tmpfile.zip", fopen("http://someurl/file.zip", 'r'));
Из руководства:
Если данные [это второй аргумент] является ресурсом потока, оставшийся буфер этого потока будет скопирован в указанный файл. Это похоже на использование
stream_copy_to_stream()
.
Еще одна часть вашего вопроса:
Так как вы пытаетесь преобразовать массив в json, а затем сохраните этот json-код в текстовый файл, вот, вот как именно вы это сделаете:
<?php
$data = array(
array('team_name' => "Team 1", 'wins' => "3", 'losses' => "0" ), //3
array('team_name' => "Team 2", 'wins' => "2", 'losses' => "1" ), //2
array('team_name' => "Team 3", 'wins' => "1", 'losses' => "2" ), //1
array('team_name' => "Team 4", 'wins' => "0", 'losses' => "3" ), //1
array('team_name' => "Team 5", 'wins' => "3", 'losses' => "0" ), //3
array('team_name' => "Team 6", 'wins' => "2", 'losses' => "1" ) ); //2
//if you want to just print the array here
echo json_encode($data);
// If you want to save the array into a text file
$json_file = fopen("array_into_json.txt" , "a") or die("Unable to open file!");
fwrite($json_file,json_encode($data). "\r\n");
fclose($json_file);
?>
Примечание. Вы можете сделать то же самое с массивом, который вы извлекаете из своей базы данных, используя этот код, просто заменяя массив $data
массивом MySQLi..!
Живой код: https://eval.in/562247