AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Appdata, Roaming, etc.

Ein Thema von freimatz · begonnen am 4. Apr 2020 · letzter Beitrag vom 25. Apr 2020
Antwort Antwort
Seite 1 von 2  1 2      
freimatz

Registriert seit: 20. Mai 2010
1.445 Beiträge
 
Delphi 11 Alexandria
 
#1

Appdata, Roaming, etc.

  Alt 4. Apr 2020, 16:05
Hallo,
ich hoffe hier ist das Thema richtig. Ich möchte die Ablage von Dateien meines Programmes mal "richtig" machen. Also wo kommen die Daten hin. Ich habe https://bitreporter.de/windows/wofue...ocal-locallow/ gelesen, so ganz klar ist es mir nicht.

1. Ich habe ein Setup, das kopiert die exe und andere Dateien in den Installationsordner. Das ist soweit klar.

2. a) Dazu gibt es noch weiter Daten, die bei Bedarf dazu installiert werden. Der Anwender startet dazu das Programm, geht auf "Einbindung" und holt sich weitere Inhalte und/oder Funktionen von Diskette, CD-ROM, Datei oder Internet. Bislang lege ich die unter dem Programmordner ab. Das mag Windows jedoch oft mal nicht. Der Umfang ist meist so um die 20MByte, es gibt auch Dinge die auch mal 500 oder 1500MByte haben.
b) Es gibt ein integriertes Hilfesystem. Jje nach eingebunden Dingen wird dies inhaltlich angepasst. Die Dateien dazu liegen auch da.
Ich meine diese Dateien müssten eigentlich in AppData liegen aber wo genau? Roaming oder Local?

3. Es gibt Einstellungen. Die meisten sind in einer INI-Datei. Die liegt je nach Installation auch direkt beim Programm oder in AppData. Im letzteren Fall ist das in %appdata%\<Unternehmsname>\<Produkname>\<Installat ion>. Man mehrere Instanzen meines Programmes installieren. Für jede gibt es da einen Unterordner <Installation>.
Bei den Einstellungen gibt es solche die spezifisch für eine Maschine sind, z.B. welche Dinge eingebunden sind. Dann gibt es Einstellungen vom Benutzer wie z.B. eine Farbe.
Allerdings gibt es die Einstellungen auch in <User>\Dokumente\<Produktname>. Wann welches benutzt wird bin ich mir selber auch nicht mehr klar. Allerdings dürfte auch nur eine Variante richtig sein.

Gibt es irgendwo Empfehlungen zu diesem Thema?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.197 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: Appdata, Roaming, etc.

  Alt 4. Apr 2020, 16:10
Gibt es irgendwo Empfehlungen zu diesem Thema?
Ja, In der MSDN ...

Es gibt %AppData% (local/roaming). Da sollt das hin was Anwenderspezifisch ist (persönlich Einstellungen, persönliche Daten, ...)
Dann gibt es ProgramData. Dort sollte das hin was für die Anwendung am Lokalen Rechner für alle Nutzer relevant sind und sich ändern können
Programme gehört nur die Anwendungsdateien + "festen" Zusatzdateien hin.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
freimatz

Registriert seit: 20. Mai 2010
1.445 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Appdata, Roaming, etc.

  Alt 4. Apr 2020, 16:34
Danke. ProgramData hatte ich nicht mehr auf dem Schirm. Da hören wohl die Dateien von 2. hin. (und teilweise von 3.)
Hast du noch eine uRL für MSDN. Einiges gegoogelt aber nichts direkt davon gefunden. (Interessant fand ich noch das.)
  Mit Zitat antworten Zitat
Benutzerbild von Dalai
Dalai
Online

Registriert seit: 9. Apr 2006
1.682 Beiträge
 
Delphi 5 Professional
 
#4

AW: Appdata, Roaming, etc.

  Alt 4. Apr 2020, 17:38
