Heim PHP-Framework Denken Sie an PHP ThinkPhp5.1 + jSignature implementiert die Online-Signaturfunktion

ThinkPhp5.1 + jSignature implementiert die Online-Signaturfunktion

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

Online-Signaturen werden an vielen Stellen verwendet. Der Herausgeber hat kürzlich ein Projekt übernommen, bei dem die Funktion der Genehmigungssignatur auf dem Mobiltelefon implementiert werden muss um diese Funktion abzuschließen, teilen Sie sie als Referenz für alle.

Da Sie die jSignature-Bibliothek zum Erstellen von Signaturen verwenden, müssen Sie die jSignature-Bibliothek natürlich wie folgt herunterladen. Freunde können sie herunterladen:

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

Ich habe die jSignature-Bibliothek erhalten. Viele Freunde stecken möglicherweise in diesem Bereich fest. Sie können es sich ansehen:

jsignature Chinesisches Entwicklungshandbuch

Darüber hinaus muss jsignature mit der jQuery-Bibliothek verwendet werden, da sonst einige Funktionen nicht angezeigt werden können. Die Download-Adresse steht auch jedem zum Herunterladen zur Verfügung:

LinkJQuery herunterladen

Natürlich, Es gibt viele Versionen von jQuery. Die von mir verwendete ist jquery-3.2.1.js

Die vorläufige Vorbereitungsfunktion ist fertig und die Produktionsmethode wird unten bereitgestellt.

Das Frontend 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>
Nach dem Login kopieren
E1 instanziierte JSIGNATURE

$(document).ready(function(){
    var arguments = {
        width: &#39;100%&#39;,
        height: &#39;200px&#39;,
    };
    $("#signature").jSignature(arguments);
});
Nach dem Login kopieren
E2 setzte die Signatur zurück

$("#reset").click(function(){
    $("#signature").jSignature("reset"); //重置画布,可以进行重新作画
    $("#images").attr(&#39;src&#39;,&#39;&#39;);
});
Nach dem Login kopieren
3 übermittelte die Signatur

Xiaobian verwendet TP5.1 + AJAX-Übermittlung [Verwandte Empfehlung:
Thinkphp-Video-Tutorial

//点击确定按钮,把签名的转成图片,然后把数据放进图片中,最后把图片中的数据传到后台
$("#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("错误");
        }
    });
});
Nach dem Login kopieren
4 Hintergrunddatenempfang (getSignInfo.php)

$data = Request::param();
$src = $this->base64ContentToImage($data[&#39;src_data&#39;],$path);
Nach dem Login kopieren
$src ist die Speicheradresse des Signaturbildes, die wir benötigen, $path ist der Speicherpfad des Signaturbildes


5 Base64 das Bild Der Code ist in ein Standardbild konvertiert (base64ContentToImage-Methode)

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;
    }
}
Nach dem Login kopieren
Das Obige ist die vollständige Produktionsmethode zur Verwendung der TP5.1 + jSignature-Bibliothek zum Generieren von Signaturen, zusammengefasst vom Editor. Ich hoffe, es wird für alle hilfreich sein.

Das obige ist der detaillierte Inhalt vonThinkPhp5.1 + jSignature implementiert die Online-Signaturfunktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie kann ich ThinkPhp verwenden, um Befehlszeilenanwendungen zu erstellen? Wie kann ich ThinkPhp verwenden, um Befehlszeilenanwendungen zu erstellen? Mar 12, 2025 pm 05:48 PM

Dieser Artikel zeigt, dass die Befehlszeilenanwendungen (CLIs) mit der CLI-Funktionen von ThinkPhp gebaut werden. Es betont Best Practices wie modulares Design, Abhängigkeitsinjektion und robust

Was sind die wichtigsten Überlegungen für die Verwendung von ThinkPhp in einer serverlosen Architektur? Was sind die wichtigsten Überlegungen für die Verwendung von ThinkPhp in einer serverlosen Architektur? Mar 18, 2025 pm 04:54 PM

