先看看效果吧:

图片保存到服务器为png格式,一般10k左右。

这个功能适用于H5app,或者H5,或者pc网页端(IE9以上,支持canvas),

低端安卓机依然不支持,具体低端到什么程度,没有经过测试。

下边上代码,前端HTML:

<!DOCTYPE html>
<html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /><!--<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">--><!--<meta name="viewport" content="initial-scale=1.0, target-densitydpi=device-dpi" />--><!-- this is for mobile (Android) Chrome --><!--<meta name="viewport" content="initial-scale=1.0, width=device-height">--><!--  mobile Safari, FireFox, Opera Mobile  --><script src="js/libs/modernizr.js"></script><!--[if lt IE 9]><script type="text/javascript" src="libs/flashcanvas.js"></script><![endif]--><style type="text/css">/*div {margin-top: 1em;margin-bottom: 1em;}*/input {padding: .5em;margin: .5em;}select {padding: .5em;margin: .5em;}#signatureparent {color: #000;background-color: #fff;/*max-width:600px;*/padding: 10px;width: 100%;}/*This is the div within which the signature canvas is fitted*/#signature {border: 1px dotted #3eaed2;background-color: #ececec;height: 200px;width: 100%;}/* Drawing the 'gripper' for touch-enabled devices */html.touch #content {float: left;width: 92%;}/*html.touch #scrollgrabber {float: right;width: 4%;margin-right: 2%;background-image: url()}*/html.borderradius #scrollgrabber {border-radius: 1em;}.signature .jSignature{height: 100%;}</style></head><body style="background-color: #fff;"><div id="content" style="width: 100%;"><p>说明:服务器端用的thinkphp,这里只是个控制器,单独使用无效的,如果不知道控制器该放在什么位置,请自行百度。自行拼接请求服务器的完整的网址。</p><p style="padding-left: 10px;margin-top:10px;margin-bottom: 5px;">请在虚线框内签名,完毕后点击“保存”。</p><div id="signatureparent"><div id="signature"></div></div><div style="text-align: center;"><input type="button" name="btnReset" id="btnReset" value="重写" /><input type="submit" class="" name="btnSave" id="btnSave"  value="保存签名" /></div></div><script src="libs/jquery1.10.2.min.js"></script><script type="text/javascript">jQuery.noConflict();</script><script>/*  @preservejQuery pub/sub plugin by Peter Higgins (dante@dojotoolkit.org)Loosely based on Dojo publish/subscribe API, limited in scope. Rewritten blindly.Original is (c) Dojo Foundation 2004-2010. Released under either AFL or new BSD, see:http://dojofoundation.org/license for more information.*/(function($) {var topics = {};$.publish = function(topic, args) {if(topics[topic]) {var currentTopic = topics[topic],args = args || {};for(var i = 0, j = currentTopic.length; i < j; i++) {currentTopic[i].call($, args);}}};$.subscribe = function(topic, callback) {if(!topics[topic]) {topics[topic] = [];}topics[topic].push(callback);return {"topic": topic,"callback": callback};};$.unsubscribe = function(handle) {var topic = handle.topic;if(topics[topic]) {var currentTopic = topics[topic];for(var i = 0, j = currentTopic.length; i < j; i++) {if(currentTopic[i] === handle.callback) {currentTopic.splice(i, 1);}}}};})(jQuery);</script><script src="libs/jSignature.min.noconflict.js"></script><script>(function($) {$(document).ready(function() {// This is the part where jSignature is initialized.var $sigdiv = $("#signature").jSignature({'UndoButton': false}),// All the code below is just code driving the demo. $tools = $('#tools'),$extraarea = $('#displayarea'),pubsubprefix = 'jSignature.demo.'var export_plugins = $sigdiv.jSignature('listPlugins', 'export');$("#btnSave").on("click",function(){//可选格式:native,image,base30,image/jsignature;base30,svg,image/svg+xml,svgbase64,image/svg+xml;base64var basedata = "data:"+$sigdiv.jSignature('getData', "image");
//                      console.log("basedata:"+basedata);
//                      $(".signResult").html(data);//server是我自定义的,值为http://www.abc.com/index.php?g=user&m=jk//这样就能拼接完整的请求路径了。var weburl=server+"&a=make_sign";var jsdata={imgbase:basedata};$.ajax({type:"post",url:weburl,async:true,data:jsdata,dataType:"json",success:function(data){console.log(JSON.stringify(data));if(data.success){console.log(data.msg);}else{console.log(data.msg);}}});
//                      if(data.length<100){//本来这里想判断是否为空的,发现什么都不写时,竟然也有数据,应该是底板的编码了
//                          mui.toast("请重新签名");
//                      }});$("#btnReset").on("click",function(){$sigdiv.jSignature('reset');});})})(jQuery)</script></body></html>