Eigentlich ist die Geschichte recht einfach: Alles, was der Nutzer nicht schreiben muss, gehört ins Programmverzeichnis. Sämtliche Einstellungsdateien entweder nutzerspezifisch (%AppData%) oder gemeinsam (%Public% oder %AllUsersProfile% (=%ProgramData%)) ablegen. Im %ProgramData% haben auch Nutzer Schreibrechte. Generell gilt: Je weniger Schreibrechte ein Nutzer an den Dateien hat, desto weniger kann kaputtgemacht werden.

Schwierig wird es dann, wenn der Nutzer Änderungen am Programmumfang vornehmen können soll. Eigentlich sollte sowas dem Admin vorbehalten sein, aber mit einem Neustart als Admin (Verb runas) lässt sich auch das lösen. Für Updates gibt's ja zahlreiche Lösungen, auch wenn nur wenige davon wirklich technisch zufriedenstellend sind.

Der Unterschied %AppData% und %LocalAppData% ist nur für Roaming Profiles in Domänen relevant. Wenn deine Software nicht in derartigen Umgebungen zum Einsatz kommt, brauchst du dir darüber keine Gedanken zu machen (und kannst einfach %AppData% benutzen).

Grüße
Dalai
  Mit Zitat antworten Zitat
freimatz

Registriert seit: 20. Mai 2010
1.445 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: Appdata, Roaming, etc.

  Alt 4. Apr 2020, 18:45
Zu 99% sind es Einzelplätze, zumeist privat. Da gibt es keinen Admin. Da passt Dein letzter Satz gut dazu. LocalAppData kann ich mir dann sparen. Danke.
Ob und dass ein Benutzer Schreibrechte hat ist mir relativ egal. Im Supoprtall könnte das nicht schlecht sein.

Den ersten Satz finde ich jedoch nicht "ganz einfach". Was meinst Du mit "Das der Nutzer nicht schreiben muss". Der Anwender schreibt doch selber nie etwas, sondern das Programm. Meinst Du damit sowas wie "Datei|Speichern unter". Wo käme eine Adressdatenbank hin? Wo eine Textdatei, die der Anwender mit dem Programm editieren kann?
Könnte man allgemein sagen, dass alles was man sichern sollte käme in AppData und alle Dateien die das Programm wieder herstellten könnte (wie z.B. Indexdateien) kämen in ProgramData?
  Mit Zitat antworten Zitat
Benutzerbild von Dalai
Dalai
Online

Registriert seit: 9. Apr 2006
1.682 Beiträge
 
Delphi 5 Professional
 
#6

AW: Appdata, Roaming, etc.

  Alt 4. Apr 2020, 22:13
Ob und dass ein Benutzer Schreibrechte hat ist mir relativ egal.
Nicht doch. Genau diese Ansicht sorgt immer wieder dafür, dass Programme im Nutzerprofil landen, wo sie absolut nichts zu suchen haben. Oder ähnlich schlimm, dass Vollzugriff für "Jeder" vom Setup gesetzt wird. So nach dem Motto: "Dann geht's in jedem Fall". Die meisten Admins würden solchen Software-Herstellern am liebsten den Hals rumdrehen, und die Security-Spezialisten übrigens ebenfalls, DLL Sideloading bzw. DLL Hijacking sei da nur als Beispiel genannt.

Zitat:
Den ersten Satz finde ich jedoch nicht "ganz einfach". Was meinst Du mit "Das der Nutzer nicht schreiben muss". Der Anwender schreibt doch selber nie etwas, sondern das Programm.
Ob ein Programm diese Daten schreibt oder der Nutzer an sich, spielt doch keine Rolle. Jedes Programm läuft mit bestimmten Rechten, standardmäßig sind das die des Nutzers. Wenn ein Programm für bestimmte Dinge mehr Rechte braucht, sollte es diese beim Nutzer bzw. beim OS (z.B. per UAC) anfordern.

