Diskuze: PHP - zápis do souboru
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Tvůrce

Zobrazeno 12 zpráv z 12.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Proč zapisuje takhle riskantně? Když už, tak použij funkci serialize() nebo json_encode().
Možná nemáš právo zápisu do aktuálního adresáře. Bývá to častá chyba. Mohl by sis ji aspoň vypsat.
Tak to funguje:
<?php
if ($_POST["nick"] != null)
{
$fileA = fopen("high.txt", 'a') or die("can't open file");
fwrite($fileA, $_POST["nick"] + '|' + $_POST["score"] + '|' + time() + '\n');
fclose($fileA);
}
$fileR = fopen("high.txt", 'r') or die("can't open file");
$lines = array();
while (!feof($fileR))
$lines[] = fgets($fileR);
fclose($fileR);
?>
<script type="text/javascript">
<?php
$jsLines = json_encode($lines);
echo "var lines = ".$jsLines.";";
?>
</script>
Ale místo nicku, skóre a data to vypíše 12345...
Výstup:
Sam|2501354430180\\n$_POST[\"nick\"]|$_POST[\"score\"]|$date\\n$_POST[\"nick\"];$_POST[\"score\"];$date\\nSam;250;12\/02\/2012 01:47:16 am\\n
Kód:
$date = date('m/d/Y h:i:s a', time());
fwrite($fileA, htmlspecialchars($_POST["nick"]) .';'. htmlspecialchars($_POST["score"]) .';'. $date .'\n');
Pořád tam máš injekci. Když už chceš zapisovat ve formátu CSV, používej funkce fputcsv() a fgetcsv().
if ($_POST["nick"] != null)
{
$fileA = fopen("high.csv", 'a') or die("can't open file");
fputcsv($fileA, array($_POST["nick"], $_POST["score"], date('m/d/Y h:i:s a', time())));
fclose($fileA);
}
$fileR = fopen("high.csv", 'r') or die("can't open file");
$lines = array();
while (($data = fgetcsv($fileR, 1000, ",")) !== FALSE) {
$lines[] = $data;
fclose($fileR);
Parse error: syntax error, unexpected $end
To je přesně ten důvod, proč se mají složené závorky používat i pro jednořádkové bloky.
BTW: v Pythonu by se ti to nestalo.
Bude problém v přístupu více uživatelů najednou? (Nenapadá mne, jak to ošetřit. - nemohu to jednomu zakázat...)
Pokud budeš přidávat vždy jen jeden záznam do velikosti 8 KB, tak problémy nebudou. Proto se tento způsob hodí pro logování. Pokud jich bude víc, mohou se při současném zápisu promíchat.
Pokud máš jen trochu vyšší nároky, použij databázi.
Právěže DB se mi moc nechce - je to jen High Score. Takže velikost by to splňovat mělo - Nick, Skóre a Datum... (Nick omezím - dejme tomu na 12 znaků.)
Spousta aplikací pro takový účel používá SQLite. V databázi můžeš totiž údaje nejen přidávat, ale i přepisovat a mazat. V textovém souboru si to dovolit nemůžeš.
Zobrazeno 12 zpráv z 12.