服务端使用thinkphp:

<?php
namespace User\Controller;
use Common\Controller\HomebaseController;
class JkController extends HomebaseController {function make_sign(){$host=$_SERVER['HTTP_HOST'];//系统域名$base64=I("imgbase");$result=$this->base64_upload($base64);if($result!==false){$signUrl=$host.$result;$rtn='{"success":true,"msg":"保存成功","signurl":"http://'.$signUrl.'"}';}else{$rtn='{"success":false,"msg":"签名保存失败"}';}echo $rtn;}//保存base64为图片function base64_upload($base64) {$base64_image = str_replace(' ', '+', $base64);//post的数据里面,加号会被替换为空格,需要重新替换回来,如果不是post的数据,则注释掉这一行//上一行是注释好像没有意义,测试后发现,post来的数据,并没有把+替换为空格if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image, $result)){//匹配成功if($result[2] == 'jpeg'){$image_name = uniqid().'.jpg';//纯粹是看jpeg不爽才替换的}else{$image_name = uniqid().'.'.$result[2];}$img_url="/Uploads/".date("Ymd")."/";//目录要有可写权限,一般给user全部权限就行了。if(!is_dir("./".$img_url)){mkdir("./".$img_url);}$image_file = $img_url.$image_name;//服务器文件存储路径//  ./这才是指向根目录的if (file_put_contents(".".$image_file, base64_decode(str_replace($result[1], '', $base64_image)))){return $image_file;}else{return false;}}else{return false;}}
}

这是控制器,具体位置不用细说了吧。

注意:demo里,有个地方需要修改,就是控制器的33和34行,路径前面要加上./,这样才能指向根目录。

修改后如下:

if(!is_dir("./".$img_url)){mkdir("./".$img_url);
}

完整的demo下载路径:https://download.csdn.net/download/moniteryao/10639108

js插件来源:http://www.jq22.com/jquery-info13488

服务器接收base64另存为图片借鉴:https://www.cnblogs.com/hopelooking/p/6277419.html

H5手写签名,适用于手机网页、电脑网页(IE9+)相关推荐

  1. H5手写签名canvas(附源码)

    效果图: 图片保存到服务器为png格式,一般10k左右. 这个功能适用于H5app,或者H5,或者pc网页端(IE9以上,支持canvas), 低端安卓机依然不支持,具体低端到什么程度,没有经过测试. ...

  2. 在钉钉上怎么手写_数码知识:钉钉手写签名如何设置开启手写签名教程

    如今使用IT数码设备的小伙伴们是越来越多了,那么IT数码设备当中是有很多小技巧的,这些技巧很多小伙伴一般都是不知道如何来实用的,就好比最近就有很多小伙伴们想要知道钉钉手写签名如何设置开启手写签名教程, ...

  3. vue3+h5实现手写签名

    接上 还是同一个后台 还是同一个h5页面- 先看效果 点击签字 跳转路由 canvas页面主要实现手写签名部分 <template><div class="canvasPa ...

  4. 手写签名(H5\小程序)

