Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

Datenbankexport per PHP-Datei

Frage Entwicklung PHP

Mitglied: 17735

17735 (Level 2)

10.07.2006, aktualisiert 23.08.2006, 5167 Aufrufe, 5 Kommentare

Hi,

ich möchte auf meiner Homepage Benutzern mit Administratorrechten die Möglichkeit geben, per Klick auf "Vollbackup" einen kompletten Export aus der MySQL-Datenbank (also alle Tabellen) vorzunehmen, der dann in einer *.sql-Datei gespeichert wird (oder an den Benutzer gesendet wird) und den Inhalt schon in der MySQL-Sprache enthält. Also gleiche Funktion wie bei PHPMyAdmin "Exportieren" der Datenbank.

Wie kann ich das am Geschicksten lösen, so dass der Code in der *.sql-Datei schon in der MySQL-Sprache verfasst ist?

Gruß,
Ahnenforscher
Mitglied: filippg
10.07.2006 um 23:56 Uhr
Hallo,

ich weiss nicht, was MySQL da alles unterstützt. Du solltest vielleicht mal in der Doku schauen, MSSQL bietet z.B. bestimmte SQL-Befehle für Massenim- und -export, kann sein das MySQL da ähnliches hat. Ansonsten bietet ja auch phpMyAdmin diese Funktionalität. Und da kannst du entweder direkt das verwenden, oder du schaust halt im Quelltext, wie es da gemacht wird (es leben OpenSource), dann kannst du das auch in eigene Anwendungen integrieren (bei direkter Kopie von Funktionen Lizenzbestimmungen beachten!).

Filipp
Bitte warten ..
Mitglied: Guenni
11.07.2006 um 15:44 Uhr
@17735

Hi,

im Homeverzeichnis des Benutzers muß ein Verzeichnis existieren mit Vollzugriff
für jeden.

Der Benutzer, der das Dump ausführt, muß in der MySQL-Datenbank ein Konto haben.

In der folg. PHP-Seite kann der Benutzer:
-seinen Namen
-sein Passwort
-die Datenbank
-den Pfad inclusive Dateinamen (z.B. /home/benutzername/dump/db.sql)

eingeben.

<?
if($cmd){
exec("mysqldump -ac --user=$user --password=$pass $db > $dump");
}
?>
<html>
<head>
<title>MySQL-Dump</title>
</head>
<body>
<form action="dump.php">
Benutzer<input type="text" name="user">
Passwort<input type="password" name="pass">
Datenbank<input type="text" name="db">
Dumpfile<input type="text" name="dump">
<input type="submit" value="Sichern" name="cmd">
</form>
</body>
</html>

Es wird eine Datei erstellt mit allen Tabellendefinitionen und Insert's.

Ist jetzt nur mal ein grober Entwurf, eleganter ist es natürlich, die Daten
und Pfadangaben in einer Datenbank zu speichern und dort beim Ausführen
des Script's auszulesen.

Gruß
Günni

PS.: Getestet im Intranet!
Bitte warten ..
Mitglied: 17735
23.08.2006 um 14:55 Uhr
Hi Günni,

lokal / im Intranet funktioniert dieses Skript bei mir nicht, keine Datei wird erzeugt oder an den Browser gesendet, obwohl Eingaben stimmen. Beim Hoster ist der Befehl "exec" aus Sicherheitsgründen deaktiviert. Gibt es eine andere Möglichkeit, ein MySQL-Dump zu erstellen?

Gruß,
Ahnenforscher
Bitte warten ..
Mitglied: Guenni
23.08.2006 um 19:52 Uhr
@17735

Hi,

warum bei dir kein Dump erzeugt wurde, kann ich jetzt aus
der Ferne nicht sagen.

Es gibt aber noch 'ne andere Möglichkeit, ohne exec o.ä..

Systemkommandos, die zwischen mit Shift + `` Taste(neben Backspace) erzeugten
Zeichen stehen, werden vom PHP-Interpreter versucht, diese auch als solche auszuführen.

Folg. Code erzeugt im Browserfenster ein Dump der angegebenen Datenbank:

<?
$output = `mysqldump -ac --user=username --password=passwort datenbank`;
echo "<pre>$output</pre>";
?>

Eine Umleitung in eine Datei…

... datenbank > /Pfad_zum_Dump/Dateiname`;

...funktioniert ebenfalls.

Und wie gesagt, das Zielverzeichnis MUSS von jedem beschreibbar sein
dürfen!

Grüße
Günni
Bitte warten ..
Mitglied: 17735
23.08.2006 um 20:24 Uhr
Nein, das funktioniert leider auch nicht: Lokal wird von XAMPP bei mir nur das <pre></pre> ausgegeben, also kein Dump, beim Dienstleister kommt die Meldung: Warning: shell_exec() has been disabled for security reasons in blabla/mysqldump.php on line 3


(Das "blabla" ist nur symbolisch für das Verzeichnis )

Gruß,
Ahnenforscher
Bitte warten ..
Neuester Wissensbeitrag
CPU, RAM, Mainboards

Angetestet: PC Engines APU 3a2 im Rack-Gehäuse

(1)

Erfahrungsbericht von ashnod zum Thema CPU, RAM, Mainboards ...

Ähnliche Inhalte
PHP
gelöst Externe XML-Datei in PHP auslesen (18)

Frage von Akrosh zum Thema PHP ...

Webentwicklung
HTML Output in eine txt Datei mit VisualBasicScript (2)

Frage von coca22COCA zum Thema Webentwicklung ...

Informationsdienste
gelöst Aktuelle Firefox MSI Datei!? (8)

Frage von Hendrik2586 zum Thema Informationsdienste ...

Heiß diskutierte Inhalte
Grafikkarten & Monitore
Win 10 Grafikkarte Crash von Software? (13)

Frage von Marabunta zum Thema Grafikkarten & Monitore ...

DSL, VDSL
DSL-Signal bewerten (13)

Frage von SarekHL zum Thema DSL, VDSL ...

Switche und Hubs
Trunk für 2xCisco Switch. Wo liegt der Fehler? (9)

Frage von JayyyH zum Thema Switche und Hubs ...

Backup
Clients als Server missbrauchen? (8)

Frage von 1410640014 zum Thema Backup ...