位置: IT常识 - 正文
推荐整理分享day14-HTTP01,希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!
HTTP请求头大全 - 常用参考表对照表
HTTP状态码大全 - 常用参考表对照表
2.快速入门HTTP协议2.1使用Chrome抓取http请求和相应数据包快捷键ctrl+shift+i或者f12
浏览器请求资源的UML图详见Tomcat01-3.9浏览器访问web服务器过程详解
2.2页面请求次数分析如下,新建一个web项目,在web文件夹中编写test.html文件
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>http请求的问题</title></head><body><h1>图片</h1><img src="" width="300px"><img src="" width="300px"></body></html>当浏览器访问test.html页面时,一共发出了几次请求?
答:一共发出了三次请求。
第一次请求的是test.html文件当浏览器解析发现tese.html中还有<img src="" width="300px"> <img src="">时会向服务器继续发送请求,要1.png和2.png图片的资源,一共三次请求验证
启动Tomcat服务器,在浏览器中按f12打开控制台:
可以看到浏览器一共请求了三次,第一次是html,后两次是jpg图片
favicon.ico是网站的图标,每次都会默认请求,这里忽略
3.HTTP请求包分析(GET)演示:HTTP请求(GET)-有数据提交情况
新建一个java项目,添加web支持,导入servlet-api的jar包,创建Tomcat。
在src目录下创建LoginServlet,给页面返回数据
package li.servlet;import javax.servlet.*;import javax.servlet.http.*;import javax.servlet.annotation.*;import java.io.IOException;import java.io.PrintWriter;/** * LoginServlet */@WebServlet(urlPatterns = {"/login"})public class LoginServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //服务器端输出 System.out.println("LoginServlet doGet() 被调用"); //输出一句话,返回给浏览器 //1.通过response获取一个流PrintWriter,可以给浏览器回复数据 //2.为了让浏览器显示中文,需要设置编码为utf-8 //(1)给回送的数据设置编码 (2)text/html这个是MIME,即告诉浏览器返回的数据是 //text类型下的html格式数据[MIME类型](3)charset=utf-8给数据设置编码 //注意:设置编码要在 response.getWriter()之前,否则无效 response.setContentType("text/html;charset=utf-8"); PrintWriter writer = response.getWriter(); writer.print("<h1>登录成功~</h1>"); //为了确保数据返回,可以调用flush()和close() //flush()表示将缓存的数据进行刷新 writer.flush(); //close()表示关闭流,有些语言是close方法中就包含了flush方法 writer.close(); //建议调用flush()和close() } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //服务器端输出 System.out.println("LoginServlet doPost() 被调用"); //输出一句话,返回给浏览器 //1.通过response获取一个流PrintWriter,可以给浏览器回复数据 //2.为了让浏览器显示中文,需要设置编码为utf-8 //(1)给回送的数据设置编码 (2)text/html这个是MIME,即告诉浏览器返回的数据是 //text类型下的html格式数据[MIME类型](3)charset=utf-8给数据设置编码 //注意:设置编码要在 response.getWriter()之前,否则无效 response.setContentType("text/html;charset=utf-8"); PrintWriter writer = response.getWriter(); writer.print("<h1>POST登录成功~</h1>"); //为了确保数据返回,可以调用flush()和close() //flush()表示将缓存的数据进行刷新 writer.flush(); //close()表示关闭流,有些语言是close方法中就包含了flush方法 writer.close(); //建议调用flush()和close() }}在web目录下创建login.html:
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>用户登录</title></head><body><h1>用户登录</h1><!--给LoginServlet发送get请求--><form action="http://localhost:8080/http/login" method="get"> u:<input type="text" name="username"/><br/> p:<input type="password" name="pwd"/><br/> <input type="submit" name="用户登录"/><input type="reset" name="重置"/></form></body></html>点击redeployTomcat
在浏览器中打开调试台(f12),点击网络。在地址栏输入:http://localhost:8080/http/login.html,回车。
在login.html的框中输入信息,点击登录,调试台显示如下:
点击第一个请求,查看请求头:
4.HTTP请求包分析(POST)在上面的基础上修改login.html文档的提交方式为 post
redeployTomcat,然后在浏览器中打开调试台(f12),点击网络。
在地址栏输入:http://localhost:8080/http/login.html并回车。
在login.html的框中输入信息,点击登录,调试台显示如下:
点击第一个请求,查看请求头:可以发现请求行中已经没有用户提交的数据了
在请求按钮下面可以看到用户请求的表单数据:其实原始的post请求是包含该数据的,只是浏览器将其分开了
补充:
content-type中的x-www-form-urlencoded:表示我们的表单数据是url编码
url编码是一种浏览器用来打包表单输入的格式。浏览器从表单中获取所有的name和其中的值 ,将它们以name/value参数编码(移去那些不能传送的字符,将数据排行等等)作为URL的一部分或者分离地发给服务器
例如:表单输入中文符号提交,在表单数据中可以看到url编码如下:
解码后显示:
content-length表示发送的数据长度,这里的数据为表单数据,告诉服务器要按多少个字节来读取
5.GET请求和POST请求到底有哪些?5.1GET请求form标签method=geta 标签link标签引入css [以get方式来获取资源]script标签引入js文件 [以get方式来获取资源]img标签引入图片iframe引入html页面在浏览器地址栏中输入地址后敲回车例子
5.2POST请求form标签method=post5.3HTTP请求中怎么样选择get和post请求在大多数情况下不需要考虑这个问题,因为业务本身就会自动区别
传输的数据大小区别
get传送的数据量比较小,不能大于2KB(不同的浏览器不一样)post传输的数据量比较大,一般默认不受限制什么情况下使用post请求
post请求是会在浏览器上隐藏参数部分的,在安全要求的部分都会使用到post请求,如用户登录等。这样不会通过你的请求暴露你的参数格式在向服务器传递数据较大的时候,使用post(get有限制),比如发帖,上传文件什么情况下使用get请求
在前台页面展示,比如分页内容,可以保留传递参数;也可用来分享和传播,而在post中链接地址是不变的
建议:
get方式的安全性较post要差些。包括机密信息的话就使用post在做数据查询时,建议使用get方式;而在做数据加入,改动和删除时,建议用post方式上一篇:phpcms是收费的么(phpcms 用的是什么模板引擎)
下一篇:详解如何在JavaScript中使用三元运算符(java sc)
友情链接: 武汉网站建设