答案:除非你代碼里面做了特殊判斷,否則仍然正在執(zhí)行。

注意點(diǎn):

1、客戶端顯示頁(yè)面的時(shí)候,后 " /> 樱花动漫成人隐藏入口,在线视频 亚洲,国产产乱码一二三区别免费

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

ASP.net 頁(yè)面被關(guān)閉后,服務(wù)器端是否仍然執(zhí)行中?

問題:當(dāng)一個(gè)正在執(zhí)行中的ASPX頁(yè)面執(zhí)行到一半的時(shí)候,瀏覽器中你關(guān)閉了這個(gè)頁(yè)面,服務(wù)器端對(duì)應(yīng)的這個(gè)頁(yè)面的代碼仍然在執(zhí)行么?

答案:除非你代碼里面做了特殊判斷,否則仍然正在執(zhí)行。  

注意點(diǎn):

1、客戶端顯示頁(yè)面的時(shí)候,后臺(tái)已經(jīng)執(zhí)行完了的頁(yè)面對(duì)象早已經(jīng)不存在了。當(dāng)然這時(shí)候談不上服務(wù)器段執(zhí)行不執(zhí)行的問題了。

2、頁(yè)面還沒有返回,處于等待狀態(tài)的時(shí)候。關(guān)閉ASPX頁(yè)面,才會(huì)涉及到上面提到的服務(wù)器端仍然在執(zhí)行的情況。

3、客戶端關(guān)閉的時(shí)候根本不向服務(wù)器發(fā)送指令。

4、除非你代碼里面做了特殊判斷,這里的特殊判斷指用 if(!Response.IsClientConnected) 來(lái)檢測(cè)狀態(tài)而用代碼終止運(yùn)行。

下面的簡(jiǎn)單代碼就是演示關(guān)閉頁(yè)面后,看是否仍然在執(zhí)行?

你可以在這個(gè)頁(yè)面打開后, 還沒有返回任何信息的時(shí)候把這個(gè)頁(yè)面關(guān)閉,然后看指定目錄下是否有對(duì)應(yīng)文件被創(chuàng)建并填寫內(nèi)容。

        protected void Page_Load(object sender, EventArgs e)
        {
            StringBuilder txt = new StringBuilder();

            txt.AppendLine();
            txt.AppendLine(DateTime.Now.ToString("u"));
            txt.AppendLine("asvd");

            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");
            Thread.Sleep(50000);


            txt.AppendLine(DateTime.Now.ToString("u"));
            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");

            // 把一些信息寫到另外一個(gè)文件,借此察看是否正在運(yùn)行
            string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");
            if (!Directory.Exists(dir))
                Directory.CreateDirectory(dir);
            DateTime dt = DateTime.Now;
            string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);
            string fileName = Path.Combine(dir, shortfileName);

            StreamWriter sw;
            if (File.Exists(fileName))
                sw = File.AppendText(fileName);
            else
                sw = File.CreateText(fileName);

            sw.Write(txt.ToString());
            sw.Close();
            sw = null;

        } 

作了特殊判斷的情況簡(jiǎn)單例子:

注意: IsClientConnected 的判斷在 VS.NET 開發(fā)工具自帶的開發(fā)站點(diǎn) ASP.NET Development Server  是不支持的。 ASP.NET Development Server 永遠(yuǎn)返回 true 。

IIS 才是支持的。

        protected void Page_Load(object sender, EventArgs e)
        {

            StringBuilder txt = new StringBuilder();

            for (int i = 0; i < 100; i++)
            {
                if (this.Response.IsClientConnected)
                {
                    txt.AppendLine();
                    txt.AppendLine(DateTime.Now.ToString("u"));
                    txt.AppendLine(i.ToString());

                    Response.Write(DateTime.Now.ToString("u"));
                    Response.Write("<br />/r/n");
                    Thread.Sleep(500);
                }
                else
                {
                    Response.End();
                    return;
                }
            }

            txt.AppendLine(DateTime.Now.ToString("u"));
            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");

            // 把一些信息寫到另外一個(gè)文件,借此察看是否正在運(yùn)行
            string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");
            if (!Directory.Exists(dir))
                Directory.CreateDirectory(dir);
            DateTime dt = DateTime.Now;
            string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);
            string fileName = Path.Combine(dir, shortfileName);

            StreamWriter sw;
            if (File.Exists(fileName))
                sw = File.AppendText(fileName);
            else
                sw = File.CreateText(fileName);

            sw.Write(txt.ToString());
            sw.Close();
            sw = null;
        }這個(gè)例子中是發(fā)現(xiàn)中斷,就拋棄之前做的任何東西。

