Procedura: salvare file con il controllo RichTextBox Windows Form
Aggiornamento: novembre 2007
Il controllo RichTextBox Windows Form consente di scrivere le informazioni da visualizzare in uno dei seguenti formati:
Testo normale
Testo normale Unicode
RTF (Rich-Text Format)
RTF con spazi al posto di oggetti OLE
Testo normale con una rappresentazione in forma di testo di oggetti OLE
Per salvare un file, chiamare il metodo SaveFile, che può essere utilizzato anche per salvare dati in un flusso. Per ulteriori informazioni, vedere SaveFile(Stream, RichTextBoxStreamType).
Per salvare il contenuto del controllo in un file
Determinare il percorso del file da salvare.
Per eseguire questa operazione in un'applicazione reale, viene in genere utilizzato il componente SaveFileDialog. Per informazioni generali, vedere Cenni preliminari sul componente SaveFileDialog (Windows Form).
Chiamare il metodo SaveFile del controllo RichTextBox, specificando il file da salvare e, facoltativamente, un tipo di file. Se si chiama il metodo utilizzando come unico argomento un nome file, il file verrà salvato come RTF. Per specificare un altro tipo di file, chiamare il metodo con un valore dell'enumerazione RichTextBoxStreamType come secondo argomento.
Nell'esempio riportato di seguito, il percorso impostato per la posizione del file RTF coincide con la cartella Documenti. Si consiglia di utilizzare questa posizione perché tale cartella è presente nella maggior parte dei computer che esegue il sistema operativo Windows. La scelta di questa posizione consente inoltre di eseguire l'applicazione senza problemi agli utenti che dispongono di livelli di accesso minimo. Nell'esempio riportato di seguito si presuppone che un controllo RichTextBox sia già stato aggiunto al form.
Public Sub SaveFile() ' You should replace the bold file name in the ' sample below with a file name of your own choosing. RichTextBox1.SaveFile(System.Environment.GetFolderPath _ (System.Environment.SpecialFolder.Personal) _ & "\Testdoc.rtf", _ RichTextBoxStreamType.RichNoOleObjs) End Sub
public void SaveFile() { // You should replace the bold file name in the // sample below with a file name of your own choosing. // Note the escape character used (@) when specifying the path. richTextBox1.SaveFile(System.Environment.GetFolderPath (System.Environment.SpecialFolder.Personal) + @"\Testdoc.rtf", RichTextBoxStreamType.RichNoOleObjs); }
public void SaveFile() { // You should replace the bold file name in the // sample below with a file name of your own choosing. richTextBox1.SaveFile(System.Environment.GetFolderPath (System.Environment.SpecialFolder.Personal) + "\\Testdoc.rtf", RichTextBoxStreamType.RichNoOleObjs); }
public: void SaveFile() { // You should replace the bold file name in the // sample below with a file name of your own choosing. richTextBox1->SaveFile(String::Concat (System::Environment::GetFolderPath (System::Environment::SpecialFolder::Personal), "\\Testdoc.rtf"), RichTextBoxStreamType::RichNoOleObjs); }
Nota sulla sicurezza: Se il file non esiste, ne viene creato uno nuovo nell'esempio. Per poter creare un file in un'applicazione, è necessario che l'applicazione disponga di accesso in creazione alla cartella. Le autorizzazioni vengono impostate tramite gli elenchi di controllo di accesso (ACL). Se il file è già esistente, l'applicazione necessita solo dell'accesso in scrittura, ossia di un privilegio inferiore. Laddove possibile, è più sicuro creare il file durante la fase di distribuzione e concedere solo accesso in lettura a un unico file, anziché accesso in creazione a una cartella. È inoltre più sicuro scrivere i dati nelle cartelle utente anziché nella cartella principale o nella cartella Programmi.