Diskuze: Odeslání form do database.txt přes php
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 2 zpráv z 2.
//= 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.
Ahoj.
Úplně 100% ti nerozumím, píšeš dost nepřehledně. :/
No, tak prvně - proč nepoužiješ databázi, když právě k tomuto účelu je určena? Nemůžeš? Pak ok... Nechceš? Nauč se to, bude se ti to hodit.
Tohle je co? Vytváříš soubor s <?php a hned za to vkládáš něco, co v .php souboru nemá v tomto formátu co dělat. Pokud to je ilustrativní, ok, ale i tak nevidím důvod, proč "databázový" soubor začíná <?php - server nemá co zpracovávat a pokud by se o to pokusil, skončí to chybou.
<?php
id|date|jmeno|bydliste|datumnarozeni|
?>
Ten tvůj kód víceméně funguje - v čem je problém? Při zavolání skriptu vezme údaje a vloží je na začátek souboru. Pokud bys chtěl zapisovat na konec, tak by ses obešel bez té konstrukce na konci fce file_put_contents, jelikož by ti stačilo přidat příznak 'FILE_APPEND' na konec funkce (případně i LOCK_EX, aby ti data nepřepsal v půlce jiný proces). A osobně mi je tedy jedno, jestli řadím data sestupně nebo vzestupně, pokud jsou v takto příšerném formátu.
Ten formát ukládání je cesta do záhuby. Pokud už nechceš používat
databázi, tak ukládej data tak, aby měly nějakou rozumnou podobu. Osobně
bych v tom případě volil JSON, případně serializovaná data.
Jakmile totiž budeš chtít ukládat či parsovat složitější údaje, tak
strašně narazíš.
Když ukládáš údaje, tak se používá escapování, htmlspecialchars se používá při výpisu dat, nikoliv při ukládání.
Co se týče exportu, tak být tebou, tak použiji 3 soubory (možná to tak
už máš) a každý ať se napřed chová 100% podle očekávání.
1 - databázový soubor (čistě na data, to už máš)
2 - zápisový soubor
3 - exportovací soubor
Zobrazeno 2 zpráv z 2.