• 亲身经历面试题总结


    又到了一年一度跳槽高峰期,小女子不才,又皮了,面了几家公司督促自己上进,嘿嘿嘿

    一、关于页面之间如何传值(通过后台代码)

    1.QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中。如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法。但是对于传递数组或对象的话,就不能用这个方法了。(这东西应该有三年没用过了):

    复制代码
    private void Button1_Click(object sender, System.EventArgs e)
     {
         string s_url;
         s_url = "b.aspx?name=" + Label1.Text;
         Response.Redirect(s_url);
     }
    b.aspx中C#代码
    private void Page_Load(object sender, EventArgs e)
     {
         Label2.Text = Request.QueryString["name"];
     }
    复制代码

    query传值又分类post ,get格式如:

    复制代码
    //post请求 
    string name = Request["name"].toString(); 
    string name =Request.Form.Get("name").toString(); 
    //get请求 
    string name = Request.QueryString["name"].toString(); 
    但我发现 无论是否是post与get传值都可用
    string name = Request["name"].toString();
    复制代码

    表单提交中get和post方式的区别归纳如下几点: 
    1. get是从服务器上获取数据,post是向服务器传送数据。 
    2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。post是通过HTTP post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。 
    3. 对于get方式,服务器端用Request.QueryString获取变量的值,对于post方式,服务器端用Request.Form获取提交的数据。 
    4. get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。 
    5. get安全性非常低,post安全性较高。

    2.  使用Application 对象变量

      Application对象的作用范围是整个全局,也就是说对所有用户都有效。其常用的方法用Lock和UnLock。

    复制代码
    a.aspx的C#代码
    private void Button1_Click(object sender, System.EventArgs e)
     {
         Application["name"] = Label1.Text;
         Server.Transfer("b.aspx");
     }
    b.aspx中C#代码
    private void Page_Load(object sender, EventArgs e)
     {
         string name;
         Application.Lock();
         name = Application["name"].ToString();
         Application.UnLock();
     }
    复制代码

    3.  使用Session变量

      想必这个肯定是大家使用中最常见的用法了,其操作与Application类似,作用于用户个人,所以,过量的存储会导致服务器内存资源的耗尽。

    复制代码
    a.aspx的C#代码
    private void Button1_Click(object sender, System.EventArgs e)
     {
         Session["name"] = Label.Text;
     }
    b.aspx中C#代码
    private void Page_Load(object sender, EventArgs e)
     {
         string name;
         name = Session["name"].ToString();
     }
    复制代码

    4.  使用Cookie对象变量

      这个也是大家常使用的方法,与Session一样,其是什对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在服务器端的。而且Cookie的使用要配合ASP.NET内置对象Request来使用。

    复制代码
    a.aspx的C#代码
    private void Button1_Click(object sender, System.EventArgs e)
     {
         HttpCookie cookie_name = new HttpCookie("name");
         cookie_name.Value = Label1.Text;
         Reponse.AppendCookie(cookie_name);
         Server.Transfer("b.aspx");
     }
    b.aspx中C#代码
    private void Page_Load(object sender, EventArgs e)
     {
         string name;
         name = Request.Cookie["name"].Value.ToString();
     }
    复制代码

    5.  使用Server.Transfer方法

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

    复制代码
    a.aspx的C#代码
    public string Name
     {
         get{ return Label1.Text;}
     }
     private void Button1_Click(object sender, System.EventArgs e)
     {
         Server.Transfer("b.aspx");
     }
    b.aspx中C#代码
    private void Page_Load(object sender, EventArgs e)
     {
         a newWeb;   //实例a窗体
         newWeb = (source)Context.Handler;
         string name;
         name = newWeb.Name;
     }
    复制代码

    下面介绍一下传值缺点和优点

    cookie
         方式:将数据存在客户端的经典方法。
         缺点:安全性低、受客户端设置限制、一个站点仅存20个cookie,每个容量4096字节。

    Session
         方式:将用户数据存储在服务端。
         特点:asp.net中可以设置session的存储方式、位置、SessionID的保存是否依赖cookie。
                 可以直接存储对象。 
         缺点:asp.net中有失效的隐患
    Cache
         方式:将用户数据存储在服务端数据缓存中。 
         特点:可以大大提高效率。 可以直接存储对象。
    Appliction
         方式: 将数据存储于此,相当于全局变量。 
         特点:可以直接存储对象。整个站点的共享数据
    ViewState
         方式:asp.net特有机制,用来恢复页面状态。 
         特点:将页面各控件及其所存数据序列化存在name为_ViewState的隐藏域中。
         缺点:存在HTML中,安全性较低。可以设置加密和验证,但数据量会大增、效率有影响。
    Static
         方式: 将数据存于静态变量中。 
         特点:利于提高效率。
         缺点:若用不好会致使用户或页面间数据紊乱,造成极大的隐患。建议只赋值一次,绝对禁止为单个用户而更改此值。

    二、关于页面之间如何传值(不通过后台代码)

    1、get方式,url携带参数

    可以通过window.location.search获取url上的参数。如下面的示例。

    a.html

    <a href="./b.html?a=1&a=2&username=zhangsan&password=123&=">跳转</a> 

    b.html

    <script type="text/javascript" src="./js/getUrlParam.js"></script> 
    <script> 
      var a = UrlParam.paramValues("a"); 
      console.log(a); 
    </script>

    2、通过cookie,传递

    cookie能够存储少量数据到客户端的磁盘中,特定的网页之间是可以共享cookie中的数据。

    a.html

    <script type="text/javascript" src="./js/jquery.min.js"></script> 
    <script type="text/javascript" src="./js/jquery.cookie.js"></script> 
    <script> 
      $.cookie("a","对象"); //存值
    </script>

    b.html

    <script type="text/javascript" src="./js/jquery.min.js"></script> 
    <script type="text/javascript" src="./js/jquery.cookie.js"></script> 
    <script> 
      var param = $.cookie("a"); //取值
      console.log(param); //如果用alert必须要点按钮很麻烦
    </script>
    console.log的展示
     

    3、window.open和window.opener之间传值

    window.open可以打开一个新的页面,在新的页面中可以通过window.opener获取父页面的窗口对象,从而可以获取父窗口中的参数。

    a.html

    <button id="open">打开新的页面</button> 
    <script> 
      $('#open').click(function () { 
        window.open('./b.html') 
      }) 
    </script>

    b.html

    <script>
    
      var content = window.opener.document.getElementById("open").innerHTML;
     console.log(content);
    </script>

    4、h5技术,window.localStorage存储数据

    在HTML5中,新加入了一个localStorage特性,这个特性主要是用来作为本地存储来使用的,解决了cookie存储空间不足的问题(cookie中每条cookie的存储空间为4k),localStorage中一般浏览器支持的是5M大小,这个在不同的浏览器中localStorage会有所不同。此方法类似cookie,将数据存在一个公共的地方,实现页面之间传值。

    a.html

    <input type="text" name="username" /> 
    <input type="button" name="" value="post" onclick="set()"/> 
    <script> 
      function set() { 
        //由于是一个新的技术,你可以通过下面的代码检测你的浏览器是否支持 
        if (window.localStorage) { 
        //存储变量的值 
          localStorage.name = document.all.username.value; 
          location.href = './b.html'; 
        } else { 
          alert("NOT SUPPORT"); 
        } 
      } 
    </script>

    b.html

    <script> 
      var value = localStorage["name"]; 
        console.log(value)
    </script>

    下面介绍一下传值缺点和优点

    1、url携带参数

    优点:取值方便,可以跨域,利于页面分享,没有环境限制。

    缺点:url携带参数值的长度有限制。

    2、cookie方式

    优点:可以在同源内的的任意网页中访问,存储数据的周期可以自由设置。

    缺点:有长度限制。

    3、设置窗口之间的父子关联关系

    优点:取值方便.只要window.opener指向父窗口,就可以访问所有对象.不仅可以访问值,还可以访问父窗口的方法.值长度无限制。
    缺点:两窗口要存在着关系.就是利用window.open打开的窗口。不能跨域。

    4、h5技术,window.localStorage存储数据

    优点:储存空间大,有5M存储空间。

    缺点:不是所有浏览器都支持。

    二、递归经典面试题(这道题惨败,怪我太年轻)

    斐波那契数列是递归里的经典,指的是这样一个数列:1、1、2、3、5、8、13、21、……

    求第30位数字是多少。答案为832040,规律就是当前数字等于前两个数字的和。以下用MVC做实例,代码为后台代码,页面输出看下就好了。

           public ActionResult Fabonaci()
            {
                int i = 30;
                int value = function(i);
                ViewBag.value = value;
                return View();
            }
    
            //定义递归计算的方法
            public int function(int num)
            {
                if (num == 0)
                {
                    return 0;
                }
                else if (num >= 1 && num <= 2)
                {
                    return 1;
                }
                else
                {
                    return function(num - 1) + function(num - 2);
                }
            }

    三、用过什么UML建模工具?

    工具有很多种,在读书时用过PowerDesigner,工作以后用的次数极少。用来建数据库表关系

    四、过滤器粗解

    几大过滤器通常用在什么情况(继承这些过滤器,重写以下方法可实现想要的功能):

    1、AuthorizeAttribute授权过滤器,

           OnAuthorization-进入方法前校验,通常用来做登录校验

           HandleUnauthorizedRequest-用于处理验证失败后的方法

            AuthorizeCore-也可以用来做权限校验,返回false执行HandleUnauthorizedRequest,在此写跳转的页面即可

    2、HandleErrorAttribute 异常过滤器:

          OnException-当action出现异常时执行

          继承此类,重写OnException,当项目报错时执行此操作

    3、ActionFilterAttribute过滤器:

           OnActionExecuting -执行控制器中的方法之前先执行该方法。

            继承此类,重写OnActionExecuting,当需要做用户权限时用

           OnResultExecuted  -执行完控制器方法以后执行该方法。

           继承此类,重写OnResultExecuted,清空登录信息,通常退出登录时用

     public class FilterAttribute : ActionFilterAttribute
        {
            public string Message { get; set; }
    
            public override void OnActionExecuting(ActionExecutingContext filterContext)
            {
                base.OnActionExecuting(filterContext);
                filterContext.HttpContext.Response.Write("Action执行之前" + Message + "<br />");
            }
    
            public override void OnActionExecuted(ActionExecutedContext filterContext)
            {
                base.OnActionExecuted(filterContext);
                filterContext.HttpContext.Response.Write("Action执行之后" + Message + "<br />");
            }
    
            public override void OnResultExecuting(ResultExecutingContext filterContext)
            {
                base.OnResultExecuting(filterContext);
                filterContext.HttpContext.Response.Write("返回Result之前" + Message + "<br />");
            }
    
            public override void OnResultExecuted(ResultExecutedContext filterContext)
            {
                base.OnResultExecuted(filterContext);
                filterContext.HttpContext.Response.Write("返回Result之后" + Message + "<br />");
            }
        }

     5、全局过滤器

    MVC:在Global.asax注册Filter后可以不用每个Action上都写上特性

     

     .NetCore:在Startup.cs注册Filter后可以不用每个Action上都写上特性

  • 相关阅读:
    [转]Asp.Net页面输出到WORD、EXCEL、TXT、HTM等类型的文档
    人工智能AI基础 四
    关于设计的一点小结 四
    Visual Studio 11 将强化对2D/3D游戏开发的支持 四
    如何正确的对待设计模式 四
    C++设计模式原型模式 四
    C++游戏编程8步云 四
    Qt编译 四
    软件架构师应该知道的97件事 四
    给年轻程序员的几句话 四
  • 原文地址:https://www.cnblogs.com/xiaoxiaoqiao/p/10491427.html
Copyright © 2020-2023  润新知