>백엔드 개발 >C#.Net 튜토리얼 >ASP.NET 페이지 간에 값을 전송하는 여러 가지 방법

ASP.NET 페이지 간에 값을 전송하는 여러 가지 방법

PHPz
PHPz원래의
2017-03-05 12:27:361704검색

페이지 값 전달은 asp.net 학습 초기에 직면하는 문제입니다. 일반적으로 페이지 값 전달, 저장소 개체 값 전달, ajax, 클래스, 모델, 양식 등이 있습니다. 그러나 일반적으로 일반적으로 사용되는 간단한 것들은 QueryString, Session, Cookies, Application 및 Server.Transfer입니다. 인터뷰를 하다 보면 이런 질문을 자주 접하게 되는데, 사실 우리는 프로젝트에서 자주 사용하는 몇 가지 방법에 대해 잘 알고 있습니다. 그러나 ASP.NET에서 페이지 값 전달 방식에 대해서는 종합적으로 답변하기 어려운 경우가 많은 것으로 추정됩니다.

 1. QueryString

QueryString은 전송된 값을 브라우저의 주소 표시줄에 표시하는 매우 간단한 방법입니다. 이 방법은 보안 요구사항이 낮거나 구조가 간단한 하나 이상의 값을 전달할 때 사용할 수 있습니다. 그러나 배열이나 객체를 전달하는 경우에는 이 방법을 사용할 수 없습니다.

 이 방법의 장점: 1. 사용이 간편하고 보안 요구 사항이 높지 않은 경우 숫자나 텍스트 값을 전송할 때 매우 효과적입니다.
 이 방법의 단점: 1. 해당 값이 브라우저의 URL 주소에 노출되므로 보안이 부족합니다.
2. 객체를 전달할 수 없습니다.

 사용법: 1. 소스 페이지의 코드에 전달되어야 하는 이름과 값으로 URL 주소를 구성합니다.
2. 소스 페이지 코드에서 Response.Redirect(URL);를 사용하여 위의 URL 주소로 리디렉션합니다.
3. 대상 페이지의 코드에서 Request.QueryString["name"];을 사용하여 URL 주소에 전달된 값을 검색합니다.

 예:(1)a.aspx


private void Button1_Click(object sender, System.EventArgs e) 
{ 
  string s_url; 
  s_url = "b.aspx?name=" + Label1.Text; 
  Response.Redirect(s_url); 
}


 (2)b. aspx


rreee


 2. 이는 모두가 가장 일반적으로 사용하는 사용법일 것입니다. 그 동작은 애플리케이션과 유사하며, 개인 사용자에게 적용되므로 과도한 저장 공간은 서버 메모리 리소스를 고갈시킵니다.

 장점: 1. 사용하기 쉬우며, 간단한 데이터 유형뿐만 아니라 객체도 전달할 수 있습니다.

2. 데이터 양에는 제한이 없습니다.

 단점:
1. 세션 변수에 많은 양의 데이터를 저장하면 서버 리소스가 더 많이 소모됩니다.

2. 잃기 쉽다.  

사용법:

1. 세션 변수를 구성하기 위해 소스 페이지의 코드에 전달해야 하는 이름과 값을 만듭니다. Session["Name"]="Value(Or Object) )";

2. 대상 페이지의 코드에 세션 변수를 사용하여 전달된 값을 검색합니다. 결과 = Session["Nmae"] 

참고:

세션을 사용하지 않을 때 파기할 수 있습니다. 파기 방법은 다음과 같습니다. ");

      모두 지우기: Session.Clear(); > (2)b.aspx

private void Page_Load(object sender, EventArgs e) 
{ 
  Label2.Text = Request.QueryString["name"]; 
}


3. 쿠키

이 역시 작은 정보를 저장하는 데 사용되는 방식입니다. 이용자의 웹사이트 방문시 ID, 이용자 선호도 등 이용자의 관련정보를 이용자의 브라우저에 저장하고, 다음 방문시 검색을 통해 이전 정보를 확인할 수 있습니다. 따라서 쿠키는 페이지 간에 값을 전달할 수도 있습니다. 쿠키는 HTTP 헤더를 통해 브라우저와 서버 사이를 오가며 전달됩니다. 쿠키에는 문자열 값만 포함될 수 있습니다. 쿠키에 정수 값을 저장하려면 먼저 문자열 형식으로 변환해야 합니다.

Session과 마찬가지로 사용자별이지만 본질적인 차이점이 있습니다. 즉, Cookie는 클라이언트 측에 저장되고, Session은 서버 측에 저장됩니다. 그리고 쿠키 사용은 ASP.NET 기본 제공 개체인 Request와 함께 사용해야 합니다.


 

장점:

1. 사용이 간단하며 사용자 상태를 유지하는 데 매우 일반적인 방법입니다. 예를 들어, 쇼핑 웹사이트에서는 사용자가 여러 페이지 양식에 걸쳐 있을 때 사용자 상태를 유지하는 데 사용할 수 있습니다.

 단점: 1. 사용자의 개인 정보를 수집하는 데 사용된다는 비판을 받는 경우가 많습니다.

