Согласно этой статье MSDN:
W3C Extended Формат файла журнала (IIS 6.0)
В нем говорится, что cs(Referrer)
содержит информацию REFERER, которую можно прочитать из файлов журнала IIS.
Я пытаюсь отобразить информацию журнала с помощью элемента управления ASP.NET Repeater:
<asp:Repeater ID="rptlIISLogEntries" runat="server">
...
...
<ItemTemplate>
<tr>
<td><%# Eval("time")%></td>
<td><%# Eval("cs(Referrer)")%></td>
</tr>
</ItemTemplate>
</asp:Repeater>
Строка с Eval("cs(Referrer)"
вызывает исключение:
DataBinding:'System.Data.DataRowView' does not contain a property with the name 'cs'.
У меня вопрос, как отобразить информацию REFERER в ретрансляторе?
Код для анализа файла журнала и привязки его к повторителю выглядит следующим образом:
string theDate =txtDate.Text;
string FILE_NAME = @"\\" +txtMachine.Text +
@"\C$\WINNT\System32\LogFiles\" +
drpSiteBox.SelectedItem.Text + @"\ex" + theDate + ".log";
FileStream fs = new FileStream(FILE_NAME, FileMode.Open,
FileAccess.Read,FileShare.ReadWrite);
StreamReader sr = new StreamReader(fs);
string strResult = sr.ReadToEnd();
sr.Close();
fs.Close();
sr=null;
fs=null;
string[] arLogLines = strResult.Split(Convert.ToChar("\n"));
dt = new DataTable("log");
string revisedColmNames=arLogLines[3].Replace("#Fields: ","");
string[] arColm=revisedColmNames.Split(Convert.ToChar(" "));
for(int j=0;j<arColm.Length;j++)
{
dt.Columns.Add(arColm[j]);
Debug.WriteLine(arColm[j]);
}
for (i =arLogLines.Length-1; i>3;i--)
{
// need this because some logs get additional data appended
// aren't unhandled exceptions great? The CLR just loves 'em...
try
{
dt.Rows.Add(arLogLines[i].Split(Convert.ToChar(" ")));
}
catch {}
}
DataGrid1.DataSource=dt;
DataGrid1.DataBind();
Примечание: это тот же код, что и в http://www.eggheadcafe.com/articles/20021203.asp