当前位置: 首页 > article >正文

node.js基础学习-querystring模块-查询字符串处理(三)

一、前言

querystring是 Node.js 中的一个内置模块,主要用于处理 URL 查询字符串。它提供了一些实用的方法来解析和格式化查询字符串,使得在处理 HTTP 请求中的查询参数等场景时非常方便。
还可以防止sql注入

二、解析查询字符串(parse方法)

功能:将 URL 查询字符串解析为一个 JavaScript 对象。

语法querystring.parse(str[, sep[, eq[, options]]])

  • str:要解析的查询字符串。
  • sep(可选):用于分隔查询字符串中的键值对的字符,默认是&
  • eq(可选):用于分隔键和值的字符,默认是=
  • options(可选):一个包含decodeURIComponent函数的对象,用于解码查询字符串中的字符。如果没有提供这个函数,默认使用querystring.unescape()

示例

const querystring = require('querystring');
const query = 'name=John&age=30';
const parsed = querystring.parse(query);
console.log(parsed); 
// 输出: { name: 'John', age: '30' }

三、格式化对象为查询字符串(stringify方法)

功能:将一个 JavaScript 对象格式化为 URL 查询字符串。

语法querystring.stringify(obj[, sep[, eq[, options]]])

  • obj:要格式化的对象。
  • sep(可选):用于分隔键值对的字符,默认是&
  • eq(可选):用于分隔键和值的字符,默认是=
  • options(可选):一个包含encodeURIComponent函数的对象,用于编码对象中的字符。如果没有提供这个函数,默认使用querystring.escape()

示例

const querystring = require('querystring');
const obj = { name: 'John', age: 30 };
const str = querystring.stringify(obj);
console.log(str); 
// 输出: name=John&age=30

四、编码(escape方法)和解码(unescape方法)

可以使用编码解码的方式防止sql注入

escape方法

功能:对字符串进行 URL 编码,将特殊字符转换为它们的十六进制编码形式。

示例

const querystring = require('querystring');
const str = 'a b c';
const escaped = querystring.escape(str);
console.log(escaped); 
// 输出: a%20b%20c

unescape方法

功能:对经过 URL 编码的字符串进行解码,将十六进制编码形式的字符转换回原始字符。

示例

const querystring = require('querystring');
const str = 'a%20b%20c';
const unescaped = querystring.unescape(str);
console.log(unescaped); 
// 输出: a b c

这些方法在 Node.js 的 Web 开发中,特别是在处理 HTTP 请求的查询参数和构建 URL 等场景下发挥着重要的作用。例如,在处理GET请求时,从请求的 URL 中提取查询参数并将其转换为易于操作的对象,就可以使用querystring.parse方法。而在构建GET请求的 URL 时,需要将参数对象转换为查询字符串,这时就可以使用querystring.stringify方法。


http://www.kler.cn/a/419126.html

相关文章:

  • Django Auth的基本使用
  • 【接口封装】——11、Qt 的单例模式
  • 【linux学习指南】Linux进程信号产生(三) 硬件异常除零出错?野指针异常?core文件
  • AtomicIntegerFieldUpdater能否降低内存
  • 202页MES项目需求方案深入解读,学习MES系统设计规划
  • SRS搭建直播推流服务
  • 二分搜索(二)搜索插入位置
  • javascript切换类、删除类、修改类以及增加类
  • 低代码与微服务融合在医疗集团中的补充应用探究
  • 计算机网络--网络安全测试
  • 【关闭or开启电脑自带的数字键盘】
  • 第1章-JVM和Java体系架构
  • 【QNX+Android虚拟化方案】127 - QNX侧 uart 读写程序分析
  • MySQL中的count函数
  • 大模型开发和微调工具Llama-Factory-->量化2(AQLM和OFTQ)
  • Ubuntu在NVME硬盘使用Systemback安装记录
  • Design Linear Filters in the Frequency Domain (MATLAB帮助文档)
  • Python json 序列化
  • mongodb/redis/neo4j 如何自己打造一个 web 数据库可视化客户端?
  • Linux —— 《线程控制》
  • nmap基本用法
  • 【小白学机器学习39】如何用numpy生成总体,生成样本samples
  • 【RISC-V CPU debug 专栏 2.3 -- Run Control】
  • .NET周刊【11月第4期 2024-11-24】
  • React与Ant Design入门指南
  • springboot336社区物资交易互助平台pf(论文+源码)_kaic