Rumah rangka kerja php ThinkPHP ThinkPhp5.1 jSignature melaksanakan fungsi tandatangan dalam talian

ThinkPhp5.1 jSignature melaksanakan fungsi tandatangan dalam talian

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

Tanda tangan dalam talian digunakan di banyak tempat Editor baru-baru ini mengambil projek, yang melibatkan fungsi tandatangan kelulusan Pelanggan memerlukan fungsi tandatangan masa nyata pada telefon mudah alih telah digunakan untuk melengkapkan Fungsi ini, kongsikannya untuk rujukan semua orang.

Memandangkan anda menggunakan perpustakaan jSignature untuk membuat tandatangan, sudah tentu anda perlu memuat turun perpustakaan jSignature Editor menyediakan alamat muat turun seperti berikut. Rakan boleh pergi untuk memuat turun:

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

Selepas mendapat pustaka jSignature, bagaimanakah cara untuk menggunakannya? , editor menerangkan Sila sediakan dokumentasi, anda boleh menyemaknya:

Manual Pembangunan Cina jsignature

Selain itu, jsignature perlu digunakan dengan jQuery perpustakaan, jika tidak sesetengah fungsi tidak akan berfungsi Untuk paparan, alamat muat turun juga disediakan untuk semua orang memuat turun:

pautanMemuat turun jQuery

Sudah tentu, terdapat banyak versi jQuery, dan editor menggunakan jquery-3.2 1.js

Fungsi penyediaan awal sudah sedia, dan kaedah pengeluaran disediakan di bawah.

HTML bahagian hadapan

<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>
Salin selepas log masuk

1 Sertakan jsignature

$(document).ready(function(){
    var arguments = {
        width: &#39;100%&#39;,
        height: &#39;200px&#39;,
    };
    $("#signature").jSignature(arguments);
});
Salin selepas log masuk

2 Tetapkan semula tandatangan

$("#reset").click(function(){
    $("#signature").jSignature("reset"); //重置画布,可以进行重新作画
    $("#images").attr(&#39;src&#39;,&#39;&#39;);
});
Salin selepas log masuk

3 Serahkan tandatangan

Editor menggunakan penyerahan ajax TP5.1 [Cadangan berkaitan: tutorial video thinkphp

//点击确定按钮,把签名的转成图片,然后把数据放进图片中,最后把图片中的数据传到后台
$("#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("错误");
        }
    });
});
Salin selepas log masuk

4 Penerimaan data latar belakang (getSignInfo.php)

$data = Request::param();
$src = $this->base64ContentToImage($data[&#39;src_data&#39;],$path);
Salin selepas log masuk

$src ialah alamat storan imej tandatangan yang kami perlukan, $path ialah The saving laluan imej tandatangan

5 Tukar kod base64 imej kepada imej standard (kaedah 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;
    }
}
Salin selepas log masuk

Di atas adalah editor Merumuskan kaedah pengeluaran lengkap menggunakan perpustakaan jSignature TP5.1 untuk menjana tandatangan Saya harap ia akan membantu semua orang, terima kasih!

Atas ialah kandungan terperinci ThinkPhp5.1 jSignature melaksanakan fungsi tandatangan dalam talian. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

Repo: Cara menghidupkan semula rakan sepasukan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah perbezaan antara buku berfikir dan thinkpad Apakah perbezaan antara buku berfikir dan thinkpad Mar 06, 2025 pm 02:16 PM

Artikel ini membandingkan Lenovo's ThinkBook dan ThinkPad Laptop Lappt. ThinkPads mengutamakan ketahanan dan prestasi untuk profesional, sementara Thinkbooks menawarkan pilihan yang bergaya dan berpatutan untuk kegunaan seharian. Perbezaan utama terletak pada kualiti membina, p

Cara Mencegah Tutorial Suntikan SQL Cara Mencegah Tutorial Suntikan SQL Mar 06, 2025 pm 02:10 PM

Artikel ini menerangkan bagaimana untuk mencegah suntikan SQL dalam aplikasi ThinkPHP. Ia menekankan menggunakan pertanyaan parameter melalui pembina pertanyaan ThinkPHP, mengelakkan penggabungan SQL langsung, dan melaksanakan pengesahan input & sanitisasi yang mantap. AD

Bagaimanakah saya boleh menggunakan ThinkPhp untuk membina aplikasi baris arahan? Bagaimanakah saya boleh menggunakan ThinkPhp untuk membina aplikasi baris arahan? Mar 12, 2025 pm 05:48 PM

Artikel ini menunjukkan aplikasi baris arahan bangunan (CLI) menggunakan keupayaan CLI ThinkPHP. Ia menekankan amalan terbaik seperti reka bentuk modular, suntikan ketergantungan, dan pengendalian ralat yang mantap, sambil menonjolkan perangkap biasa seperti Inu

Bagaimana Menangani Kerentanan ThinkPhp? Bagaimana Menangani Kerentanan ThinkPhp? Mar 06, 2025 pm 02:08 PM

Artikel ini membincangkan kelemahan ThinkPHP, menekankan penampalan, pencegahan, dan pemantauan. Ia memperincikan pengendalian kelemahan tertentu melalui kemas kini, patch keselamatan, dan pemulihan kod. Langkah proaktif seperti konfigurasi selamat, input

Cara Memasang Perisian yang Dibangunkan oleh ThinkPhp Cara Memasang Tutorial Cara Memasang Perisian yang Dibangunkan oleh ThinkPhp Cara Memasang Tutorial Mar 06, 2025 pm 02:09 PM

Butiran artikel ini Pemasangan perisian ThinkPHP, meliputi langkah -langkah seperti memuat turun, pengekstrakan, konfigurasi pangkalan data, dan pengesahan kebenaran. Ia menangani keperluan sistem (versi PHP, pelayan web, pangkalan data, sambungan), pemasangan biasa

Cara Memperbaiki Kerentanan ThinkPhp Bagaimana Menangani Kerentanan ThinkPhp Cara Memperbaiki Kerentanan ThinkPhp Bagaimana Menangani Kerentanan ThinkPhp Mar 06, 2025 pm 02:04 PM

Tutorial ini menangani kelemahan berfikir biasa. Ia menekankan kemas kini yang kerap, pengimbas keselamatan (RIPS, Sonarqube, Snyk), semakan kod manual, dan ujian penembusan untuk pengenalpastian dan pemulihan. Langkah pencegahan termasuk selamat

Apakah pertimbangan utama untuk menggunakan ThinkPhp dalam seni bina tanpa pelayan? Apakah pertimbangan utama untuk menggunakan ThinkPhp dalam seni bina tanpa pelayan? Mar 18, 2025 pm 04:54 PM

Artikel ini membincangkan pertimbangan utama untuk menggunakan ThinkPhp dalam arkitek tanpa pelayan, memberi tumpuan kepada pengoptimuman prestasi, reka bentuk tanpa statik, dan keselamatan. Ia menyoroti faedah seperti kecekapan kos dan skalabiliti, tetapi juga menangani cabaran

Cara Menggunakan Tutorial ThinkPhp Cara Menggunakan Tutorial ThinkPhp Mar 06, 2025 pm 02:11 PM

Artikel ini memperkenalkan ThinkPhp, kerangka PHP sumber terbuka. IT memperincikan seni bina, ciri-ciri (penghalaan, interaksi pangkalan data), kelebihan (perkembangan pesat, kemudahan penggunaan), dan kekurangan yang berpotensi (potensi kejuruteraan, commun

See all articles