當(dāng)然我們也可以簡(jiǎn)單的修改上述代碼,讓把已經(jīng)處理完成的東西記錄下來(lái),類似下面的代碼

        protected void Page_Load(object sender, EventArgs e)
        {
            StringBuilder txt = new StringBuilder();

            for (int i = 0; i < 100; i++)
            {
                if (this.Response.IsClientConnected)
                {
                    txt.AppendLine();
                    txt.AppendLine(DateTime.Now.ToString("u"));
                    txt.Append("**********  ");
                    txt.AppendLine(i.ToString());

                    Response.Write(DateTime.Now.ToString("u"));
                    Response.Write("<br />/r/n");
                    Thread.Sleep(500);
                }
                else
                {
                    break;
                }
            }

            txt.AppendLine(DateTime.Now.ToString("u"));
            Response.Write(DateTime.Now.ToString("u"));
            Response.Write("<br />/r/n");

            // 把一些信息寫到另外一個(gè)文件,借此察看是否正在運(yùn)行
            string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");
            if (!Directory.Exists(dir))
                Directory.CreateDirectory(dir);
            DateTime dt = DateTime.Now;
            string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);
            string fileName = Path.Combine(dir, shortfileName);

            StreamWriter sw;
            if (File.Exists(fileName))
                sw = File.AppendText(fileName);
            else
                sw = File.CreateText(fileName);

            sw.Write(txt.ToString());
            sw.Close();
            sw = null;
        }需要注意的是, 使用 isClientConnected   是要占用一定的系統(tǒng)資源的。 

isClientConnected   實(shí)際上需要向客戶端輸出一點(diǎn)東西,然后才知道客戶端是否仍然在線。

這樣,除非你的應(yīng)用非常耗時(shí),否則建議你不要用 isClientConnected   。 免得判斷 isClientConnected   使用的資源比你實(shí)際業(yè)務(wù)邏輯使用的資源還要多。

在任何情況下, Response.IsClientConnected 都要有些開銷,所以,只有在執(zhí)行至少要用 500 毫秒(如果想維持每秒幾十頁(yè)的吞吐量,這是一個(gè)很長(zhǎng)的時(shí)間了)的操作前才使用它。作為通常的規(guī)則,不要在緊密循環(huán)的每次迭代中調(diào)用它,例如當(dāng)繪制表中的行,可能每  20 行或每 50 行調(diào)用一次。

AspNet技術(shù)ASP.net 頁(yè)面被關(guān)閉后,服務(wù)器端是否仍然執(zhí)行中?,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲春色AV无码专区456 | 老司机亚洲精品影院 | 国产99在线视频 | 兔费看少妇性L交大片免费 偷偷要色偷偷 | 人人啪日日观看在线 | 青青青草国产 | 成人国产精品视频频 | 朝鲜美女bbwbbw撒尿 | 囯产精品麻豆巨作久久 | 2021久久99国产熟女人妻 | 在线观看视频中文字幕 | 精品视频网站 | 99热这里只有是精品 | 狠狠色香婷婷久久亚洲精品 | 黑人巨大交牲老太 | 亚洲国产在线精品第二剧情不卡 | 99久久国内精品成人免费 | 啪啪做羞羞事小黄文 | 小处雏一区二区三区 | 亚洲精品久久久久一区二区三 | 久久久精品国产免费A片胖妇女 | 黑人巨茎vide抽搐 | 久久亚洲成a人片 | 亚洲日本乱码中文论理在线电影 | 红桃视频国产AV | chinese东北老年tv视频 | 99亚偷拍自图区亚洲 | 美女胸禁止18以下看 | 国产熟妇无码一区二 | 一区二区中文字幕在线观看 | 国产毛A片久久久久久无码 国产毛A片啊久久久久久A | 中文字幕一区二区三区在线观看 | 久久精品热线免费 | 国内久久久久影院精品 | 窝窝午夜色视频国产精品东北 | 福利免费观看体检区 | 国内精品免费视频精选在线观看 | 在线观看国产高清免费不卡 | 含羞草最新版本 | 宅男午夜大片又黄又爽大片 | 麻豆精品一区二正一三区 |