Maison cadre php PensezPHP ThinkPhp5.1 + jSignature implémente la fonction de signature en ligne

ThinkPhp5.1 + jSignature implémente la fonction de signature en ligne

Feb 15, 2022 pm 05:22 PM
thinkphp5.1

La signature en ligne est utilisée dans de nombreux endroits. L'éditeur a récemment lancé un projet impliquant la fonction de signature d'approbation. Le client a demandé que la fonction de signature en temps réel sur le téléphone mobile soit implémentée. Après recherche, la bibliothèque jSignature a été utilisée. pour compléter cette fonction. Partagez-la pour la référence de tous.

Puisque vous utilisez la bibliothèque jSignature pour créer des signatures, vous devez bien sûr télécharger la bibliothèque jSignature. L'éditeur fournit l'adresse de téléchargement comme suit. Les amis peuvent télécharger :

https://www.phpclasses.org/. Browse/file/42277 .html

J'ai la bibliothèque jSignature. Comment l'utiliser ? De nombreux amis peuvent être bloqués dans cette zone. De même, l'éditeur vous fournit de la documentation :

jsignature. Manuel de développement chinois

De plus, jsignature doit être utilisé avec la bibliothèque jQuery, sinon certaines fonctions ne peuvent pas être affichées. L'adresse de téléchargement est également fournie pour que tout le monde puisse la télécharger :

lienTéléchargement de jQuery

Bien sûr, il existe de nombreuses versions de jQuery. Celle que j'utilise est jquery-3.2.1.js

La fonction de préparation préliminaire est prête et la méthode de production est fournie ci-dessous.

Le front-end HTMLre

<style>
    .main_sign{
        padding: 10px 10px;
        color:black;
        background-color:darkgrey;
    }
    .main_sign .sign_btn{
        padding: 5px 10px;
    }
    #signature {
        border: 2px dotted black;

    }
</style>
<div class="main_sign" id="writers">
    <div id=&#39;signature&#39; style=&#39;background-color: #d2d2e8;&#39;></div>
    <button type="button" class="sign_btn" id="reset" style="margin: 10px 5px;">重写</button>
    <button type="button" class="sign_btn" id="yes" style="margin: 10px 5px;">确认</button>
    <div id="show_img" style="display: none;"><img src="" id="images"></div>
</div>
Copier après la connexion
E1 a instancié JSIGNATURE

$(document).ready(function(){
    var arguments = {
        width: &#39;100%&#39;,
        height: &#39;200px&#39;,
    };
    $("#signature").jSignature(arguments);
});
Copier après la connexion
E2 réinitialise la signature

