HTML5中如何实现网页水印SDK
发表于:2022-08-12 作者:安全数据网编辑
编辑最后更新 2022年08月12日,这篇文章将为大家详细讲解有关HTML5中如何实现网页水印SDK,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。网页水印SDK,实现思路1.能更具获取到的当前用户信息,
这篇文章将为大家详细讲解有关HTML5中如何实现网页水印SDK,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
网页水印SDK,实现思路
1.能更具获取到的当前用户信息,如名字,昵称,ID等,生成水印
2.生成一个Canvas,覆盖整个窗口,并且不影响其他元素
3.可以修改字体间距,大小,颜色
4.不依赖Jquery
5.需要防止用户手动删除这个Canvas
实现分析
初始参数
size: 字体大小color: 字体颜色id: canvasIdtext: 文本内容density: 间距clarity: 清晰度supportTip: Canvas不支持的文字提示
生成Canvas
根据id生成Canvas,画布大小为window.screen大小,若存在原有老的Canvas,清除并重新生成。
画布固定定位在可视窗口,z-index为-1
let body = document.getElementsByTagName('body'); let canvas = document.createElement('canvas'); canvas.style.cssText= 'position: fixed;width: 100%;height: 100%;left:0;top:0;z-index: -1;'; body[0].appendChild(canvas);
指纹生成算法
let canvas = document.getElementById(this.params.id); let cxt = canvas.getContext('2d'); let times = window.screen.width * this.params.clarity / this.params.density;//横向文字填充次数 let heightTimes = window.screen.height * this.params.clarity * 1.5/ this.params.density; //纵向文字填充次数 cxt.rotate(-15*Math.PI/180); //倾斜画布 for(let i = 0; i < times; i++) { for(let j = 0; j < heightTimes; j++) { cxt.fillStyle = this.params.color; cxt.font = this.params.size + ' Arial'; cxt.fillText(this.params.text, this.params.density*i, j*this.params.density); } }
防止用户删除
使用定时器,定时检查指纹是否存在
let self = this; window.setInterval(function(){ if (!document.getElementById(self.params.id)) { self._init(); } }, 1000);
项目编译
使用glup编译
var gulp = require('gulp'), uglify = require("gulp-uglify"), babel = require("gulp-babel"); gulp.task('minify', function () { return gulp.src('./src/index.js') // 要压缩的js文件 .pipe(babel()) .pipe(uglify()) .pipe(gulp.dest('./dist')); //压缩后的路径 });
指纹效果
关于"HTML5中如何实现网页水印SDK"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
c语言网络技术和编程语言总结
c语言对应的三级考试网络技术
网站服务器后台如何加防护密码
c语言软件开发步骤
c语言中网络技术知识点
服务器对权限提升的防护措施
怎么在阿里云租服务器
黑苹果能做web服务器吗
c语言和网络技术哪个好考
云服务器2核4G是什么性能
常州软件开发公司
网络技术数据库技术信息安全
管理工具里没有服务器管理器
网络技术跟软件开发哪个简单
源恩access数据库教程
软件开发设计工程师薪资
app软件开发硬件环境
添加图片在数据库
淘宝服务器租用安全吗
贵州六台家庭教育与网络安全
幻塔可以换服务器么
网络安全生活存在的不安全
成都传固奇软件开发工作室
大逃杀国内服务器
linux查看服务器规格命令
越南软件开发技术
数据库表主键id自增长
怎么通过互联网访问数据库
服务器部署方案 图
深圳鸿创网络技术
区块链需要服务器
软件开发项目思想
金蚂蚁软件开发
从另一个表格中引用数据库
ef从数据库生成实体类
linux查看服务器规格命令
vb连接数据库写注册功能
怎么看域管理服务器的名称
乡镇网络安全责任制实施办法
scum荒野求生多人联机服务器