Сделать реальный экран-заставку перед запросом http - PullRequest
0 голосов
/ 19 октября 2011

Мне нужно создать заставку C #, которая будет запускаться до вызова default.aspx.

Когда я просматриваю свой URL, я вижу сообщение IE 8.0 waiting for http://xxxxx с пустым экраном, и через некоторое время моя первая страница полностью загружается. Как я могу обработать \ перехватить это сообщение, чтобы показать мой экран-заставку, пока не будет установлено соединение?

Я пытался использовать HttpListener, но, похоже, это не правильный путь.

Ответы [ 2 ]

1 голос
/ 19 октября 2011

Вы не можете показать что-то о своем сайте, пока браузер не свяжется с ним.

То, что вы можете сделать, это иметь легкую стартовую страницу (которая быстро загружается) в корневаш сайт, а затем перенаправить на более тяжелую "настоящую" страницу.

0 голосов
/ 19 октября 2011

Вы можете отключить буферизацию вывода, чтобы сделать что-то, как вы просите, но содержимое «кода ожидания» не должно использовать какие-либо другие загружаемые ресурсы. Общение также станет более разговорчивым.

ASPX-страница:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="BufferingResponse.Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        Waiting...
    </div>
    </form>
</body>
</html>

Код:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace BufferingResponse
{
    public partial class Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            Context.Response.BufferOutput = false;

            // simulate some work...
            System.Threading.Thread.Sleep(5000);

            Response.Write("<div>Another response five seconds later...</div>");
        }
    }
}
...