$("#reset").click(function(){
    $("#signature").jSignature("reset"); //重置画布,可以进行重新作画
    $("#images").attr(&#39;src&#39;,&#39;&#39;);
});
Copier après la connexion
3 Soumettez la signature

Xiaobian utilise TP5.1 + AJAX soumis [Recommandation associée
thinkphp tutoriel vidéo

//点击确定按钮,把签名的转成图片,然后把数据放进图片中,最后把图片中的数据传到后台
$("#yes").click(function(){
    //将画布内容转换为图片
    var $signature = $("#signature");
    var datapair = $signature.jSignature("getData", "image");
    $("#images").attr(&#39;src&#39;,&#39;data:&#39; + datapair[0] + "," + datapair[1]);
    var src_data = $("#images").attr(&#39;src&#39;);//拿到图片中的src,这就是我们需要的base64
    //console.info(src_data);//显示生成的笔迹图片
    //在这里就写我们的后台操作
    $.ajax({
        url:"{:url(&#39;getSignInfo&#39;)}",
        data:{src_data:src_data},
        type:"post",
        dataType:"json",
        success:function(data){
            window.location.href = data.dump_url;
        },
        error:function(){
            console.log("错误");
        }
    });
});
Copier après la connexion
4 Réception des données d'arrière-plan (getSignInfo.php)

$data = Request::param();
$src = $this->base64ContentToImage($data[&#39;src_data&#39;],$path);
Copier après la connexion
$src est l'adresse de sauvegarde de l'image de signature dont nous avons besoin, $path est le chemin de sauvegarde de l'image de signature


5 Base64 l'image Le code est converti en image standard (méthode base64ContentToImage)

public function base64ContentToImage($base64_image_content,$path){
    $dir = "./".$path;
    if(!file_exists($dir)){
        mkdir(iconv("GBK", "UTF-8", $dir),0777,true);
    }
    //匹配出图片的格式
    if (preg_match(&#39;/^(data:\s*image\/(\w+);base64,)/&#39;, $base64_image_content, $result)){
        $type = $result[2];
        $new_file = $path."/".date(&#39;Ymd&#39;,time())."/";
        if(!file_exists($new_file)){
            //检查是否有该文件夹,如果没有就创建,并给予最高权限
            mkdir($new_file, 0700);
        }
        $new_file = $new_file.time().".{$type}";
        if (file_put_contents($new_file, base64_decode(str_replace($result[1], &#39;&#39;, $base64_image_content)))){
            return &#39;/&#39;.$new_file;
        }else{
            return false;
        }
    }else{
        return false;
    }
}
Copier après la connexion
Ce qui précède est la méthode de production complète utilisant la bibliothèque TP5.1 + jSignature pour générer des signatures résumée par l'éditeur. J'espère que cela sera utile à tout le monde, merci !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment puis-je utiliser ThinkPHP pour créer des applications de ligne de commande? Comment puis-je utiliser ThinkPHP pour créer des applications de ligne de commande? Mar 12, 2025 pm 05:48 PM

Cet article montre la création d'applications de ligne de commande (CLI) en utilisant les capacités CLI de ThinkPhp. Il met l'accent sur les meilleures pratiques telles que la conception modulaire, l'injection de dépendance et la gestion des erreurs robuste, tout en mettant en évidence les pièges communs tels que INSU

Quelles sont les principales considérations pour utiliser ThinkPhp dans une architecture sans serveur? Quelles sont les principales considérations pour utiliser ThinkPhp dans une architecture sans serveur? Mar 18, 2025 pm 04:54 PM

L'article traite des considérations clés pour l'utilisation de ThinkPHP dans des architectures sans serveur, en se concentrant sur l'optimisation des performances, la conception sans état et la sécurité. Il met en évidence des avantages tels que la rentabilité et l'évolutivité, mais relève également des défis

Quelles sont les caractéristiques avancées du conteneur d'injection de dépendance de ThinkPhp? Quelles sont les caractéristiques avancées du conteneur d'injection de dépendance de ThinkPhp? Mar 18, 2025 pm 04:50 PM

Le conteneur IOC de ThinkPhp propose des fonctionnalités avancées comme le chargement paresseux, la liaison contextuelle et l'injection de méthode pour une gestion efficace des dépendances dans les applications PHP. COMMANDE CHARACTER: 159

Comment puis-je prévenir les vulnérabilités d'injection SQL dans ThinkPhp? Comment puis-je prévenir les vulnérabilités d'injection SQL dans ThinkPhp? Mar 14, 2025 pm 01:18 PM

L'article discute de la prévention des vulnérabilités d'injection SQL dans ThinkPhP à travers des requêtes paramétrées, en évitant le SQL brut, en utilisant ORM, des mises à jour régulières et une bonne gestion des erreurs. Il couvre également les meilleures pratiques pour sécuriser les requêtes de base de données et le validat

Comment construire un système de file d'attente de tâches distribué avec ThinkPhp et RabbitMQ? Comment construire un système de file d'attente de tâches distribué avec ThinkPhp et RabbitMQ? Mar 18, 2025 pm 04:45 PM

L'article décrit la création d'un système de file d'attente de tâches distribué à l'aide de ThinkPhp et RabbitMQ, en se concentrant sur l'installation, la configuration, la gestion des tâches et l'évolutivité. Les problèmes clés incluent assurer la haute disponibilité, éviter les pièges communs comme Imprope

Quelles sont les principales caractéristiques du cadre de test intégré de ThinkPHP? Quelles sont les principales caractéristiques du cadre de test intégré de ThinkPHP? Mar 18, 2025 pm 05:01 PM

L'article traite du cadre de test intégré de ThinkPhP, mettant en évidence ses principales fonctionnalités telles que les tests d'unité et d'intégration, et comment il améliore la fiabilité des applications grâce à la détection précoce des bogues et à une meilleure qualité de code.

Quelles sont les principales différences entre ThinkPhp 5 et ThinkPhp 6, et quand utiliser chacun? Quelles sont les principales différences entre ThinkPhp 5 et ThinkPhp 6, et quand utiliser chacun? Mar 14, 2025 pm 01:30 PM

L'article traite des différences clés entre ThinkPHP 5 et 6, en se concentrant sur l'architecture, les fonctionnalités, les performances et l'adéquation pour les mises à niveau héritées. ThinkPhp 5 est recommandé pour les projets traditionnels et les systèmes hérités, tandis que ThinkPhp 6 convient au nouveau PR

Comment implémenter la découverte de services et l'équilibrage de chargement dans les microservices ThinkPHP? Comment implémenter la découverte de services et l'équilibrage de chargement dans les microservices ThinkPHP? Mar 18, 2025 pm 04:51 PM

L'article discute de la mise en œuvre de la découverte de services et de l'équilibrage des charges dans les microservices ThinkPHP, en se concentrant sur la configuration, les meilleures pratiques, les méthodes d'intégration et les outils recommandés. [159 caractères]

See all articles