主頁 > 軟體工程 > HTTP請求GET/POST

HTTP請求GET/POST

2021-10-16 03:42:42 軟體工程

我在visual studio 2010上創建網站。所以,我應該打開一個新的表格,并從第一個表格中發送資訊。我使用了文本檔案(我從拳頭頁面寫到檔案,然后在新的表單中讀取這個檔案),這很有效。但是我想通過GET/POST請求創建連接。我從How to make an HTTP POST web request中得到這個代碼。 專案是可以編譯的,但超過了時間限制。所以,我在下面附上了代碼和錯誤。

第一頁的代碼

var request = (HttpWebRequest)WebRequest.Create("http://localhost:55590/WebSite2/Form2.aspx") 。

    var postData = text;
    var data = Encoding.ASCII.GetBytes(postData)。

    request.Method = "POST"/span>;
    request.ContentType = "application/x-www-form-urlencoded";
    request.ContentLength = data.Length。

    using (var stream = request.GetRequestStream()
    {
        stream.Write(data, 0, data.Length)。
    }

    var response = (HttpWebResponse)request.GetResponse();

    var responseString = new StreamReader(response.GetResponseStream() ).ReadToEnd()。

第二頁的代碼

var request = (HttpWebRequest)WebRequest.Create("http://localhost:55590/WebSite2/Form2.aspx"/span>);

    var response = (HttpWebResponse)request.GetResponse();

    var responseString = new StreamReader(response.GetResponseStream() ).ReadToEnd()。

錯誤

Operation timed out。
描述。在執行當前Web請求時發生了一個未處理的例外。檢查堆疊跟蹤以獲得更多關于這個錯誤導致它的代碼片段的資訊。

例外細節。System.Net.WebException。操作超時了out。

源頭錯誤。
136。       }
137:
138:        var response = (HttpWebResponse)request.GetResponse(); // Error here.
139:
140:        var responseString = new StreamReader(response.GetResponseStream() ).ReadToEnd()。

我試了一下,從源頭上的第二個變體,但得到了錯誤。所以,請幫助我

uj5u.com熱心網友回復:

因此,有相當多的方法可以將資料和 "東西 "從一個網頁發送到下一個網頁。

Session() 當然是一種可能的方法。

另一種方法是在 URL 中使用引數,因此你經常在許多網站上看到這種情況

甚至在我寫這篇文章時--我們在StackOverFlow上看到的URL是這樣的:

stackoverflow.com/questions/66294186/http-request-get-post?noredirect=1#comment117213494_66294186

所以,以上就是stack overflow的傳值方式。

因此,session()和URL中的引數是常見的。

然而,asp.net net有一個 "功能",你可以將前一個頁面傳遞給下一個。因此,在你加載的下一個頁面中簡單地摘取/獲取/抓取/使用第一個頁面中的東西就成為了一件簡單的事情。因此,這個功能是 asp.net 的一部分,它將為你完成傳遞前一個頁面的所有骯臟作業!

嗯,我想知道的是,如果你想讓你的網站變得更好,那么你就必須讓它變得更好。

嗯,我想知道人們是否需要從前一個頁面傳遞和獲取值?我打賭這個最常見的想法一定是被處理過的,對嗎?而且這不僅是一個常見的事情,比如說像人類如何呼吸空氣?它也是asp.net的一個特點。

那么,一個非常簡單的方法就是當你點擊一個按鈕,然后跳到下一個相關頁面?好吧,如果事情設定正確,那么你可以簡單地使用 "上一個 "頁面!

你可以在一個頁面上這樣做。

你可以在頁面加載時這樣做:

if (IsPostBack == false) { TextBox txtCompay = PreviousPage.FindControl("txtCompnay") 。 Debug.Print("上一頁的文本框公司的價值=" txtCompay.Text)。 }

這種方法很好,因為你真的不需要提前決定是要前一頁的控制元件的2個還是20個值--你真的不在乎。

這個方法是如何運作的?

前一頁只基于兩種方法有效。

第一種方法:

您在表單上投放的按鈕通常會有 "后面的代碼",當然會跳轉或轉到相關的下一個頁面。

該命令(后面的代碼)是典型的這樣:

該命令(后面的代碼)是典型的這樣。

Response.Redirect("某個aspx網頁跳轉到")

上面的內容不會傳遞上一頁

