node图片处理工具gm的使用:图片水印、图片验证码、图片裁剪示例

2024-06-10 04:48

本文主要是介绍node图片处理工具gm的使用:图片水印、图片验证码、图片裁剪示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

请在这里查看示例 gm示例

安装

GraphicsMagick和ImageMagick的区别

  • GraphicsMagick是从ImageMagick中分离出来的,推荐下载ImageMagick
  • 加载GraphicsMagick(大小4.72 MB)
    var gm = require('gm')

  • 加载ImageMagick(大小23.8 MB)
    var gm = require('gm').subClass({imageMagick: true})// 注意使用的区别

  • 除了加载有区别,其他使用方式完全一样

window版本

  • 下载imagemagick的window版本(在页面靠下方),如图:
    这里写图片描述
  • 双击exe文件,进行安装,安装过程中要注意勾选以下选项
    这里写图片描述

linux版本(ubuntu 16.04)

  • ubuntu 安装imagemagick

要点

图片水印

var gm = require('gm').subClass({imageMagick: true})gm('./public/images/a.png')// 原图路径
.font('./fonts/zhulangyingxingti.ttf')// 配置逐浪硬行体字库路径
.drawText(10, 10, '水印')
.write('./public/images/b.png', function (e) {// 输出的图片路径if(e) {console.log(e.message)}else {console.log('done')}
})

drawText()中文乱码

  • 字体文件使用中文名称命名,运行时会报错,所以不要使用中文命名
    这里写图片描述
  • 如果确保字库引入正确,还出现中文乱码,那一定是字库文件本身有问题,换一种字库就可以了
  • 尝试过字库格式ttf、otf均支持
    详见:
    字库ttf和otf格式有什么区别?

图片验证码

  • 准备一张背景杂乱的图片和艺术字体的英文字库
    这里写图片描述
  • index.html

    <img src="/gm/captchaAdd"><!-- 前端通过img标签请求验证码 -->
  • app.js

    var express = require('express')
    var session = require('express-session')
    ...var cap = {// 通过函数随机出一个验证码对象,包括文字和在杂乱背景上的位置(这里假如如下)text: 'ab12',pos: [20, 50],
    }// 生成验证码
    app.all('/gm/captchaAdd', function(req, res, next) {var url = './public/images/'+(''+Math.cap()).replace('.', '')+'.png'// 设置验证码的输出路径,且给一个随机文件名gm('./lib/images/captchaBg.png')// 一张背景杂乱的图片作为验证码的背景.font('./lib/src/SelfRighteousness-Regular.ttf')// 一种略艺术的英文字库.fontSize(50)// 设置字体大小.drawText(cap.pos[0], cap.pos[1], cap.text)// 写入随机的验证码.crop(100, 40, cap.pos[0], cap.pos[1])// 将相应的文字部分裁剪出来,作为验证码.noise(1// 加入噪点.write(url, function (e) {// 随机一个文件名,并输出验证码if(e) {console.log(e.message)}else {req.session.captcha = cap// 将验证码对象写入session,用来登录时跟用户输入的作比较res.download(url)// 这里用download方法发送图片,前端千万不能用ajax方式请求}})
    })// 用户登录
    app.all('/user/login', function(req, res, next) {if(req.body.captcha.toLocaleLowerCase() != req.session.captcha.text.toLocaleLowerCase()) {res.send({message: '验证码不正确'})}else {...}
    })
  • 效果如下
    1. 这里写图片描述 2. 这里写图片描述 3. 这里写图片描述
  • 最后可以通过AI开放平台提供的文字识别技术来测试机器识别的效果
  • 升级版验证码(参考慕课网)
    • 用户使用某个用户名尝试登陆,如果错误,将给该用户名在数据库记录一次错误
    • 该用户名错误次数达到3次,要求需等待半小时后才能再次尝试登录该用户名,且必须输入验证码
    • 所以当用户来到登录页面时,在输入用户名之后(或从cookie拿到记录的用户名),需要发送一个请求去验证此用户名是否需要输入验证码,如需要,将验证码输入框显示出来
    • 这个有个问题就是,其他用户可以通过故意错误的登录某些用户名,来使这些用户名永远处于等半小时的状态,导致永远无法登陆(不过为了用户安全,牺牲一点用户体验也是值得的)

详见:
使用session实现一次性验证码

头像裁剪

  • 下面我给出4种方式的思路
  • 方式1(本篇提供的demo即使用此方法)
    • 前端使用上传插件Webuploader来提供上传图片的功能
    • 前端使用Jcrop来提供裁剪的位置
    • 后端使用gm根据给出的裁剪位置对上传的图片进行裁剪
  • 方式2(可以借助jquery-plugins/h5Crop/插件,该插件我会继续完成)
    • 前端利用canvas实现裁剪和压缩,将处理后的base64传给后端
    • 后端将base64转化成图片,返回给前端进行展示
  • 方式3
    • 前端把图片传给后端
    • 后端压缩处理过之后,返回给前端(附带图片唯一标识)
    • 前端使用Jcrop获取图片的裁剪位置,将裁剪位置和图片唯一标识传给后端
    • 后端对对应的图片进行裁剪
  • 方式4(这个需要借助我的另一个裁剪插件,提供了2种方式进行裁剪,效果跟qq裁剪头像一样,以后会开源)
    • 前端裁剪
      • 前端通过js对图片进行平移、缩放操作
      • 再通过canvas的drawImage方法绘制操作后的图片
      • 再通过canvas的toDataURL进行压缩同时获取最终的base64
      • 传base64到后端,后端转为图片,返回图片路径,前端进行展示
    • 后端裁剪
      • 前端通过js对图片进行平移、缩放操作
      • 将操作后获取的裁剪参数(裁剪框的大小、缩放的比率、压缩的比率)和图片文件一同传给后端
      • 后端对上传的文件进行裁剪,返回图片路径,前端进行展示
    • 需使用到的ImageMagick小细节
      • 读取本地图片资源gm('upload\\temp\\crop\\20180601\\49076530-6584-11e8-9542-0d60dcc7daa8.jpg'))
      • 读取外链图片资源gm('http://localhost:3000/upload/temp/crop/20180601/49076530-6584-11e8-9542-0d60dcc7daa8.jpg'))
      • 读取base64图片资源'inline:' + 'data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wBD...')(注意不适用超过5000个字符的base64字符串,否则会转换失败)
      • 为了解决base64过长时ImageMagick处理会失败,我们使用node来转换base64为图片
      • 缩放图片传入百分比gm('xxx.png').resize('50%'))
      • 压缩图片传入值gm('xxx.png').quality(50))
      • 不管是前端canvas压缩还是后端ImageMagick压缩,最后的输出的格式都要是jpeg或jpg,否则压缩后的大小很可能会变大
    • 效果展示(动图较大,请耐心等待)
      这里写图片描述
  • 优缺点对比
    • 方式1:后端只要写1个接口(Webuploader对图片可以进行压缩)
    • 方式2:兼容性IE>=10,减少后端工作量
    • 方式3:适中,后端需要写2个接口(上传图片接口和裁剪图片接口)
    • 方式4:编写复杂,但是扩展性好,可自由选择一种方式

参考

gm官方文档
nodejs图片处理工具gm用法
nodejs gm drawText使用(中文、字体、大小及颜色)
ImageMagick常用操作

这篇关于node图片处理工具gm的使用:图片水印、图片验证码、图片裁剪示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1047254

相关文章

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、