2. 보안성이 높지 않고 위조가 쉽습니다.  

 

사용법:

1. 쿠키 개체를 구성하기 위해 소스 페이지의 코드에 전달해야 하는 이름과 값을 만듭니다.

private void Button1_Click(object sender, System.EventArgs e) 
{ 
  Session["name"] = Label.Text; 
}

2. 대상 페이지의 코드에서 Cookie 개체를 사용하여 전달된 값을 검색합니다. Result = Request.Cookies[ "myCookie" ].Value ;

예:

(1)a.aspx

private void Page_Load(object sender, EventArgs e) 
{ 
  string name; 
  name = Session["name"].ToString(); 
}


 (2)b .aspx

아아앙


  四、Application

  Application对象的作用范围是整个全局,也就是说对所有用户都有效。它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中对它进行存取。它和Session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。

  可能有人会问,既然所有用户都可以使用application变量,那他可以用在什么场合呢?这里举个例子:网站访问数。多个请求访问时都可以对它进行操作。

  优点:1.使用简单,消耗较少的服务器资源。

     2.不仅能传递简单数据,还能传递对象。

     3.数据量大小是不限制的。

  缺点:1.作为全局变量容易被误操作。所以单个用户使用的变量一般不能用application。

  使用方法:1.在源页面的代码中创建你需要传递的名称和值构造Application变量:Application["Nmae"]="Value(Or Object)";

       2.在目的页面的代码使用Application变量取出传递的值。Result = Application["Nmae"]

  注意:常用lock和unlock方法用来锁定和解锁,为了防止并发修改。

  例子:(1)a.aspx


private void Button1_Click(object sender, System.EventArgs e) 
{ 
  Application["name"] = Label1.Text; }


  (2)b.aspx


private void Page_Load(object sender, EventArgs e) 
{ 
  string name; 
  Application.Lock(); 
  name = Application["name"].ToString(); 
  Application.UnLock(); 
}


 

  五、Server.Transfer

  这个才可以说是面象对象开发所使用的方法,其使用Server.Transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效。

  Server.Transfer是从当前的ASPX页面转到新的ASPX页面,服务器端执行新页并输出,在新页面中通过Context.Handler来获得前一个页面传递的各种数据类型的值、表单数据、QueryString.由于重定向完全在服务器端完成,所以客户端浏览器中的URL地址是不会改变的。调用Server.Transfer时,当前的ASPX页面终止执行,执行流程转入另一个ASPX页面,但新的ASPX页面仍使用前一ASPX页面创建的应答流。

  ps:比较Server.Transfer和Response.Redirect的区别。
    (1)Server.Transfer在服务器端完成,所以客户端浏览器中的URL地址是不会改变的;Response.Redirect是客户端完成,向服务器端提出新的页面处理请求,所以客户端浏览器中的URL地址是会改变的。
    (2)Server.Transfer在服务器端完成,不需要客户端提出请求,减少了客户端对服务器端提出请求。[2]
    (3)Server.Transfer只能够转跳到本地虚拟目录指定的页面,也就是工程项目中的页面,而Response.Redirect则十分灵活,可以跳转到任何URL地址。
    (4)Server.Transfer可以将前一个页面的各种类型的值传到新的页面;Response.Redirect则只能借助URL中带参数或是结合上面四种办法把各种类型的值传到新的页面。

  优点:1.直接在服务器端重定向,使用简单方便,减少了客户端对服务器端提出请求。

     2.可以传递各种数据类型的值和控件的值。

  缺点:1.客户端浏览器中的URL地址是不改变,会导致在新的页面可能出现一些意想不到的问题。比如如果源页面和目的页面不在同一个虚拟目录或其子目录下,那么使用相对路径的图片、超链接都会导致错误的指向。

  使用方法:1.在源页面的代码中,使用Page类的Server.Transfer跳到另一个页面传递页面数据:Server.Transfer("b.aspx","false")。

       2.在目的页面中,使用Context.Handler来接收数据:FormerPage formerPage = (FormerPage)Context.Handler; 然后用formerPage的属性和方法来获取前一个页面的值,或者直接用Context.Items["myParameter "]

  例子:(1)a.aspx


public string Name 
{ 
  get{ return Label1.Text;} 
} 
private void Button1_Click(object sender, System.EventArgs e) 
{ 
  Server.Transfer("b.aspx"); 
}


    (2)b.aspx


private void Page_Load(object sender, EventArgs e) 
{ 
  a newWeb; //实例a窗体   newWeb = (source)Context.Handler; 
  string name; 
  name = newWeb.Name; 
}


 

위는 ASP.NET에서 페이지 간 값을 전송하는 데 일반적으로 사용되는 몇 가지 방법입니다. 값을 전송하기 위해 주로 세션과 쿼리스트링을 사용합니다. 이 글에서는 이러한 방법의 사용방법만을 소개합니다. 세션 저장 방법에 대해서는 세션 저장 방법 및 구성 파일


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.