Zitat:
Wo käme eine Adressdatenbank hin? Wo eine Textdatei, die der Anwender mit dem Programm editieren kann?
Bei der DB kommt es darauf an, ob diese von mehreren Benutzern ver-/bearbeitet werden soll. Wenn ja, dann irgendwo im %Public%, wenn nicht, dann im %AppData% oder vom Benutzer entscheiden lassen.

Zitat:
Könnte man allgemein sagen, dass alles was man sichern sollte käme in AppData und alle Dateien die das Programm wieder herstellten könnte (wie z.B. Indexdateien) kämen in ProgramData?
Muss der Index vom Nutzer (immer wieder) geschrieben werden können? Wenn nicht, dann gehört sowas eher ins Programmverzeichnis.

Ach, noch eine Sache: Verzeichnisse wie %Public%\Documents und %UserProfile%\Documents sind für den Nutzer da, nicht für Daten, die von Programmen abgelegt werden (dafür gibt's %AppData% und %ProgramData%). Mich nervt es immer wieder, wenn ich zwischen den von mir angelegten Verzeichnissen welche sehe, die durch irgendeine Software angelegt wurden, also ohne dass ich das bewusst getan hätte. Mir ist klar, warum Software-Hersteller meinen, das sei eine gute Idee (einfache Auffindbarkeit für den Nutzer, Backup-Möglichkeiten), aber es ist keine wirklich gute Idee.

Grüße
Dalai
  Mit Zitat antworten Zitat
freimatz

Registriert seit: 20. Mai 2010
1.445 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Appdata, Roaming, etc.

  Alt 16. Apr 2020, 17:25
Hallo zusammen,
Danke für alle Antworten. In den letzten Tagen habe ich mich mehr Gedanken gemacht welche Daten es überhaupt gibt in meinem Programm. Über zehn verschiedene Arten habe ich bislang identifiziert.

Schwierig finde ich herauszufinden was "für alle Nutzer relevant" ist und was für den jeweiligen Nutzer spezifisch ist. Ich kenne keinen Anwender meines Programmes, der sich ein PC mit jemand anderen teilt. (Ausgenommen ich selber und meine Frau. Auf dem LapTop habe ich das Programm installiert, sie will jedoch keine eigenen Einstellungen.)

Eine neue Frage ist mir aufgetaucht. In etlichen Setups gab es früher die Option "Für alle Benutzer" oder so ähnlich. Was hat das damit auf sich? Wird dann statt %AppData% dann alles in %AllUsersProfile% (oder %ProgramData%) gespeichert? In letzter Zeit habe ich diese nicht mehr gesehen. Ist die nicht mehr wichtig?

@Bernhard: Habe leider in der MSDN noch keine offzielle Doku gefunden geschweige denn eine Empfehlung gefunden. Das Beste war noch eine Doku zu .NET

@Dalai: bin etwas verwirrt. Du schlägst "%Public%" vor (aber nicht %Public%\Documents). Ich komme da bei mir bei in "C:\Users\Public" raus. In %Public% selber ist bei mir fast nichts drin. Lediglich "CyberLink" hat da was reingeschrieben. In %AppData% dagegen habe ich 74 Ordner.

Und wegen %UserProfile%\Documents - hm, ich bin da auch so einer, muss ich noch prüfen. Ich versuche das dann auch gleich besser zu machen.
  Mit Zitat antworten Zitat
Redeemer

Registriert seit: 19. Jan 2009
Ort: Kirchlinteln (LK Verden)
1.052 Beiträge
 
Delphi 2009 Professional
 
#8

AW: Appdata, Roaming, etc.

  Alt 16. Apr 2020, 17:55
Hallo zusammen,
Danke für alle Antworten. In den letzten Tagen habe ich mich mehr Gedanken gemacht welche Daten es überhaupt gibt in meinem Programm. Über zehn verschiedene Arten habe ich bislang identifiziert.

Schwierig finde ich herauszufinden was "für alle Nutzer relevant" ist und was für den jeweiligen Nutzer spezifisch ist. Ich kenne keinen Anwender meines Programmes, der sich ein PC mit jemand anderen teilt. (Ausgenommen ich selber und meine Frau. Auf dem LapTop habe ich das Programm installiert, sie will jedoch keine eigenen Einstellungen.)
In aller Regel haben Programme keine "für alle Nutzer relevanten" Einstellungen. Mit persönlichen Vorlieben hat das nichts zu tun eher mit administrativen Notwendigkeiten, z.B. allen Benutzern ein Plugin oder ein Sprachpaket installieren können.

Schau dir doch einfach Windows an. Welche Einstellungen können Normalos ändern, was dann alle anderen betrifft? Persönlich fallen mir nur einige Punkte der Eigenschaften von Anzeige ein sowie die Einrichtung von Netzwerkdruckern.

In etlichen Setups gab es früher die Option "Für alle Benutzer" oder so ähnlich.
Da geht es um Verknüpfungen. Sollen die im Startmenü/Desktop von %USERNAME% oder von Öffentlich installiert werden?
Janni
2005 PE, 2009 PA, XE2 PA
  Mit Zitat antworten Zitat
Benutzerbild von Dalai
Dalai
Online

Registriert seit: 9. Apr 2006
1.682 Beiträge
 
Delphi 5 Professional
 
#9

AW: Appdata, Roaming, etc.

  Alt 16. Apr 2020, 19:40
In %Public% selber ist bei mir fast nichts drin. Lediglich "CyberLink" hat da was reingeschrieben.
Naja, jedes Windows hat dort mindestens Documents, Downloads, Pictures, Videos usw.

Zitat:
In %AppData% dagegen habe ich 74 Ordner.
Klar, ist ja nutzerspezifisch. Schau mal unter dem nutzerunabhängigen %ProgramData%, dort dürfte weit weniger liegen.

Zitat:
Und wegen %UserProfile%\Documents - hm, ich bin da auch so einer, muss ich noch prüfen. Ich versuche das dann auch gleich besser zu machen.
Nicht, dass ich falsch verstanden werde: Für Dateien, die per Speichern-Dialog abgelegt werden sollen, bietet sich %UserProfile%\Documents (als Vorschlag) durchaus an, aber nicht für Dateien, mit denen der Nutzer nichts direkt machen soll. Denn man sollte berücksichtigen, dass sich %UserProfile%\Documents mit Bordmitteln verschieben lässt (Registerkarte "Pfad" in den Eigenschaften), und normalerweise macht der Nutzer das, um die eigenen Daten auf andere Partitionen/Platten zu packen (nicht die Anwendungsdaten von Programmen).

Grüße
Dalai
  Mit Zitat antworten Zitat
freimatz

Registriert seit: 20. Mai 2010
1.445 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: Appdata, Roaming, etc.

  Alt 17. Apr 2020, 08:20
Dalai, sorry das verstehe ich immer noch nicht richtig oder es leuchtet mir nicht ein.
Ja, bei mir hat es in %Public% auch Documents, Downloads, Pictures, Videos und so. Aber die Daten meines Programmes passen in keine dieser Kategorien.
In %ProgramData% habe ich 70 Ordner, von Adobe bis XamarinAndroidPlayer. Wenn ich mich dazu gesellen soll verstehe ich das. Aber wieso soll ich etwas in %Public% speichern (so habe ich dich zumindest verstanden) wenn es doch auch sonst fast keiner tut.
Warum sollte z.b. eine DB, die von mehreren Benutzern bearbeitet wird, in %Public% und nicht in %ProgramData%.
(Wegen den %UserProfile%\Documents, ich meine das ist bei mir schon so, dass es nur ein Vorschlag für die eigenen Dateien des Anwender sind.)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:30 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz