Como salvo o conteúdo do RichTextBox na coluna SQL Varbinary (Byte Array)?
-
06-07-2019 - |
Pergunta
Quero salvar o conteúdo de um RichTextBox em varbinária (= matriz de byte) no formato xamlpackage. Preciso de conselhos técnicos sobre como isso.
Na verdade, preciso saber como converter entre o documento de fluxo para a matriz de bytes.
É recomendável armazená -lo como varbinário, ou isso é uma má ideia?
Atualizar
Fragmento de código:
///Load
byte[] document = GetDocumentFromDataBase();
RickTextBox tb = new RickTextBox();
TextRange tr = new TextRange(tb.Document.ContentStart, tb.Document.ContentEnd)
tr.Load(--------------------------) //Load from the byte array.
///Save
int maxAllowed = 1024;
byte[] document;
RichTextBox tb = new RichTextBox();
//User entered text and designs in the rich text
TextRange tr = new TextRange(tb.Document.ContentStart, tb.Document.ContentEnd)
tr.Save(--------------------------) //Save to byte array
if (document.Length > maxAllowed)
{
MessageBox.Show((document.Length - maxAllowed) + " Exceeding limit.");
return;
}
SaveToDataBase();
TextRange
Solução
Não consigo encontrar meu exemplo completo agora, mas você pode usar o XamlReader e o XamlWriter para colocar o documento dentro e fora de uma string. A partir daí, você pode usar unicodeencoding, asciiencoding ou qualquer que desejar para colocá -lo dentro e fora dos bytes.
Meu exemplo mais curto para definir o documento de uma string ... DocReader é meu leitor de documentos de fluxo
private void SetDetails(string detailsString)
{
if (docReader == null)
return;
if (String.IsNullOrEmpty(detailsString))
{
this.docReader.Document = null;
return;
}
using (
StringReader stringReader = new StringReader(detailsString))
{
using (System.Xml.XmlReader reader = System.Xml.XmlReader.Create(stringReader))
{
this.docReader.Document = XamlReader.Load(reader) as FlowDocument;
}
}
}