百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Node.js 学习笔记:使用数据库

liuian 2025-03-13 17:17 12 浏览

这部分示例将示范SQLite3、MongoDB这两种不同类型的数据库在 Node.js 中的使用方法。首先,我们要在code目录下执行mkdir 06_database命令来创建用于存放这一组示例的目录。

1. SQLite

SQLite3是一个轻量级的关系型数据库,我们在这里用它来示范 Node.js 对关系型数据库的处理。首先,在code/06_database目录下执行mkdir sqlite命令,并执行以下步骤:

  1. 在code/06_database/sqlite目录下执行npm install sqlite3命令,将sqlite3安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/sqlite目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/sqlite目录下执行touch Sqlite.js,创建一个脚本文件,具体如下:
const fs = require('fs')
const sqlite3 = require('sqlite3').verbose()

class SqliteDB {
constructor(file) {
this.db = new sqlite3.Database(file)
const db_exist = fs.existsSync(file)

if ( !db_exist ) {
console.error('数据库文件创建成功!')
fs.openSync(file, 'w')
}
}

createTable(sql) {
this.db.serialize(function() {
this.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
})
}

insertData(sql, objects) {
this.db.serialize(function() {
const stmt = this.prepare(sql)
for ( let i = 0; i < objects.length; ++i ) {
stmt.run(objects[i])
}

stmt.finalize()
})
}

queryData(sql, callback, message) {
this.db.all(sql, function(err, rows) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}

if( callback ) {
callback(rows, message)
}
})
}

executeSql(sql) {
this.db.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
}

close() {
this.db.close()
}
}

module.exports = SqliteDB

4、在code/06_database/sqlite目录下执行touch useSqlite.js,创建一个脚本文件,具体如下:

const async = require('async')
const SqliteDB = require('./Sqlite')
const file = "HRDB.db"
const sqliteDB = new SqliteDB(file)

function dataDeal(objects, message) {
console.log(message)
for ( const i = 0; i < objects.length; ++i ) {
console.log(objects[i])
}
}

async.waterfall([
function (callback) {
// 创建表格
const createTableSql = `
create table if not exists HR_TABLE (
name TEXT,
age TEXT,
sex TEXT,
items TEXT
);`
sqliteDB.createTable(createTableSql)
callback()
},

function (callback) {
// 插入数据
const insertTileSql = `
insert into HR_TABLE
(name, age, sex, items)
values(?, ?, ?, ?)`
const arr = [
['凌杰', '24', '男', '看书, 看电影, 旅游'],
['蔓儿', '25', '女', '看书, 看电影, 写作'],
['张语', '32', '女', '看书, 旅游, 绘画']
]
sqliteDB.insertData(insertTileSql, arr)
callback()
},

function (callback) {
// 查询数据
const querySql = 'select * from HR_TABLE'
sqliteDB.queryData(querySql, dataDeal, '初始数据')
callback()
},

function (callback) {
// 更新数据
const updateSql = `update HR_TABLE set age = 37 where name = "凌杰"`
sqliteDB.executeSql(updateSql)
callback()
},

function (callback) {
// 查询更新后的数据
querySql = `select * from HR_TABLE`
sqliteDB.queryData(querySql, dataDeal, '更新后数据')
callback()
},

function (callback) {
sqliteDB.close()
callback()
}
])

5、保存所有文件后,在code/06_database/sqlite目录下执行node useSqlite.js命令,结果如下:

2. MongoDB

MongoDB是非关系型数据库的一个典型代表,我们在这里用它来示范 Node.js 对关系型数据库的处理。在 Node.js 中操作MongoDB数据库有两个扩展包可以选择,下面我们一一来演示。首先,在code/06_database目录下执行mkdir mongodb命令,并执行以下步骤:

使用mongodb包

  1. 在code/06_database/mongodb目录下执行npm install mongodb命令,将mongodb包安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/mongodb目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/mongodb目录下执行touch useMongodb.js,创建一个脚本文件,具体如下:
 const MongoClient = require('mongodb').MongoClient
const async = require('async')
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName

MongoClient.connect(dbPath, { useNewUrlParser: true },
function(err, db) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}

const dbo = db.db(dbName)
console.log(dbName + '数据库创建成功')

const collect = dbo.collection(collName)
console.log(collName + '集合创建成功')