然而,如果你使用這個:

Server.Transfer("some aspx web page to jump to"/span>)

那么前一個頁面就被通過了,你可以使用它!!!!

所以在下一個頁面中,在頁面加載事件中,你可以按照上述方法使用 "prevouspage"。

所以Server.Transfer("to the next page") 將允許在你的代碼中使用 "previous page"。

因此你可以拾取任何控制元件,任何值。你甚至可以參考一個網格視圖和用戶選擇的行。實際上,整個前一頁被轉移并可用于上述 "前一頁 "中。你不能抓取viewstate,但是你可以在前一個頁面中設定公共方法來暴露viewstate的成員,如果這也是需要的。

你當然必須使用FindControl,但這是前一個頁面。

另一種方法(允許使用前一個頁面)。

你不使用后面的代碼來觸發跳轉到新的頁面(使用Server.Transfer()),但你在第一頁的按鈕中設定了post-back URL。(將當前頁面傳遞給回傳URL)。

例如這樣:

 <asp:Button ID="Button1" runat=" server" Text="View Hotels"
    PostBackUrl="~/HotelGrid.aspx" />

因此你使用了按鈕的 "回貼 "URL功能。

現在,當你點擊該按鈕時,它將跳轉到第二頁,并再次按上述方法使用前一頁。當然,如果設定了回傳 URL,那么你當然不需要在存根后面添加代碼來跳轉到該頁面。

因此這在很大程度上是asp.net的一個 "基本 "功能,并且是將前一個頁面轉移到下一個頁面的內置手段。這有點像asp.net的 "101"。

因此,這也許是很常見的,實際上是最常見的基本需求,從前一個網頁傳遞值不僅是內置的,而且事實上它被稱為 "前一個頁面"!!!!!

規則:

上一頁只在如果你使用Server.Transfer("to the page")

Response.Request("to the page")不允許使用以前的頁面。

使用按鈕 事實上許多其他控制)也
有一個post-back URL設定 - 再次如果該控制元件有post-back URL,那么
由于該控制元件導致了這樣的頁面導航,再次使用前一個頁面允許的。
導航。

前一頁只能在第一頁加載ispostBack = False)時使用。

在一個按鈕中使用post-back URL當然意味著存根后面的代碼是不需要頁面跳轉的。而且再一次,使用post-back URL將確保前一個頁面可以在下一個頁面中使用。

