Lucene.Net fallisce nel mio host perché chiama GetTempPath (). Qual è il problema?
-
10-07-2019 - |
Domanda
Sto usando Lucene.Net in un'applicazione ASP.NET su un host condiviso. Ho questa traccia dello stack mostrata di seguito. Qual è il problema?
[SecurityException: richiesta di autorizzazione del tipo 'System.Security.Permissions.EnvironmentPermission, mscorlib, Version = 2.0.0.0, Culture = neutral, PublicKeyToken = b77a5c561934e089' non riuscita.] System.Security.CodeAccessSecurityEngine.Check (Richiesta oggetto, StackCrawlMark & ??amp; stackMark, Boolean isPermSet) +0 System.Security.CodeAccessPermission.Demand () +59 System.IO.Path.GetTempPath () +54 Lucene.Net.Store.FSDirectory..cctor () +73
Soluzione
Ecco la risposta alla mia domanda. La soluzione era modificare Lucene.Net.Store.FSDirectory, commentando questa riga inutilizzata:
// Comments out by Corey Trager, Oct 2008 to workaround permission restrictions at shared host. This is not used.
// public static readonly System.String LOCK_DIR = SupportClass.AppSettings.Get("Lucene.Net.lockDir", System.IO.Path.GetTempPath());
C'è stato un altro ostacolo per l'autorizzazione di sicurezza dopo, ed ecco anche questa soluzione alternativa. Non capisco perché un modo per ottenere i nomi dei file in una directory venga bloccato e un altro modo non bloccato.
public override System.String[] List()
{
/* Changes by Corey Trager, Oct 2008, to workaround permission restrictions at shared host */
System.IO.DirectoryInfo dir = new System.IO.DirectoryInfo(directory.FullName);
System.IO.FileInfo[] files = dir.GetFiles();
string[] list = new string[files.Length];
for (int i = 0; i < files.Length; i++)
{
list[i] = files[i].Name;
}
return list;
/* end of changes */
// System.String[] files = SupportClass.FileSupport.GetLuceneIndexFiles(directory.FullName, IndexFileNameFilter.GetFilter());
// for (int i = 0; i < files.Length; i++)
// {
// System.IO.FileInfo fi = new System.IO.FileInfo(files[i]);
// files[i] = fi.Name;
// }
// return files;
}