async.series([
// 控制程序串行执行

function (callback) {
// 插入单条数据
const data = {
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
}

collect.insertOne(data, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('单条数据插入成功')
})
callback()
},

function (callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

collect.insertMany(dataArray, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('数组插入成功')
})
callback()
},

function (callback) {
// 列出所有数据
collect. find({}).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('列出当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 更新单一数据
const whereData = {'name' : '小龙女'}
const updataValue = { $set: { 'sex' : '女' } }
collect.updateOne(whereData, updataValue,
function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + "的数据更新成功")
})
callback()
},

function (callback) {
// 查询指定数据
const querystr = { 'name' : '小龙女' }
collect. find(querystr).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('查看更新后的' + querystr['name'] + '的数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定单一数据
const whereData = { 'name' : '黄蓉' }
collect.deleteOne(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name降序排列
const isort = { name : -1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('降序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定多条数据
const whereData = { 'age' : '24' }
collect.deleteMany(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('年龄为' + whereData['age'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name升序排列
const isort = { name : 1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('升序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定集合
dbo.dropCollection(collName, function(err, delOK) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
if ( delOK !== null ) {
console.log(collName + "集合已删除!")
}
})
callback()
}
])

db.close()
})

4、保存所有文件后,在code/06_database/mongodb目录下执行node useMongodb.js命令,结果如下:

使用mongoose包

  1. 在code/06_database/mongodb目录下执行npm install mongoose命令,将mongoose包安装到当前示例项目中。
  2. 在code/06_database/mongodb目录下执行touch useMongoose.js,创建一个脚本文件,具体如下:
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName
const mongoose = require('mongoose');
const async = require('async')
const Schema = mongoose.Schema
const hrSchema = new Schema({
name : {
type : String,
required: true
},
age : {
type : String,
required: true
},
sex : {
type : String,
required: true
},
items : {
type : String,
required: true
}
})
const hrModel = new mongoose.model('Hrobj', hrSchema)
mongoose.connect(dbPath, {useNewUrlParser: true});
const conn = mongoose.connection
conn.on('error', console.error.bind(console, '连接错误:'))
conn.on('open', console.log.bind(console, '数据库连接成功'))
conn.on('disconnected', console.log.bind(console, '断开数据库连接'))

conn.once('open', function(){
async.series([
function(callback) {
// 插入单条数据
const someone = new hrModel ({
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
})
someone.save(function(err, one){
callback(err, one.name+'的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入一条数据后的结果:' + hrTable)
})
},

function(callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
},
{
name : '阿波罗',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

hrModel.insertMany(dataArray, function(err) {
callback(err, '数组中的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入多条数据后的结果:' + hrTable)
})
},

function(callback) {
hrModel.updateMany({sex:'男'}, {sex:'女'}, function(err, one){
callback(err, '将所有男人改为女人')
})
},

function(callback) {
hrModel.updateOne({name:'阿波罗'}, {sex:'男'}, function(err, one){
callback(err, '将阿波罗的性别改为:男')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.findOne({age:'24'}, function(err, hrTable){
callback(err, '第一个年龄为24的结果:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24数据已被删除')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({}, function(err, hrTable){
callback(err, '所有数据已被删除')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '删除所有数据后的结果:' + hrTable)
})
},

function(callback) {
mongoose.disconnect(function(err){
callback(err, '正在断开连接……')
})
}
], function(err, message) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(message)
})
})

3、保存所有文件后,在code/06_database/mongodb目录下执行node useMongoose.js命令,结果如下:

如果图片重复显示或者内容重复显示影响阅读,请访问:
https://www.cnblogs.com/owlman/p/13588513.html

这部分示例将示范SQLite3、MongoDB这两种不同类型的数据库在 Node.js 中的使用方法。首先,我们要在code目录下执行mkdir 06_database命令来创建用于存放这一组示例的目录。

1. SQLite

SQLite3是一个轻量级的关系型数据库,我们在这里用它来示范 Node.js 对关系型数据库的处理。首先,在code/06_database目录下执行mkdir sqlite命令,并执行以下步骤:

  1. 在code/06_database/sqlite目录下执行npm install sqlite3命令,将sqlite3安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/sqlite目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/sqlite目录下执行touch Sqlite.js,创建一个脚本文件,具体如下:
const fs = require('fs')
const sqlite3 = require('sqlite3').verbose()

class SqliteDB {
constructor(file) {
this.db = new sqlite3.Database(file)
const db_exist = fs.existsSync(file)

if ( !db_exist ) {
console.error('数据库文件创建成功!')
fs.openSync(file, 'w')
}
}

createTable(sql) {
this.db.serialize(function() {
this.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
})
}

insertData(sql, objects) {
this.db.serialize(function() {
const stmt = this.prepare(sql)
for ( let i = 0; i < objects.length; ++i ) {
stmt.run(objects[i])
}

stmt.finalize()
})
}

queryData(sql, callback, message) {
this.db.all(sql, function(err, rows) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}

if( callback ) {
callback(rows, message)
}
})
}

executeSql(sql) {
this.db.run(sql, function(err) {
if( err !== null ) {
return console.error('错误信息:' + err.message)
}
})
}

close() {
this.db.close()
}
}

module.exports = SqliteDB

4、在code/06_database/sqlite目录下执行touch useSqlite.js,创建一个脚本文件,具体如下:

const async = require('async')
const SqliteDB = require('./Sqlite')
const file = "HRDB.db"
const sqliteDB = new SqliteDB(file)

function dataDeal(objects, message) {
console.log(message)
for ( const i = 0; i < objects.length; ++i ) {
console.log(objects[i])
}
}

async.waterfall([
function (callback) {
// 创建表格
const createTableSql = `
create table if not exists HR_TABLE (
name TEXT,
age TEXT,
sex TEXT,
items TEXT
);`
sqliteDB.createTable(createTableSql)
callback()
},

function (callback) {
// 插入数据
const insertTileSql = `
insert into HR_TABLE
(name, age, sex, items)
values(?, ?, ?, ?)`
const arr = [
['凌杰', '24', '男', '看书, 看电影, 旅游'],
['蔓儿', '25', '女', '看书, 看电影, 写作'],
['张语', '32', '女', '看书, 旅游, 绘画']
]
sqliteDB.insertData(insertTileSql, arr)
callback()
},

function (callback) {
// 查询数据
const querySql = 'select * from HR_TABLE'
sqliteDB.queryData(querySql, dataDeal, '初始数据')
callback()
},

function (callback) {
// 更新数据
const updateSql = `update HR_TABLE set age = 37 where name = "凌杰"`
sqliteDB.executeSql(updateSql)
callback()
},

function (callback) {
// 查询更新后的数据
querySql = `select * from HR_TABLE`
sqliteDB.queryData(querySql, dataDeal, '更新后数据')
callback()
},

function (callback) {
sqliteDB.close()
callback()
}
])

5、保存所有文件后,在code/06_database/sqlite目录下执行node useSqlite.js命令,结果如下:

2. MongoDB

MongoDB是非关系型数据库的一个典型代表,我们在这里用它来示范 Node.js 对关系型数据库的处理。在 Node.js 中操作MongoDB数据库有两个扩展包可以选择,下面我们一一来演示。首先,在code/06_database目录下执行mkdir mongodb命令,并执行以下步骤:

使用mongodb包

  1. 在code/06_database/mongodb目录下执行npm install mongodb命令,将mongodb包安装到当前示例项目中。
  2. 为控制程序按串行方式执行,需在code/06_database/mongodb目录下执行npm install async命令,将async包安装到当前示例项目中。
  3. 在code/06_database/mongodb目录下执行touch useMongodb.js,创建一个脚本文件,具体如下:
 const MongoClient = require('mongodb').MongoClient
const async = require('async')
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName

MongoClient.connect(dbPath, { useNewUrlParser: true },
function(err, db) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}

const dbo = db.db(dbName)
console.log(dbName + '数据库创建成功')

const collect = dbo.collection(collName)
console.log(collName + '集合创建成功')

async.series([
// 控制程序串行执行

function (callback) {
// 插入单条数据
const data = {
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
}

collect.insertOne(data, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('单条数据插入成功')
})
callback()
},

function (callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

collect.insertMany(dataArray, function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('数组插入成功')
})
callback()
},

function (callback) {
// 列出所有数据
collect. find({}).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('列出当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 更新单一数据
const whereData = {'name' : '小龙女'}
const updataValue = { $set: { 'sex' : '女' } }
collect.updateOne(whereData, updataValue,
function(err, res) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + "的数据更新成功")
})
callback()
},

function (callback) {
// 查询指定数据
const querystr = { 'name' : '小龙女' }
collect. find(querystr).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('查看更新后的' + querystr['name'] + '的数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定单一数据
const whereData = { 'name' : '黄蓉' }
collect.deleteOne(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(whereData['name'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name降序排列
const isort = { name : -1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('降序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定多条数据
const whereData = { 'age' : '24' }
collect.deleteMany(whereData,function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('年龄为' + whereData['age'] + '的数据已被删除')
})
callback()
},

function (callback) {
// 查询所有数据,并按name升序排列
const isort = { name : 1 }
collect. find({}).sort(isort).toArray(function(err, result) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log('升序排列当前集合中的所有数据:')
console.log(result)
})
callback()
},

function (callback) {
// 删除指定集合
dbo.dropCollection(collName, function(err, delOK) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
if ( delOK !== null ) {
console.log(collName + "集合已删除!")
}
})
callback()
}
])

db.close()
})

4、保存所有文件后,在code/06_database/mongodb目录下执行node useMongodb.js命令,结果如下:

使用mongoose包

  1. 在code/06_database/mongodb目录下执行npm install mongoose命令,将mongoose包安装到当前示例项目中。
  2. 在code/06_database/mongodb目录下执行touch useMongoose.js,创建一个脚本文件,具体如下:
const server = 'mongodb://localhost:27017'
const dbName = 'hrdb'
const collName = 'hr_table'
const dbPath = server + '/' + dbName
const mongoose = require('mongoose');
const async = require('async')
const Schema = mongoose.Schema
const hrSchema = new Schema({
name : {
type : String,
required: true
},
age : {
type : String,
required: true
},
sex : {
type : String,
required: true
},
items : {
type : String,
required: true
}
})
const hrModel = new mongoose.model('Hrobj', hrSchema)
mongoose.connect(dbPath, {useNewUrlParser: true});
const conn = mongoose.connection
conn.on('error', console.error.bind(console, '连接错误:'))
conn.on('open', console.log.bind(console, '数据库连接成功'))
conn.on('disconnected', console.log.bind(console, '断开数据库连接'))

conn.once('open', function(){
async.series([
function(callback) {
// 插入单条数据
const someone = new hrModel ({
name : '杨过',
age : '42',
sex : '男',
items : '看书, 喝酒, 习武'
})
someone.save(function(err, one){
callback(err, one.name+'的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入一条数据后的结果:' + hrTable)
})
},

function(callback) {
// 插入多条数据
const dataArray = [
{
name : '小龙女',
age : '24',
sex : '男',
items : '看书, 唱歌, 习武'
},
{
name : '郭靖',
age : '52',
sex : '男',
items : '看书, 喝酒, 习武'
},
{
name : '黄蓉',
age : '45',
sex : '女',
items : '看书, 绘画, 习武'
},
{
name : '雅典娜',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
},
{
name : '阿波罗',
age : '24',
sex : '女',
items : '看书, 音乐, 被救'
}
]

hrModel.insertMany(dataArray, function(err) {
callback(err, '数组中的数据插入成功')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '插入多条数据后的结果:' + hrTable)
})
},

function(callback) {
hrModel.updateMany({sex:'男'}, {sex:'女'}, function(err, one){
callback(err, '将所有男人改为女人')
})
},

function(callback) {
hrModel.updateOne({name:'阿波罗'}, {sex:'男'}, function(err, one){
callback(err, '将阿波罗的性别改为:男')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.findOne({age:'24'}, function(err, hrTable){
callback(err, '第一个年龄为24的结果:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24数据已被删除')
})
},

function(callback) {
hrModel.find({age:'24'}, function(err, hrTable){
callback(err, '所有年龄为24的数据:' + hrTable)
})
},

function(callback) {
hrModel.deleteMany({}, function(err, hrTable){
callback(err, '所有数据已被删除')
})
},

function(callback) {
hrModel.find(function(err, hrTable){
callback(err, '删除所有数据后的结果:' + hrTable)
})
},

function(callback) {
mongoose.disconnect(function(err){
callback(err, '正在断开连接……')
})
}
], function(err, message) {
if ( err !== null ) {
return console.error('错误信息:' + err.message)
}
console.log(message)
})
})

3、保存所有文件后,在code/06_database/mongodb目录下执行node useMongoose.js命令,结果如下:

相关推荐

2023年最新微信小程序抓包教程(微信小程序 抓包)

声明:本公众号大部分文章来自作者日常学习笔记,部分文章经作者授权及其他公众号白名单转载。未经授权严禁转载。如需转载,请联系开百。请不要利用文章中的相关技术从事非法测试。由此产生的任何不良后果与文...

测试人员必看的软件测试面试文档(软件测试面试怎么说)

前言又到了毕业季,我们将会迎来许多需要面试的小伙伴,在这里呢笔者给从事软件测试的小伙伴准备了一份顶级的面试文档。1、什么是bug?bug由哪些字段(要素)组成?1)将在电脑系统或程序中,隐藏着的...

复活,视频号一键下载,有手就会,长期更新(2023-12-21)

视频号下载的话题,也算是流量密码了。但也是比较麻烦的问题,频频失效不说,使用方法也难以入手。今天,奶酪就来讲讲视频号下载的新方案,更关键的是,它们有手就会有用,最后一个方法万能。实测2023-12-...

新款HTTP代理抓包工具Proxyman(界面美观、功能强大)

不论是普通的前后端开发人员,还是做爬虫、逆向的爬虫工程师和安全逆向工程,必不可少会使用的一种工具就是HTTP抓包工具。说到抓包工具,脱口而出的肯定是浏览器F12开发者调试界面、Charles(青花瓷)...

使用Charles工具对手机进行HTTPS抓包

本次用到的工具:Charles、雷电模拟器。比较常用的抓包工具有fiddler和Charles,今天讲Charles如何对手机端的HTTS包进行抓包。fiddler抓包工具不做讲解,网上有很多fidd...

苹果手机下载 TikTok 旧版本安装包教程

目前苹果手机能在国内免拔卡使用的TikTok版本只有21.1.0版本,而AppStore是高于21.1.0版本,本次教程就是解决如何下载TikTok旧版本安装包。前期准备准备美区...

【0基础学爬虫】爬虫基础之抓包工具的使用

大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...

防止应用调试分析IP被扫描加固实战教程

防止应用调试分析IP被扫描加固实战教程一、概述在当今数字化时代,应用程序的安全性已成为开发者关注的焦点。特别是在应用调试过程中,保护应用的网络安全显得尤为重要。为了防止应用调试过程中IP被扫描和潜在的...

一文了解 Telerik Test Studio 测试神器

1.简介TelerikTestStudio(以下称TestStudio)是一个易于使用的自动化测试工具,可用于Web、WPF应用的界面功能测试,也可以用于API测试,以及负载和性能测试。Te...

HLS实战之Wireshark抓包分析(wireshark抓包总结)

0.引言Wireshark(前称Ethereal)是一个网络封包分析软件。网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。Wireshark使用WinPCAP作为接口,直接...

信息安全之HTTPS协议详解(加密方式、证书原理、中间人攻击 )

HTTPS协议详解(加密方式、证书原理、中间人攻击)HTTPS协议的加密方式有哪些?HTTPS证书的原理是什么?如何防止中间人攻击?一:HTTPS基本介绍:1.HTTPS是什么:HTTPS也是一个...

Fiddler 怎么抓取手机APP:抖音、小程序、小红书数据接口

使用Fiddler抓取移动应用程序(APP)的数据接口需要进行以下步骤:首先,确保手机与计算机连接在同一网络下。在计算机上安装Fiddler工具,并打开它。将手机的代理设置为Fiddler代理。具体方...

python爬虫教程:教你通过 Fiddler 进行手机抓包

今天要说说怎么在我们的手机抓包有时候我们想对请求的数据或者响应的数据进行篡改怎么做呢?我们经常在用的手机手机里面的数据怎么对它抓包呢?那么...接下来就是学习python的正确姿势我们要用到一款强...

Fiddler入门教程全家桶,建议收藏

学习Fiddler工具之前,我们先了解一下Fiddler工具的特点,Fiddler能做什么?如何使用Fidder捕获数据包、修改请求、模拟客户端向服务端发送请求、实施越权的安全性测试等相关知识。本章节...

fiddler如何抓取https请求实现手机抓包(100%成功解决)

一、HTTP协议和HTTPS协议。(1)HTTPS协议=HTTP协议+SSL协议,默认端口:443(2)HTTP协议(HyperTextTransferProtocol):超文本传输协议。默认...