黑马程序员技术交流社区

标题: 学习注意事项 [打印本页]

作者: lishuaigang    时间: 2019-2-27 15:38
标题: 学习注意事项
Http:
* 概念:Hyper Text Transfer Protocol 超文本传输协议
        * 传输协议:定义了,客户端和服务器端通信时,发送数据的格式
        * 特点:
                1. 基于TCP/IP的高级协议
                2. 默认端口号:80
                3. 基于请求/响应模型的:一次请求对应一次响应
                4. 无状态的:每次请求之间相互独立,不能交互数据

        * 历史版本:
                * 1.0:每一次请求响应都会建立新的连接
                * 1.1:复用连接

* 请求消息数据格式
        1. 请求行
                请求方式 请求url 请求协议/版本
                GET /login.html        HTTP/1.1

                * 请求方式:
                        * HTTP协议有7中请求方式,常用的有2种
                                * GET:
                                        1. 请求参数在请求行中,在url后。
                                        2. 请求的url长度有限制的
                                        3. 不太安全
                                * POST:
                                        1. 请求参数在请求体中
                                        2. 请求的url长度没有限制的
                                        3. 相对安全
        2. 请求头:客户端浏览器告诉服务器一些信息
                请求头名称: 请求头值
                * 常见的请求头:
                        1. User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息
                                * 可以在服务器端获取该头的信息,解决浏览器的兼容性问题

                        2. Referer:http://localhost/login.html
                                * 告诉服务器,我(当前请求)从哪里来?
                                        * 作用:
                                                1. 防盗链:
                                                2. 统计工作:
        3. 请求空行
                空行,就是用于分割POST请求的请求头,和请求体的。
        4. 请求体(正文):
                * 封装POST请求消息的请求参数的

        * 字符串格式:
                POST /login.html        HTTP/1.1
                Host: localhost
                User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0
                Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
                Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
                Accept-Encoding: gzip, deflate
                Referer: http://localhost/login.html
                Connection: keep-alive
                Upgrade-Insecure-Requests: 1
               
                username=zhangsan       
       
                * 路径写法:
                        1. 路径分类
                                1. 相对路径:通过相对路径不可以确定唯一资源
                                        * 如:./index.html
                                        * 不以/开头,以.开头路径

                                        * 规则:找到当前资源和目标资源之间的相对位置关系
                                                * ./:当前目录
                                                * ../:后退一级目录
                                2. 绝对路径:通过绝对路径可以确定唯一资源
                                        * 如:http://localhost/day15/responseDemo2                /day15/responseDemo2
                                        * 以/开头的路径

                                        * 规则:判断定义的路径是给谁用的?判断请求将来从哪儿发出
                                                * 给客户端浏览器使用:需要加虚拟目录(项目的访问路径)
                                                        * 建议虚拟目录动态获取:request.getContextPath()
                                                        * <a> , <form> 重定向...
                                                * 给服务器使用:不需要加虚拟目录
                                                        * 转发路径
                                                       
                                        服务器输出字符数据到浏览器                * 步骤:                        1. 获取字符输出流                        2. 输出数据                * 注意:                        * 乱码问题:                                1. PrintWriter pw = response.getWriter();获取的流的默认编码是ISO-8859-1                                2. 设置该流的默认编码                                3. 告诉浏览器响应体使用的编码                                //简单的形式,设置编码,是在获取流之前设置                            response.setContentType("text/html;charset=utf-8");        3. 服务器输出字节数据到浏览器                * 步骤:                        1. 获取字节输出流                        2. 输出数据        4. 验证码                1. 本质:图片                2. 目的:防止恶意表单注册






欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2