    做个笔记! 手写签名主要是用canvas实现.通过监听手指触碰屏幕事件来完成(touchstart.touchmove.touchcancel) H5: 这里是用的vue封装一个手写签名的组件 htm ...

  5. 每天bug---用canvas实现手写签名出现轨迹错乱(重要的是苹果手机和安卓手机错乱不一致!)

    Canvas可以用来实现手写签名的功能,但在苹果手机上,可能会因为触摸屏幕采样率的问题导致轨迹不一致.下面是一些可能有用的解决方法: 使用更高的Canvas分辨率.增加Canvas的分辨率可以提高触摸 ...

  6. html5 移动端手写签名,H5移动端项目实现手写签名功能 vue实现手写签名

    vue 移动端实现手写签名效果,功能很完美,保存时保存为base64格式. 刚好项目用到此功能,就网上找了一下,清理了无用代码,简单方便,因为项目中多个地方需要使用,所以我将它整理为组件,通过ref和 ...

  7. 手机之家在线签名_手写签名在线生成器在线-手写签名在线生成器在线

    签名设计地址:www.mgs2s.com(复制到浏览器打开)工具集成签名设计免费版下载,签名设计免费版在线立即生成,简单简体签名设计免费版.最新方便设计公文签名设计颜色保存分享免费版 1.真笔网推出的 ...

  8. H5移动端项目实现手写签名功能 vue实现手写签名

    vue 移动端实现手写签名效果,功能很完美,保存时保存为base64格式. base64转file文件格式 vue中将base64转file文件格式 刚好项目用到此功能,就网上找了一下,清理了无用代码 ...

  9. html 手写签名 撤销,[转]H5 canvas手写签名

    手写签名 html,body{ margin: 0; padding: 0; } .saveimg{ text-align: center; } .saveimgs span{ display: in ...

  10. Android 电子签名,手写签名案列实现方法,并上传网页显示(base64)!

    最近说项目可能会用到一个电子签名,不需要识别的那种,只是一个单纯手写签名,然后以base64的格式提供给前端web页面.其实挺简单的,自定义一个手写view就上线了.Android 电子签名,手写签名 ...

最新文章

  1. 聚集索引与非聚集索引的总结
  2. PHP中常用的正则表达式函数
  3. PHP会话管理——Session和Cookie
  4. jsp导出数据时离开页面_您应该在要离开的公司开始使用数据
  5. pytorch保存和加载模型state_dict
  6. 蓝桥杯 - 历届试题 - 日期问题
  7. Python __subclasses__() 函数获取类的所有子类
  8. 删除mysql主键语句_MySQL主键添加/删除
  9. 孙杨事件的几点事实!
  10. CMU 11611 -NLP
  11. python段落注释的语法格式是_Python 基础语法
  12. MySQL性能优化[实践篇]-复合索引实例
  13. 二元函数连续性、可导性及极限
  14. spring三级缓存
  15. 3.shell脚本的基础知识
  16. 软件测试设计之——场景设计法,判定表法
  17. 黑鲨手机计算机科学技术器,黑鲨4Pro将PC的SSD存储科技带到手机端,真技术革命还假营销噱头?...
  18. 使用php-rdkafka错误总结: version `GLIBC_2.14‘ not found; rdkafka.so: undefined symbol: zend_object_alloc
  19. 慢慢的长大,慢慢的成长
  20. 免费的在线白板协作工具有哪些?

热门文章

  1. 多元相关分析与回归分析(转)
  2. 平衡二叉树(C++实现)
  3. 通过图书编号查询python,基于Python的ISBN书号查询示例代码-六派数据
  4. 两种方法模仿支付宝进入到后台界面模糊
  5. 误差反向传播(手把手教你推导如何通过反向传播更新参数)
  6. ubuntu 删除opencv4_ubuntu彻底卸载opencv
  7. 基于Python网络爬虫的小说网站数据分析
  8. PubYun动态域名
  9. VB语言和C语言有什么区别
  10. java excel换行_java poi出excel换行问题