作者: admin

  • – -!get与post的区别

    感谢同事小罗的讲解,然后转载网络博客的hyddd整理的。

    Http定义了与服务器交互的不同方法,最基本的方法有4种,分别是GET,POST,PUT,DELETE。URL全称是资源描述符,我们可
    以这样认为:一个URL地址,它用于描述一个网络上的资源,而HTTP中的GET,POST,PUT,DELETE就对应着对这个资源的4个操作。到这里,大家应该有个大概的了解了,GET一般用于获取/查询资源信息,而POST一般用于更新资源信息。

      1.根据HTTP规范,GET用于信息获取,而且应该是安全的和幂等的

      (1).所谓安全的意味着该操作用于获取信息而非修改信息。换句话说,GET 请求一般不应产生副作用。就是说,它仅仅是获取资源信息,就像数据库查询一样,不会修改,增加数据,不会影响资源的状态。

      * 注意:这里安全的含义仅仅是指是非修改信息。

      (2).幂等的意味着对同一URL的多个请求应该返回同样的结果。这里我再解释一下幂等这个概念:

      幂等(idempotent、idempotence)是一个数学或计算机学概念,常见于抽象代数中。
      幂等有一下几种定义:
      对于单目运算,如果一个运算对于在范围内的所有的一个数多次进行该运算所得的结果和进行一次该运算所得的结果是一样的,那么我们就称该运算是幂等的。比如绝对值运算就是一个例子,在实数集中,有abs(a)
    =abs(abs(a))
      对于双目运算,则要求当参与运算的两个值是等值的情况下,如果满足运算结果与参与运算的两个值相等,则称该运算幂等,如求两个数的最大值的函数,有在在实数集中幂等,即max(x,x) 
    = x

    看完上述解释后,应该可以理解GET幂等的含义了。

      但在实际应用中,以上2条规定并没有这么严格。引用别人文章的例子:比如,新闻站点的头版不断更新。虽然第二次请求会返回不同的一批新闻,该操
    作仍然被认为是安全的和幂等的,因为它总是返回当前的新闻。从根本上说,如果目标是当用户打开一个链接时,他可以确信从自身的角度来看没有改变资源即可。

      2.根据HTTP规范,POST表示可能修改变服务器上的资源的请求。继续引用上面的例子:还是新闻以网站为例,读者对新闻发表自己的评论应该通过POST实现,因为在评论提交后站点的资源已经不同了,或者说资源被修改了。

     

      上面大概说了一下HTTP规范中GET和POST的一些原理性的问题。但在实际的做的时候,很多人却没有按照HTTP规范去做,导致这个问题的原因有很多,比如说:

      1.很多人贪方便,更新资源时用了GET,因为用POST必须要到FORM(表单),这样会麻烦一点。

      2.对资源的增,删,改,查操作,其实都可以通过GET/POST完成,不需要用到PUT和DELETE。

      3.另外一个是,早期的Web MVC框架设计者们并没有有意识地将URL当作抽象的资源来看待和设计,所以导致一个比较严重的问题是传统的Web MVC框架基本上都只支持GET和POST两种HTTP方法,而不支持PUT和DELETE方法。

       * 简单解释一下MVC:MVC本来是存在于Desktop程序中的,M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。

      以上3点典型地描述了老一套的风格(没有严格遵守HTTP规范),随着架构的发展,现在出现REST(Representational 
    State Transfer),一套支持HTTP规范的新风格,这里不多说了,可以参考《RESTful Web Services》。

     

      说完原理性的问题,我们再从表面现像上面看看GET和POST的区别

      1.GET请求的数据会附在URL之后(就是
    把数据放置在HTTP协议头中),以?分割URL和传输数据,参数之间以&相连,如:login.action?name=hyddd&
    password=idontknow&verify=%E4%BD%A0%E5%A5%BD。如果数据是英文字母/数字,原样发送,如果是空
    格,转换为+,如果是中文/其他字符,则直接把字符串用BASE64加密,得出如:%E4%BD%A0%E5%A5%BD,其中%XX中的XX为该符号以
    16进制表示的ASCII。

      POST把提交的数据则放置在是HTTP包的包体中。

      2."GET方式提交的数据最多只能是1024字节,理论上POST没有限制,可传较大量的数据,IIS4中最大为80KB,IIS5中为100KB"??!

      以上这句是我从其他文章转过来的,其实这样说是错误的,不准确的:

      (1).首先是"GET方式提交的数据最多只能是1024字节",因为GET是通过URL提交数据,那么GET可提交的数据量就跟URL的长度有直接关系了。而实际上,URL不存在参数上限的问题HTTP协议规范没有对URL长度进行限制。这个限制是特定的浏览器及服务器对它的限制。IE对URL长度的限制是2083字节(2K+35)。对于其他浏览器,如Netscape、FireFox等,理论上没有长度限制,其限制取决于操作系统的支持。

      注意这是限制是整个URL长度,而不仅仅是你的参数值数据长度。[见参考资料5]

      (2).理论上讲,POST是没有大小限制的HTTP协议规范也没有进行大小限制,说“POST数据量存在80K/100K的大小限制”是不准确的,POST数据是没有限制的,起限制作用的是服务器的处理程序的处理能力。

      对于ASP程序,Request对象处理每个表单域时存在100K的数据长度限制。但如果使用Request.BinaryRead则没有这个限制。

      由这个延伸出去,对于IIS 6.0,微软出于安全考虑,加大了限制。我们还需要注意:

         1).IIS 6.0默认ASP POST数据量最大为200KB,每个表单域限制是100KB。
         2).IIS 6.0默认上传文件的最大大小是4MB。
         3).IIS 6.0默认最大请求头是16KB。
      IIS 6.0之前没有这些限制。[见参考资料5]

      所以上面的80K,100K可能只是默认值而已(注:关于IIS4和IIS5的参数,我还没有确认),但肯定是可以自己设置的。由于每个版本的IIS对这些参数的默认值都不一样,具体请参考相关的IIS配置文档。

      3.在ASP中,服务端获取GET请求参数用
    Request.QueryString,获取POST请求参数用Request.Form。在JSP中,用
    request.getParameter("XXXX")来获取,虽然jsp中也有request.getQueryString()方法,但使用
    起来比较麻烦,比如:传一个test.jsp?name=hyddd&password=hyddd,用
    request.getQueryString()得到的是:name=hyddd&password=hyddd。在PHP中,可以
    用$_GET和$_POST分别获取GET和POST中的数据,而$_REQUEST则可以获取GET和POST两种请求中的数据。值得注意的是,JSP
    中使用request和PHP中使用$_REQUEST都会有隐患,这个下次再写个文章总结。

      4.POST的安全性要比GET的安全性
    高。注意:这里所说的安全性和上面GET提到的“安全”不是同个概念。上面“安全”的含义仅仅是不作数据修改,而这里安全的含义是真正的Security
    的含义,比如:通过GET提交数据,用户名和密码将明文出现在URL上,因为(1)登录页面有可能被浏览器缓存,(2)其他人查看浏览器的历史纪录,那么
    别人就可以拿到你的账号和密码了,除此之外,使用GET提交数据还可能会造成Cross-site request forgery攻击。

      总结一下,Get是向服务器发索取数据的一种请求,而Post是向服务器提交数据的一种请求,在FORM(表单)中,Method默认为"GET",实质上,GET和POST只是发送机制不同,并不是一个取一个发!

      纯属hyddd个人总结,如有错漏请指出。:>

     

    参考资料

    [1].http://hi.baidu.com/liuzd003/blog/item/7bfecbfa6ea94ed8b58f318c.html

    [2].http://www.blogjava.net/onlykeke/archive/2006/08/23/65285.aspx

    [3].http://baike.baidu.com/view/2067025.htm

    [4].http://www.chxwei.com/article.asp?id=373

    [5].http://blog.csdn.net/somat/archive/2004/10/29/158707.aspx

    转载请说明出处,谢谢[hyddd(http://www.cnblogs.com/hyddd/)]

  • 我就是我,是颜色不一样的烟火

    有的传奇演义了,有的演绎了传奇。

    一切都好。

    记得看过一个小故事。

    上帝对人的评价。有三种。

    第一种人,只付出,没有享受过生活和人生。评价50分。

    第二种人,只收获,不付出。没有感受过分享的喜悦。评价50分

    第三种人,既付出又收获,感受了完整的人生。评价100分

    人类对人的评价,也有三种。

    第一种,是圣人,一直在付出,在传道,在奉献,在牺牲。留下永载史册的名称。评价100分

    第二种,是为了一己私欲和野心发动战争,只顾自己享受骄奢淫逸的人。评价是0分。

    第三种,就是芸芸众生,为了家庭而奋斗,付出,然后努力工作拿到报酬是收获。这些人,人类只记得他们面容模糊,给个50分。

    其实上帝记住的人都是芸芸众生。是100分的人。

    而人类记住的人是走两个极端的。不是最美就是最丑的,不是最善的就是最恶的。

    4.1  一切还好。

    生活中有两个悲剧:一个是不能得到你想要的,另一个是得到了它。

    惟草木之零落兮,恐美人之迟暮。  天堂依然,歌声还好。

    后记:应该还有一种人生,他们为自己而活,无论善恶,他们对于自己的评价是多少分?

    活在世人束缚的圣人也许比不上发动战争的恶人对于自己的评分高。

    超越一切,本来就喜欢这种生活的圣人,那就是100分了。自己的人生自己来打分是最合理的。他人生分数的增减只有自己的在生命的长河里,和终点会明白。

  • 少女啊,不要摇曳你的马尾辫

    马尾四处啊摇晃是为了赶苍蝇

    在这个拥挤的地铁里,

    海拔低的人总是在鼻子尖上的发丝,

    在地铁

    看,扎着马尾的女孩

    我站在你的后面,近乎拥抱

    这是十三号线的惯例。

    人体所需要的安全距离已成枉然。

    你站在前面摇头看风景,

    我在后面摇头躲闪你的发。

    无论你多美,

    请让我静止的欣赏吧!

    O(∩_∩)O谢谢

  • 清除空白节点

    先看下面的代码:

    title
    definition

    分别在IE浏览器FF浏览器下执行下面的代码,作用是显示

    标记子节点的个数。
    var dll=document.getElementById(“dll”);
    alert(dll.childNodes.length);

    结果显示:IE为2,FF为5。两个浏览器产生了不同的结果,这是由于一段文本是一个独立的节点,但如果这段文本仅仅由空格,换行,制表符这些特殊的文本字符组成,IE和FF就会产生分歧,IE会忽略这些节点,而FF则认可这些节点。分歧产生的原因是FF认为

    ,

    ,

    之间的空白节点也是一个单独的节点,所说FF chrome的结果是5,而IE的结果是2。

    对于节点的认定,IE在不同的场合也有不同的结果,如下:

    ttt
    some here

    IE认为改div有4个子节点,而FF仍然认为是5个,通过测试发现IE忽略了

    标记之间的空白文本节点,而其他空白文本节点则未被忽略。

    这种分歧给开发带来了很大的难度,它影响了childNodes[index],nextSibling,previousSibling这些间接节点引用的行为,因为nextSibling很可能是一个无用的空白文本节点。解决这个问题是避免文档中出现文本节点。如:

    title
    definition

    这样看上去不好阅读。

    另一种解决的办法就是使用节点的判断,判断要引用的节点是不是需要的节点。prototype-1.3.1框架中提供了一个方法来解决这个问题,在使用前先删除其中的空白节点:

    所以第一例子的代码就可以改成:

    var dll=document.getElementById("dll");
    cleanWhitespace(dll);
    alert(dll.childNodes.length);
    结果在IE和FF都是2。

  • 未曾得到,何谈失去

    感觉很久没有写过东西了,或者认真的剖析自己了。以前一直努力的从学校里面出来,后来一直努力的去济南,后来一直努力的去北京。然后走到了一个节点,就开始想下一个节点。但是来到了北京后,我刚开始感觉是急促的,是觉得时间来不及挥霍就已经流逝了。是在眼花缭乱里面的无穷尽的好奇和试探。是这样的。

    “来京后,最大的发现就是皇城脚下得人就觉得不过如此,什么都是不过如此。

    而以前的同学会觉得怎么怎么的不可思议,而现在就觉得不过如此,也就是一个城市,一个生活而已。没有什么不可以的,什么地方你都敢去,只要你自己独行了后。天下都是任你行的。

    现在需要加强的还是技术方面的。精通css+div 熟练JS和jquery,加油~ ↖(^ω^)↗

    出来后你会后悔,你不是后悔出来,而是后悔懊恼为什么没有早早的出来闯,时间是最宝贵的货币。时间可以买到经历 幸福 金钱 感受等等,但是反过来却不可以。

    考到优米网上面有人询问

    “想去北京发展,各位老师有什么建议? 2012-06-01 14:10:03 ”

    想出来就赶紧的出来。

    到了之后你就后悔为什么没有早出来,为什么没有在实习的时候就出来。为什么还整个什么冠冕堂皇的理由说什么要积累积累工作经验才出来。

    如果你从事的互联网行业的职业,那就赶紧的出来吧。越晚越后悔的。

    其实没有什么困难,在哪都能活,只是看你怎么努力,有目标最棒的。”

    还没有想到写一个节点,现在开始想下一个节点。去年的生活是怎样的呢? 去公司 然后回住处做饭,吃完看小说,到睡觉。然后没了。自己关注的职业规划,努力的基本和未来的目标。沉浸在小说的世界里就像是那些跟我没有关系。看不到就觉得没有我的什么问题。日记也好久没有更新,哪怕是流水账似的写。

    反思现在:

    做到:接触更多的项目,学习好前端开发


    有的时候,你会发现自己有很多的选择,但是不知道自己该走哪条。可是你在犹豫的时刻,可选择的东西越来越少,直至你只有放弃的那条可以选择。

    上帝说 一个只懂得付出的人得到

  • IP又变了,可以上facebook了,不过有些网站则不让上了

     

     

     

    这面墙,不仅围住里面,也会阻止外面的进入。

     

  • 慕课网js练习一




    new document






  • 公交车上得奇人-谢枋得

    如果说他的前一半段人生是部传奇小说,那么后半段是惨烈的悲剧了。其实,不仅仅是文天祥在死的时候高喊“人生自古谁无死,留取丹心照汗青”。他同样在被押赴大都时还高唱“万古纲常担上肩,脊梁铁硬对皇天。人生芳秽有千载,世上荣枯无百年”。他和文天祥是同学么。

    谢枋得(1226~1289年),江西信州弋阳人,字君直,号叠山,别号依斋。聪明过人,文章奇绝;学通“六经”,淹贯百家。

     

    《宋史列传》对谢枋得是这样描绘:“为人豪爽,每观书五行俱下,一览终身不忘。性好直言,一与人论古今治乱国家事,必掀髯抵几,跳跃自奋,以忠义自任”。

    "谢枋得(宋)字君直,号叠山。仕至江西宣谕使。宋亡,死节。" —-《千家诗

     

    其伯父谢徽明抗元战死,其父应琇因忤贵官被冤枉死,枋得由母亲桂氏教养,自幼颖悟,“每观书,五行俱下,一览终身不忘”。宝祐四年(1256)与文天祥同科中进士。次年复试教官,中兼经科。又应吴潜征辟,组织民兵抗元。同年任考官,性好直言,因得罪贾似道而遭黜斥,咸淳三年(1267)赦还。德祐元年(1275),以江东提刑、江西诏谕使知信州。元兵犯境,战败城陷,隐遁于建宁唐石山中,后流寓建阳,以卖卜教书度日。宋亡,寓居闽中。元朝屡召出仕,坚辞不应,福建参政魏天祐强之北行至大都(今北京),在大都悯忠寺(今北京法源寺),坚贞不屈,绝食而死。门人私谥文节。有《叠山集》,存词一首。

     

    再如《小孤山》
    人言此是海门关,海眼无涯骇众观。
    天地偶然留砥柱,江山有此障狂澜。
    坚如猛士敌场立,危似孤臣末世难。
    明日登峰须造极,渺观宇宙我心宽。
    枋得的诗在当时非常有名,读之朗朗上口,回味无穷,他的文也可堪称一流。他无书不读,在当时也是非常有名的学者,他写了大量的书、序、记、启等方面的文章,“文词清丽,高迈奇绝,汪洋演迤,自成一家”。他所作文章,切中时弊,令人读之泣下。如《谒辛稼轩先生祠记》、《上丞相留忠斋书》、《上程雪楼御史书》、《与参政魏容斋书》等都是文中上品,不可多得。他在《上程雪楼御史书》中写道:“某三十一而仕,五十一休官,平生实历,不满八月,俸禄无一毫归家养亲,己不可言孝矣……亲丧在浅土,贫不能礼葬,苫块余息,心死形存”。所谓悠悠寸草心,十分感人。在《与参政魏容斋书》中“宋室遗臣,只欠一死。上天降其才,其生也有日,其死也有时,某愿一死全节矣,所恨时未至耳。”更足以证明他决心为国殉难,视死如归的民族气节。

     

     

    后记:某日在公交上看电子书,里面下载了一本《千家诗》,简简单单的诗句加简简单单的作者介绍,发现有个规律,不外乎是做官做到几何,死后得蒙统治者的加封谥号。没有一个不是文采飞扬的。慢慢的看着,忍不住摇头晃脑的,念出声来。车窗外的阳光也仿若激烈起来。个个儿的诗句,有的能让你觉得震动无比。我想,改变成歌词,不知道能引出人多少泪水和豪迈呢。猛然发现了他,谢枋得。最后的结局是死节,当时不解,过后查找,感慨万千。如此,正应了,人人皆是一部传奇,他们的精彩超出了我的想象。

     

    他们的人生在激扬四射,在慷慨激昂,在烟灰云灭,在重重叠叠的历史中,慢慢的化为尘土。只是但凡有一日,擦拭斑斑的历史后,你发现了他,你就会为他感动,这真是一种美好的感觉。同笑同哭,仿若癫狂。

  • 听首老歌,是在为怀念旧时光做得韵脚

    睡不着,突然想到听电台。

     

    深夜听FM电台,听到大多的人点歌的都是快要高考的人,他们说还有五个月就要高考,希望能再次在同一个校园里欢笑。希望能到某某笔友网友,生长的地方,走过的他或她嬉戏的大街小巷。感受他说的天晴似水,风霜雷电。看看是否能感受他或她说的风景。在主持人说到还有五个月高考的时候,自己就一停顿。我也恍然,原来今天已经是一月份的尾巴,二月份的开始了。时间好快!

     

    还有是在外打工的人,说就要过年回家了,去见那些想见而又不敢见的人。忐忑着欣喜着。

    不确定性 唯一性。

    荏苒岁月颓,此心稍已去。渐行渐远渐无书。

    深夜,只要醒着就会把沉到心底的尘埃宝藏碎片,翻腾而出。随着碎片的上升,老歌的旋律,你开始忆起某些以为遗忘的时光。当听到高潮的时候,奔腾的回忆呼啸而来。

    某些时光,你以为已经忘却,只需要一个契机,就开始翻腾出现。

  • 向日葵远程控制:PC主控端远控

        向日葵远程控制是一款免费的面向企业和专业人员的远程PC管理和控制软件。在任何可链接互联网的地点,都可以通过PC主控端方式轻松控制和访问安装了向日葵被控端的远程主机。
         向日葵PC主控端是为便捷的批量远程主机而生,操作管理简单,具有超炫的界面效果和创新的多屏幕查看模式。 
     
    1.PC主控端介绍
         向日葵PC主控端具有简单易操作的特点,三种展示模式,可自由切换。 
     
    1.1.向日葵PC主控端登录
         向日葵主控端登录只需填写护照及密码即可。 

    图1.1向日葵主控端登录

    1.2.向日葵主控端界面介绍
         登录后可直接进入向日葵主控端界面。如图所示。 
         向日葵主控端界面简单易操作。主要包括远程控制、远程协助、屏幕查看、远程桌面、远程文件、命令行、添加主机七个部分。 
    图1.2向日葵主控端界面

    1.3.展示模式
         向日葵主控端共有三种展示模式:普通模式、迷你模式、导航模式。点击面板右下角的模式切换图标,即可切换到不同的显示模式。如下图所示。 
         普通模式,点击可切换到迷你模式。 

    图1.3.1普通模式

         迷你模式,点击后可切换到导航模式。 

    图1.3.2迷你模式

         导航模式,点击可切换到普通模式。

     
    图1.3.3导航模式

    2.PC主控端远程控制
         使用PC主控端如何实现远控控制呢? 
    2.1.登录远程主机
         向日葵PC主控端登录远程主机提供两种验证方式:windows验证和访问密码验证。 
         注:访问密码是在被控端主机设置中的安全中进行设置的。 

    图2.1.1windows帐号登录


    图2.1.2访问密码登录

         成功登录后,进入远程主机桌面,选择模式。如下图所示。 

    图2.1.3选择模式

         选择模式后,即可进入到远程主机桌面。 
         注:控制模式可进入到远程主机桌面控制台,对远程主机进行管理操作。观看模式则只用于观看,不可进行远程操作。 
    2.2.远程控制
         在向日葵远程控制中可以看到远程主机名称、创建时间、标记、葵码、登录账户等信息。 

    图2.2.1远程控制

         右键点击远程主机,也可对远程主机进行远程桌面、远程文件、发送即时消息、屏幕查看、删除主机、查看主机属性等操作。 

    图2.2.2远程主机操作

    2.3.远程桌面
         登录远程主机后即可进入到远程主机桌面,对远程主机进行管理操作。 
    图2.3远程桌面

    2.4.远程文件
         通过向日葵远程文件可以方便的对远程主机文件进行传输和管理操作。支持断点续传,让远程文件和本地文件互相传输和同步。 

    图2.4远程文件

    2.5.命令行
         使用向日葵远程控制的命令行功能,可以直接输入命令来查找原因,就跟在自己的电脑上进行操作一样。 

    图2.5命令行

    2.6.添加主机
         向日葵远程控制支持批量添加主机,可以方便用户对远程主机进行批量监控与管理。 

    图2.6添加主机

    3.PC主控端特色功能
    3.1.远程协助
         向日葵远程控制也可以进行远程协作操作。只需主控端发一个链接,对方安装一个插件,待对方接受邀请后便可帮同事、朋友解决PC使用中所遇到的各类问题。具体操作步骤如下。 
         在向日葵PC主控端上,点击远程协助。 

    图3.1.1选择远程协助

         右键单击远程协助主机,在属性中选择远程协助,复制URL链接地址发送给对方,或者求助者通过访问8005566.com输入葵码方式即可发起远程协助。 

    图3.1.2复制链接发起远程协助

         在对方电脑上,会显示需要安装浏览器插件的提示,点击在线安装。 

    图3.1.3在线安装插件

         下载安装文件。 

    图3.1.4下载安装文件

         运行安装文件,进入安装程序。 

    图3.1.5运行安装文件

         安装完成。 

    图3.1.6安装完成

         插件安装成功后,点击“请求协助”,等待对方接受。在此也可以添加附言。 

    图3.1.7请求协助

         对方收到远程协助请求,选择接受。 

    图3.1.8对方收到请求

         对方接受请求后即可进入远程桌面,开始控制对方电脑帮忙解决问题了。在远程桌面右侧也可以和对方聊天,发送文件。 

    图3.1.9进入远程桌面

    3.2.多屏幕查看
         向日葵远程控制支持多屏幕查看功能,用户可以在同一桌面上实现对多个被控端的管理。 

    图3.2多屏幕查看
     

         更多向日葵详情请登录向日葵官网:http://www.oray.com/sunlogin
         向日葵被控端下载地址:http://www.oray.com/sunlogin/download_sunlogin.php
         向日葵主控端下载地址:http://www.oray.com/sunlogin/download_cclient_beta.php