http协议,又称为超文本传输协议,顾名思义,http协议不仅能传输文本,还能传输图片,视频,压缩包等文件,http协议是建立在tcp/ip协议的基础之上的,http协议对php程序员来讲可以说是重中之重了;

  http请求基本结构分为:请求行;消息头;实体内容;

  请求行:

    GET/xxx/xxx.html  HTTP/1.1          //HTTP/1.1是http协议版本,1.1支持长连接,1.0支持短连接,目前普遍使用1.1版本;

  消息头(请求报头):

    Accept:*/*         //表示客户端可接受什么类型的资源,*表示通配符,表示可以接受任何类型的资源;

    Referer : http://localhost:80/XX.html        //表示用户是从哪里链接过来的(之后防盗链技术会详解);

    Accept-Launguage: zh-cn                 //表示页面可以支持哪种语言;

    User-Agent: Mozila/4.0                    //表示浏览器的内核以及操作系统;

    Accept-Encoding:gzip,deflate    //表示客户端支持什么类型的数据压缩格式;

    Host:localhost:80                       //表示主机号和端口,这个是给tcp/ip协议识别的;

    Connection:Keep-Alive                //表示长连接,不会立刻中断请求;

  实体内容                                               //表示客户端向服务器传递了哪些资源;

  http响应内容:

    HTTP/ 1.1  200  OK      //200表示服务器请求成功;其余常见的状态码在后面说;

    Server:          //表示服务器信息;

    Date:            //浏览器请求该页面的时间;

    Content-Length:                          //表示服务器回送了多少字节的资源;

    Content-Type:                             //文档类型及使用什么编码;

    Last-Modified:         //所请求的资源最新更新时间;

    Refresh:1;url=http:xxx.com    //间隔多少秒之后重定向;可在header()函数中写入实现X秒后重定向页面;

    Content-Disposition:        //这个关于文件下载;

    Transfer-Encoding:         //文件下载

    Set-Cookie:            

    Keep-Alive:timeout=5,max=99    //表示长连接可维持多少秒;

    Expires: -1 ;             //控制页面是否支持缓存;浏览器默认支持缓存,在header函数中输入以下三个头信息;

    Cache-Control: no-cache ;       //缓存存在的时间是可以自行指定的;

    Pragma:  no-cache ;         //控制页面是否支持缓存;

  http响应的状态码详解可以点击下面链接查阅:https://baike.baidu.com/item/HTTP%E7%8A%B6%E6%80%81%E7%A0%81/5053660?fr=aladdin

  常用的有302,304,202,404状态码:302状态码一般用于做重定向;404状态码通常是所查找的资源不存在;304码一般在当http发送请求资源时发现缓存中有相同资源,浏览器则会向服务器端发送一个(Last-Modified:)该资源最近更新的时间参数,由服务器去验证该资源的最近更新时间是否一致,如一致说明该资源没有进行更新则向缓存取出该资源;

  在PHP中你可以通过 echo  $_SERVER   来获取所有关于该页面HTTP协议的所有内容;

  常用的有:

    HTTP_HOST      //主机名;

    DOCUMENT_ROOT    //获取apche的主目录;

    REQUEST_URI    //获取请求的资源名;

    REMOVE_ADDR    //获取当前访问客户端的IP地址;

    HTTP_REFERER            //告诉服务器我是从哪个页面链接过来的;

      用法:  $_SERVER[ ' REMOVE_ADDR ' ] ;

  可以使用header()语句向http响应头写入信息;

  http的请求方式有两种,GET请求和POST请求;从安全性而言,GET请求会显示在地址栏上,相比POST而言更不安全;GET请求处理速度更快,但是只可以处理2K以内的数据,多数用于查数据,而POST虽相对较慢但不限制资源大小,多数用于增、删、改;

    $_GET :可传输多个参数,eg:http://xxx/xxx.php?字段名=参数&字段名=参数;使用empty($_GET('字段名'))验证是否接收到参数;

    $_POST :用于传递数据,多数用于增删改;在php.ini文件中关闭register_globals设置,防止SQL注入;

  简单的防盗链技术:

    if( isset ( $_SERVER[ ' HTTP_REFERER' ] ) ){          //这条语句判断HTTP协议里是否有REFERER值;

        if( strpos ( $SERVER[ ' HTTP_REFERER' ] ,“ http://页面主址 ” ) == 0 ){   //这条语句判断REFERER值是否从本网站链接进来;

            echo   显示信息  ;

        }else{

            header( " Location:  警告页面 " );      //如进入else语句则说明该用户是盗链过来的,跳转到警告页面;

        }

    }else{

      header( " Location:  警告页面 " );

    }

    

  

http协议以及防盗链技术的更多相关文章

  1. php笔记05:http协议中防盗链技术

    倘若我们自己在电脑上写了一个网站文件(可以是html,php文件等等),但是只希望本机可以访问这个文件,不希望别的电脑访问就需要这里的防盗链技术 1.我们在本地写了一个import.php文件: 而且 ...

  2. 防盗链技术终极解决方案(squid+cookie)

    防盗链技术现状:1.通过识别Referer确认请求来源页面2.Apache,squid等都能对Referer进行识别3.通过ActiveX显示的内容不向服务器提供Referer Header(例如,F ...

  3. php破解防盗链技术

    php破解防盗链技术 发送http请求 构造referer信息 在Http协议中,头信息里,有一个重要的选项: Referer Referer: 代表网页的来源,即上一页的地址 具体方法http.cl ...

  4. php防盗链技术

    在Http协议中,头信息里,有一个重要的选项: Referer Referer: 代表网页的来源,即上一页的地址 如果是直接在浏览器上输入地址,回来进来,则没有Referer头. 这也是: 为什么服务 ...

  5. [php]referer应用--http防盗链技术

    1.防盗链的理解 所谓防盗链是防止其他的网站引用自己网站的资源连接,比如图片.视频等等,但是并不会阻碍从自己网站上享受资源的用户,这就要求能够将其他网站的连接请求阻止 2.防盗链的原理 其实从自己网站 ...

  6. JavaWeb学习记录(二)——防盗链技术

    public class TestServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpSer ...

  7. PHP HTTP协议:防盗链

    test.html:主界面 <html> <head> <meta http-equiv="content-type" content="t ...

  8. Java防盗链机制

    对于防盗链技术,网上提供了很多很多的相关技术,但是不是特别复杂就是效果不好. 这里在网上找到一种思路,就是关于HTTP协议响应头中包含的Referer,告诉服务器我是从哪个页面链接过来的,服务器籍此可 ...

  9. 防盗链&CSRF&API接口幂等性设计

    防盗链技术 CSRF(模拟请求) 分析防止伪造Token请求攻击 互联网API接口幂等性设计 忘记密码漏洞分析 1.Http请求防盗链 什么是防盗链 比如A网站有一张图片,被B网站直接通过img标签属 ...

随机推荐

  1. GEF入门笔记

    最近项目中需要用到Eclipse GEF框架进行画图,故将平时学习笔记更新到博客中,便于查阅 自己画的一个GEF基本结构     最基本流程 1.创建model(包括数据域.在界面中的布局.图片索引等 ...

  2. Poj Maya Calendar

    http://poj.org/problem?id=1008 Maya Calendar Time Limit: 1000MS Memory Limit: 10000K Total Submissio ...

  3. PHP在Linux的Apache环境下乱码解决方法

    在windows平台编写的php程序默认编码是gb2312 而linux和apche默认的编码都是UTF-8 所以windows平台编写的php程序传到linux后,浏览网页中文都是乱码. 如果手工将 ...

  4. 「JavaSE 重新出发」05.03.03 使用反射编写泛型数组代码

    Employee[] a = new Employee[100]; // ... // array is full a = Arrays.copyOf(a, 2 * a.length); 如何编写这样 ...

  5. 京东专业“卖”队友,魅族手环将亮相1206魅蓝note新品发布会

    京东一直是国内顶级的数码产品自营销售渠道,但是,正因为庞大的数据体系和平台特殊性,经常会帮我们发现一些“好玩的”保密性较高的东西,譬如价格.信息.谍照等.而在最新上线的京东超级品牌日活动页面上,专业“ ...

  6. (转)基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用

    http://www.cnblogs.com/wuhuacong/p/3343967.html 大概一年前,我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随 ...

  7. 【转】Oracle基础结构认知——oracle内存结构 礼记八目 2017-12-15 20:31:27

    oracle的数据库实例是一组后台进程和内存结构组成的,而内存结构由系统全局区(system global area)和程序全局区(program global area)组成. #修改SGA和PGA ...

  8. Steamroller FreeCodeCamp

    function steamroller(arr) { // I'm a steamroller, baby var resultArr = []; for(var i = 0; i < arr ...

  9. word2016如何英汉互译

    1.如果是一篇英文文档且是pdf格式,可以用word2016打开直接转化成了word,就算不是会员也可以的,在此附上16版的光盘安装包,可以百度自行下载 (链接:https://pan.baidu.c ...

  10. BZOJ1150 [CTSC2007] 数据备份Backup 贪心_堆_神题

    Description 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味 的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家 ...