然而,在那些你不想硬編碼URL的情況下,或者在導航到下一頁之前,按鈕代碼存根中可能會出現一些額外的邏輯?(

那么好的回傳 URL 就不那么實用了,但是您可以在后面的代碼中使用 Server.Transfer() ,并且再次允許使用內置的 "前一頁"。

請記住,無論你需要/想要/將要從前一頁抓取什么,都必須在我們跳轉到的那個頁面的第一個頁面加載時發生。任何額外的回貼按鈕和常規的生命周期以及該頁后面的代碼中的控制元件和事件的使用,都不會在第一次頁面加載發生后使用前一頁。(前一頁將是空的)。

uj5u.com熱心網友回復:

你可以用這種方式試試。

var request = (HttpWebRequest)WebRequest.Create("http://localhost:55590/WebSite2/Form2.aspx"/span>);

var postData = text;
var data = Encoding.ASCII.GetBytes(postData)。

request.Method = "POST"/span>;
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = data.Length。

using (var stream = request.GetRequestStream()
{
    stream.Write(data, 0, data.Length)。
}

 HttpWebResponse httpResponse = (HttpWebResponse)httpWebRequest.GetResponse();
 使用(StreamReader streamReader = new StreamReader(httpResponse.GetResponseStream())
 {
     result = streamReader.ReadToEnd();
 }

轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/317256.html

標籤:

上一篇:我怎樣才能生成一個串列框的演算法?

下一篇:多于一個多載函式的實體與引數串列相匹配,我找不到錯誤發生的地方。

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • Git本地庫既關聯GitHub又關聯Gitee

    創建代碼倉庫 使用gitee舉例(github和gitee差不多) 1.在gitee右上角點擊+,選擇新建倉庫 ? 2.選擇填寫倉庫資訊,然后進行創建 ? 3.服務端已經準備好了,本地開始作準備 (1)Git 全域設定 git config --global user.name "成鈺" git c ......

    uj5u.com 2020-09-10 05:04:14 more
  • CODING DevOps 代碼質量實戰系列第二課,相約周三

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。**《DevOps 代碼質量實戰(PHP 版)》**為 CODING DevOps 代碼質量實戰系列的第二課,同時也是本系列的 PHP ......

    uj5u.com 2020-09-10 05:07:43 more
  • 推薦Scrum書籍

    推薦Scrum書籍 直接上干貨,推薦書籍清單如下(推薦有順序的哦) Scrum指南 Scrum精髓 Scrum敏捷軟體開發 Scrum捷徑 硝煙中的Scrum和XP : 我們如何實施Scrum 敏捷軟體開發:Scrum實戰指南 Scrum要素 大規模Scrum:大規模敏捷組織的設計 用戶故事地圖 用 ......

    uj5u.com 2020-09-10 05:07:45 more
  • CODING DevOps 代碼質量實戰系列最后一課,周四發車

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。 **《DevOps 代碼質量實戰(Java 版)》**為 CODING DevOps 代碼質量實戰系列的最后一課,同時也是本系列的 ......

    uj5u.com 2020-09-10 05:07:52 more
  • 敏捷軟體工程實踐書籍

    Scrum轉型想要做好,第一步先了解并真正落實Scrum,那么我推薦的Scrum書籍是要看懂并實踐的。第二步是團隊的工程實踐要做扎實。 下面推薦工程實踐書單: 重構:改善既有代碼的設計 決議極限編程 : 擁抱變化 代碼整潔代碼 程式員的職業素養 修改代碼的藝術 撰寫可讀代碼的藝術 測驗驅動開發 : ......

    uj5u.com 2020-09-10 05:07:55 more
  • Jenkins+svn+nginx實作windows環境自動部署vue前端專案

    前面文章介紹了Jenkins+svn+tomcat實作自動化部署,現在終于有空抽時間出來寫下Jenkins+svn+nginx實作自動部署vue前端專案。 jenkins的安裝和配置已經在前面文章進行介紹,下面介紹實作vue前端專案需要進行的哪些額外的步驟。 注意:在安裝jenkins和nginx的 ......

    uj5u.com 2020-09-10 05:08:49 more
  • CODING DevOps 微服務專案實戰系列第一課,明天等你

    CODING DevOps 微服務專案實戰系列第一課**《DevOps 微服務專案實戰:DevOps 初體驗》**將由 CODING DevOps 開發工程師 王寬老師 向大家介紹 DevOps 的基本理念,并探討為什么現代開發活動需要 DevOps,同時將以 eShopOnContainers 項 ......

    uj5u.com 2020-09-10 05:09:14 more
  • CODING DevOps 微服務專案實戰系列第二課來啦!

    近年來,工程專案的結構越來越復雜,需要接入合適的持續集成流水線形式,才能滿足更多變的需求,那么如何優雅地使用 CI 能力提升生產效率呢?CODING DevOps 微服務專案實戰系列第二課 《DevOps 微服務專案實戰:CI 進階用法》 將由 CODING DevOps 全堆疊工程師 何晨哲老師 向 ......

    uj5u.com 2020-09-10 05:09:33 more
  • CODING DevOps 微服務專案實戰系列最后一課,周四開講!

    隨著軟體工程越來越復雜化,如何在 Kubernetes 集群進行灰度發布成為了生產部署的”必修課“,而如何實作安全可控、自動化的灰度發布也成為了持續部署重點關注的問題。CODING DevOps 微服務專案實戰系列最后一課:**《DevOps 微服務專案實戰:基于 Nginx-ingress 的自動 ......

    uj5u.com 2020-09-10 05:10:00 more
  • CODING 儀表盤功能正式推出,實作作業資料可視化!

    CODING 儀表盤功能現已正式推出!該功能旨在用一張張統計卡片的形式,統計并展示使用 CODING 中所產生的資料。這意味著無需額外的設定,就可以收集歸納寶貴的作業資料并予之量化分析。這些海量的資料皆會以圖表或串列的方式躍然紙上,方便團隊成員隨時查看各專案的進度、狀態和指標,云端協作迎來真正意義上 ......

    uj5u.com 2020-09-10 05:11:01 more
最新发布
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:41:12 more
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:35:34 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:05:44 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:00:18 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:20:31 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:55 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:18:51 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:00 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:17:55 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:12:06 more