In dem Artikel werden wichtige Überlegungen zur Verwendung von ThinkPhp in serverlosen Architekturen erörtert, wobei der Schwerpunkt auf Leistungsoptimierung, staatslosem Design und Sicherheit liegt. Es unterstreicht Vorteile wie Kosteneffizienz und Skalierbarkeit, befasst sich aber auch mit Herausforderungen

Was sind die erweiterten Merkmale des Abhängigkeitsinjektionsbehälters von ThinkPhp? Was sind die erweiterten Merkmale des Abhängigkeitsinjektionsbehälters von ThinkPhp? Mar 18, 2025 pm 04:50 PM

IOC -Container von ThinkPhp bietet erweiterte Funktionen wie fauler Laden, Kontextbindung und Methodeninjektion für eine effiziente Abhängigkeitsführung in PHP -Apps.character Count: 159

Wie kann ich SQL -Injektionsanfälligkeiten in ThinkPhp verhindern? Wie kann ich SQL -Injektionsanfälligkeiten in ThinkPhp verhindern? Mar 14, 2025 pm 01:18 PM

In dem Artikel werden die Verhindern von SQL -Injektionsanfälligkeiten in ThinkPhp durch parametrisierte Abfragen verhindern, die RAW -SQL, Verwendung von ORM, regelmäßige Updates und ordnungsgemäße Fehlerbehandlung, vermeiden. Es deckt auch Best Practices für die Sicherung von Datenbankabfragen und Validaten ab

Wie erstelle ich ein verteiltes Task -Warteschlangensystem mit ThinkPhp und Rabbitmq? Wie erstelle ich ein verteiltes Task -Warteschlangensystem mit ThinkPhp und Rabbitmq? Mar 18, 2025 pm 04:45 PM

Der Artikel beschreibt das Erstellen eines verteilten Task -Warteschlangensystems mit ThinkPhp und RabbitMQ, wobei sich die Installation, Konfiguration, Aufgabenverwaltung und Skalierbarkeit konzentriert. Zu den wichtigsten Problemen gehören die Gewährleistung einer hohen Verfügbarkeit, die Vermeidung häufiger Fallstricke wie Unmensch

Was sind die Hauptmerkmale des integrierten Test-Frameworks von ThinkPhp? Was sind die Hauptmerkmale des integrierten Test-Frameworks von ThinkPhp? Mar 18, 2025 pm 05:01 PM

In dem Artikel wird das integrierte Test-Framework von ThinkPhP erläutert, wobei die wichtigsten Funktionen wie Einheit und Integrationstests hervorgehoben werden und wie die Anwendungszuverlässigkeit durch frühzeitige Fehlererkennung und verbesserte Codequalität verbessert wird.

Was sind die wichtigsten Unterschiede zwischen ThinkPhp 5 und ThinkPhp 6 und wann zu verwenden? Was sind die wichtigsten Unterschiede zwischen ThinkPhp 5 und ThinkPhp 6 und wann zu verwenden? Mar 14, 2025 pm 01:30 PM

In dem Artikel werden wichtige Unterschiede zwischen ThinkPhp 5 und 6 erörtert und sich auf Architektur, Merkmale, Leistung und Eignung für Legacy -Upgrades konzentrieren. ThinkPhp 5 wird für traditionelle Projekte und Legacy -Systeme empfohlen, während ThinkPhp 6 zu neuem PR passt

Was sind die besten Möglichkeiten, Dateien -Uploads und Cloud -Speicher in ThinkPhp zu verarbeiten? Was sind die besten Möglichkeiten, Dateien -Uploads und Cloud -Speicher in ThinkPhp zu verarbeiten? Mar 17, 2025 pm 02:28 PM

In dem Artikel werden Best Practices für das Hochladen von Dateien und die Integration von Cloud -Speicher in ThinkPhP erörtert, wobei sich die Sicherheit, Effizienz und Skalierbarkeit konzentriert.

See all articles