热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

通过Nodeexpress服务端程序深入了解HTTP请求(一)

代码仓库:https:github.comjczzqcool…HTTP知识提要HTTP(超文本传输协议)是一个客户端(浏览器)和服务端(服务器)用于请求和响应的标准。记录http请

代码仓库:https://github.com/jczzq/cool…

HTTP 知识提要

HTTP(超文本传输协议)是一个客户端(浏览器)和服务端(服务器)用于请求响应的标准。记录http请求和响应信息的代码称为报文

HTTP动作

HTTP/1.1协议中共定义了八种方法来操作指定的资源:GET、HEAD、 POST、 PUT、 DELETE、 TRACE、 OPTIONS、 CONNECT

HTTP报文

HTTP报文由4个部分组成:

  • 请求(响应)行(第一行,以下将称为起始行
  • 头字段(第一行之后,明文字符串,以冒号分隔的键名与键值对,以回车(CR)加换行(LF)符号序列结尾。)
  • 空行
  • 请求体(可选的HTTP报文主体数据)

HTTP头字段

HTTP头字段(HTTP header fields)是指在HTTP的请求和响应消息中的消息头部分。它们定义了一个超文本传输协议事务中的操作参数。HTTP头字段根据实际用途被分为以下 4 种类型:

  • 通用头字段(General Header Fields):同时适用于请求和响应消息,但与最终消息主体中传输的数据无关的消息头。
  • 请求头字段(Request Header Fields):包含更多有关要获取的资源或客户端本身信息的消息头。
  • 响应头字段(Response Header Fields):包含有关响应的补充信息,如其位置或服务器本身(名称和版本等)的消息头。
  • 实体头字段(Entity Header Fields):包含有关实体主体的更多信息,比如主体长(Content-Length)度或其MIME类型。

请求方的头结构:通用报头 | 请求报头 | 实体报头
响应方的头结构:通用报头 | 响应报头 | 实体报头

需要注意的是请求头并不是按照我们理解的语义化分类,而是按照
RFC文件标准已经归类。Accept属于请求头, Content-Type属于实体头。HTTP头部字段可以自己根据需要定义,因此可能在 Web 服务器和浏览器上发现非标准的头字段。,按照惯例,非标准的协议头字段是在字段名称前加上
X-前缀来标识。但这一惯例已在2012年6月被废弃,因为按照这种惯例,非标准字段变成标准字段时会引起很多不方便之处。

准备工作

这是我的测试表单:

:method="form.method"
:enctype="form.enctype">



{{ form.name }} | action="{{ form.action }}" | method="{{ form.method }}" | enctype="{{ form.enctype }}"

























服务端脚本:

const path = require('path');
const express = require('express');
var app = express();
// 设置静态文件目录
app.use(express.static(path.resolve('./static')));
console.info('静态文件目录:', path.resolve('./static'));
// 首页
app.get('/', function(req, res) {
res.sendFile(path.join(__dirname, './index.html'));
});
app.use('/user', (req, res, next) => {
// return res.json({
// query: req.query,
// params: req.params,
// body: req.body
// });
return res.sendStatus(200);
});
app.listen(3000, '0.0.0.0', () => {
console.log('启动服务器: http://localhost:3000');
});

1. 表单提交时表单内的数据将会被如何处理?

表单提交有三个关键的属性:action,method,enctype。这三个参数分别指定了http请求消息的路径、动作、消息实体如何编码。前两者不做赘述,下面仔细说enctype属性。HTML5 Form的enctype有三个枚举值:

  • application/x-www-form-urlencoded
    Form表单默认编码方式,method="GET"时表单值内会自动处理成(?name1=value1&name2=value2…)结构的参数并追加到action指定的url之后。
  • multipart/form-data
    表单内有文件提交必选的编码格式。
  • text/plain
    表单数据以纯文本形式进行编码。

application/x-www-form-urlencoded

《通过 Node express服务端程序深入了解HTTP请求(一)》
《通过 Node express服务端程序深入了解HTTP请求(一)》

可以看到表单GET提交的数据默认采取了application/x-www-form-urlencoded编码。被追加到url后面。服务端默认响应的Content-Type是text/plain纯文本。

《通过 Node express服务端程序深入了解HTTP请求(一)》
《通过 Node express服务端程序深入了解HTTP请求(一)》

再来看看表单POST提交的报文,请求报文头字段Content-Type明文显示application/x-www-form-urlencoded,响应报文头字段Content-Type依然是默认的text/plain纯文本。

multipart/form-data

接下来看看第二个multipart/form-data,并且上传一个图片23333.jpg
《通过 Node express服务端程序深入了解HTTP请求(一)》

《通过 Node express服务端程序深入了解HTTP请求(一)》

观察请求报文,头字段Content-Type是我们设定的multipart/form-data,并且制定了一个特定的值boundary,请求实体被编码变成了一整条消息,里面的数据由分隔符boundary分割成了多个部分,每一个部分的描述不尽相同,其中我们上传的文件23333.jpg已经处理成了乱码。

text/plain

接下来看看第三个text/plain,依然上传一个图片23333.jpg
《通过 Node express服务端程序深入了解HTTP请求(一)》
《通过 Node express服务端程序深入了解HTTP请求(一)》

头字段Content-Type是我们设定的text/plain纯文本,服务端响应的也是纯文本。

参考链接

HTTP头字段 – Wikipedia
HTTP Headers – MDN
关于HTTP Content-Type说明

如有不足,欢迎指正。


推荐阅读
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
author-avatar
郝泓帥_169
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有