密码术是将纯文本转换为不可读的,经过哈希处理的过程从文字反之亦然crypto.sign()用于创建数据签名。
用法:
crypto.sign(algorithm, data, key)
参数:该函数接受以下参数:
- algorithm:它是一个string-type值。可以通过应用签名算法的名称(例如“ SHA256”)代替摘要算法来创建签名。
- data:它应该是buffer,TypedArray或DataView的对象。读取Buffer.from()方法以将字符串转换为Buffer。
- key:它应该是keyObject的privateKey。如果没有任何私钥,则可以使用crypto.generateKeyPairSync()方法创建私钥和公钥。
模块安装:使用以下命令安装所需的模块:
npm install crypto
返回值:它根据指定的算法,数据和 key 返回签名值。返回值默认为Buffer,但可以使用buffer.toString()方法转换为其他格式。
范例1:在字符串上签名。
signature.js
const crypto = require('crypto');
const buffer = require('buffer');
// Create a private key
const { privateKey, publicKey } = crypto.generateKeyPairSync('rsa', {
modulusLength:2048,
});
// Convert string to buffer
const data = Buffer.from("I Love GeeksForGeeks");
// Sign the data and returned signature in buffer
const sign = crypto.sign("SHA256", data , privateKey);
// Convert returned buffer to base64
const signature = sign.toString('base64');
// Printing the signature
console.log(`Signature:\n\n ${signature}`);
使用以下命令运行signature.js文件:
node signature.js
输出:
范例2:签名文件。
signature.js
const crypto = require('crypto');
const buffer = require('buffer');
const fs = require('fs');
// Create a private key
const { privateKey } = crypto.generateKeyPairSync('rsa', {
modulusLength:2048,
});
console.log("Reading File...\n");
// Reading file
const text = fs.readFileSync('./doc.txt');
console.log(`File content:${text}`);
// Convert string to buffer
const data = Buffer.from(text);
// Sign the data and returned signature in buffer
const sign = crypto.sign("SHA256", data , privateKey);
// Convert returned buffer to base64
const signature = sign.toString('base64');
// Printing the signature
console.log(`Signature:\n\n ${signature}`);
使用以下命令运行signature.js文件:
node signature.js
输出:
范例3:签署JSON数据。
signature.js
const crypto = require('crypto');
const buffer = require('buffer');
// Create a private key
const { privateKey } = crypto.generateKeyPairSync('rsa', {
modulusLength:2048,
});
// JSON object
const person = {
name:"Raktim Banerjee",
email:"example@gmail.com",
address:"4 main street"
}
// Convert Stringified json data to buffer
const data = Buffer.from( JSON.stringify(person) );
// Sign the data and returned signature in buffer
const sign = crypto.sign("SHA256", data , privateKey);
// Convert returned buffer to base64
const signature = sign.toString('base64');
// Printing the signature
console.log(`Signature:\n\n ${signature}`);
使用以下命令运行signature.js文件:
node signature.js
输出:
参考:https://nodejs.org/api/crypto.html#crypto_crypto_sign_algorithm_data_key_callback
相关用法
- Node.js GM charcoal()用法及代码示例
- Node.js GM blur()用法及代码示例
- Node.js GM sharpen()用法及代码示例
- Node.js GM drawLine()用法及代码示例
- Node.js GM drawArc()用法及代码示例
- Node.js GM drawPolyline()用法及代码示例
- Node.js GM drawBezier()用法及代码示例
- Node.js GM drawCircle()用法及代码示例
- Node.js GM drawEllipse()用法及代码示例
- Node.js GM drawPolygon()用法及代码示例
- Node.js GM drawRectangle()用法及代码示例
- Node.js GM paint()用法及代码示例
- Node.js GM orderedDither()用法及代码示例
- Node.js GM roll()用法及代码示例
- Node.js GM segment()用法及代码示例
- Node.js GM quality()用法及代码示例
- Node.js GM raise()用法及代码示例
- Node.js GM resize()用法及代码示例
- Node.js GM transparent()用法及代码示例
- Node.js GM thumbnail()用法及代码示例
- Node.js GM threshold()用法及代码示例
- Node.js GM whitePoint()用法及代码示例
- Node.js GM whiteThreshold()用法及代码示例
注:本文由纯净天空筛选整理自braktim99大神的英文原创作品 Node.js crypto.sign() Function。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。