


- UsersNap adalah alat yang membolehkan pengguna melaporkan pepijat terus dari laman web dengan menandakan tangkapan skrin dan menghantar semua data dalam konsol JavaScript. Ia boleh diintegrasikan ke laman web pelanggan untuk mempercepat pelaporan dan resolusi pepijat.
- Pemaju juga boleh menggunakan UserNap untuk mengumpulkan kesilapan dan log sisi pelayan. Dengan menggunakan kelas yang mudah, mereka boleh merakam semua kesilapan dan balak yang diperlukan untuk debugging, yang kemudiannya boleh dihantar ke UserNap. Ini membolehkan pembetulan pepijat yang lebih cepat dan lebih cekap.
- UsersNap juga menyediakan maklumat tambahan seperti saiz skrin, versi penyemak imbas, OS, dan plugin pelayar yang dipasang. Ciri ini boleh dihidupkan hanya apabila diperlukan, dan ketersediaannya boleh dibatasi melalui kaedah seperti penapisan IP atau membuka dev.* Subdomain.
bagaimana kita dapat membantu pengguna melaporkan pepijat sebaik mungkin?

mari kita mempunyai permintaan JSON yang sangat mudah dan ralat untuk dapat menghasilkan semula kes kita:
<span>$json_data = '{"value":1,"apples":2,"name":3,"oranges":4,"last one":5}'; </span> <span>//we will simulate the json data, but imagine that this is the normal data exchanged daily between your client’s website and a 3rd party API </span> <span>$ch = curl_init('http://talkweb.eu/labs/fr/json_callback.php'); </span><span>curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); </span><span>curl_setopt($ch, CURLOPT_POSTFIELDS, $json_data); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HTTPHEADER, array( 'Content-Type: application/json', </span> <span>'Content-Length: ' . strlen($json_data))); </span> <span>//the normal CURL request, nothing strange here: </span><span>$result = curl_exec($ch); </span> <span>//receiving the data back </span><span>$f_data = json_decode($result,true); </span> <span>//showing a greeting with the output </span><span>echo “Welcome”. $f_data['username'];</span>Jika anda melawat laman web ujian sekarang, anda akan melihat bahawa ada masalah.
Soalannya - bagaimana pelanggan dapat melaporkannya lebih cepat dengan semua data yang anda perlukan untuk melawan bug:
- data json,
- javascript sisi pelayan dan kesilapan xmlhttpsrequest,
- beberapa kesilapan PHP teras
- ... dan data meta.
mengumpul kesilapan
Mari tambahkan lebih banyak kod kepada contoh untuk melihat bagaimana kita dapat mengumpul data yang kita perlukan. Memperkenalkan kelas yang sangat mudah untuk membantu kami:
<span><span> </span></span><span><span>class SendToUsersnap </span></span><span><span>{ </span></span><span> <span>var $m; </span></span><span> <span>//Save all logs in an array. You can use an even more elegant approach but right now I need it to be simple for the sake of this tutorial. </span></span><span> <span>function log ( $data, $type ) { </span></span><span> </span><span> <span>if( is_array( $data ) || is_object( $data ) ) { </span></span><span> <span>$this->m[]= "console.".$type."('PHP: ".json_encode($data)."');"; </span></span><span> <span>} else { </span></span><span> <span>$this->m[] = "console.".$type."('PHP: ".$data."');"; </span></span><span> <span>} </span></span><span> <span>} </span></span><span> <span>// Print all logs that have been set from the previous function. Let’s keep it simple. </span></span><span> <span>function out (){ </span></span><span> <span>for ($i=0;$i<count>m);$i++) </count></span></span><span> <span>{ </span></span><span> <span>echo $this->m[$i]."\n"; </span></span><span> <span>} </span></span><span> </span><span> </span><span> <span>} </span></span><span><span>}</span></span>Sekarang mari kita gunakan kelas ini untuk merakam semua kesilapan dan log yang kita perlukan.
<span>require_once('Usersnap.class.php'); </span> <span>$s = new SendToUsersnap; </span> <span>$json_data = '{"value":1,"apples":2,"name":3,"oranges":4,"last one":5}'; </span> <span>$s->log('Initializing the JSON request',"info"); </span> <span>$s->log($json_data,"log"); </span> <span>$ch = curl_init('http://talkweb.eu/labs/fr/json_callback.php'); </span> <span>curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); </span> <span>curl_setopt($ch, CURLOPT_POSTFIELDS, $json_data); </span> <span>curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); </span> <span>curl_setopt($ch, CURLOPT_HTTPHEADER, array( </span> <span>'Content-Type: application/json', </span> <span>'Content-Length: ' . strlen($json_data))); </span> <span>$result = curl_exec($ch); </span> <span>$f_data = json_decode($result,true); </span> <span>echo 'Welcome'. $f_data['usersname']; </span> <span>$s->log($f_data,"log"); </span> <span>$s->log(error_get_last(),"error");</span>
Mari tambahkan coretan kod pengguna di hujung halaman kami dan lihat apa yang berlaku. (Anda mungkin memerlukan akaun untuk menggunakan widget ini. UsersNap menawarkan lesen percuma untuk projek sumber terbuka dan tempoh ujian percuma untuk yang komersial.
NOTA: Anda akan melakukan ini dalam templat paparan dalam rangka kerja sebenar, tetapi kerana kami tidak menggunakan aplikasi MVC sebenar di sini, kami melangkau bahagian itu.
<span><span><span><script> type<span >="text/javascript"</script></span>></span><span> </span></span><span><span> <span>(function() { </span></span></span><span><span> <span>var s = document.createElement("script"); </span></span></span><span><span> s<span>.type = "text/javascript"; </span></span></span><span><span> s<span>.async = true; </span></span></span><span><span> s<span>.src = '//api.usersnap.com/load/'+ </span></span></span><span><span> <span>'your-api-key-here.js'; </span></span></span><span><span> <span>var x = document.getElementsByTagName('script')[0]; </span></span></span><span><span> x<span>.parentNode.insertBefore(s, x); </span></span></span><span><span> <span>})(); </span></span></span><span><span> </span></span><span><span> <span>var _usersnapconfig = { </span></span></span><span><span> <span>loadHandler: function() { </span></span></span><span><span> <span><span><?php </span></span></span></span><span><span><span> <span>//just print all errors collected from the buffer. </span></span></span></span><span><span><span> <span>$s->out(); ?></span> </span></span></span><span><span> <span>} </span></span></span><span><span> <span>}; </span></span></span><span><span></span><span><span></span>></span></span></span>
Pengguna akan melihat butang "Laporan Bug" pada halaman dan akan menulis mesej seperti "Ia tidak berfungsi, memperbaikinya ASAP". Umumnya, ini akan menjadi maklumat yang tidak berguna, tetapi kali ini, kami mendapat log ralat cantik ini juga:
<span>$json_data = '{"value":1,"apples":2,"name":3,"oranges":4,"last one":5}'; </span> <span>//we will simulate the json data, but imagine that this is the normal data exchanged daily between your client’s website and a 3rd party API </span> <span>$ch = curl_init('http://talkweb.eu/labs/fr/json_callback.php'); </span><span>curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); </span><span>curl_setopt($ch, CURLOPT_POSTFIELDS, $json_data); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HTTPHEADER, array( 'Content-Type: application/json', </span> <span>'Content-Length: ' . strlen($json_data))); </span> <span>//the normal CURL request, nothing strange here: </span><span>$result = curl_exec($ch); </span> <span>//receiving the data back </span><span>$f_data = json_decode($result,true); </span> <span>//showing a greeting with the output </span><span>echo “Welcome”. $f_data['username'];</span>anda dapat melihat data yang akan kami hantar - sama seperti biasa
<span><span> </span></span><span><span>class SendToUsersnap </span></span><span><span>{ </span></span><span> <span>var $m; </span></span><span> <span>//Save all logs in an array. You can use an even more elegant approach but right now I need it to be simple for the sake of this tutorial. </span></span><span> <span>function log ( $data, $type ) { </span></span><span> </span><span> <span>if( is_array( $data ) || is_object( $data ) ) { </span></span><span> <span>$this->m[]= "console.".$type."('PHP: ".json_encode($data)."');"; </span></span><span> <span>} else { </span></span><span> <span>$this->m[] = "console.".$type."('PHP: ".$data."');"; </span></span><span> <span>} </span></span><span> <span>} </span></span><span> <span>// Print all logs that have been set from the previous function. Let’s keep it simple. </span></span><span> <span>function out (){ </span></span><span> <span>for ($i=0;$i<count>m);$i++) </count></span></span><span> <span>{ </span></span><span> <span>echo $this->m[$i]."\n"; </span></span><span> <span>} </span></span><span> </span><span> </span><span> <span>} </span></span><span><span>}</span></span>dan anda dapat melihat output. Ya, masalahnya ada. Jelas ada masalah auth.
<span>require_once('Usersnap.class.php'); </span> <span>$s = new SendToUsersnap; </span> <span>$json_data = '{"value":1,"apples":2,"name":3,"oranges":4,"last one":5}'; </span> <span>$s->log('Initializing the JSON request',"info"); </span> <span>$s->log($json_data,"log"); </span> <span>$ch = curl_init('http://talkweb.eu/labs/fr/json_callback.php'); </span> <span>curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); </span> <span>curl_setopt($ch, CURLOPT_POSTFIELDS, $json_data); </span> <span>curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); </span> <span>curl_setopt($ch, CURLOPT_HTTPHEADER, array( </span> <span>'Content-Type: application/json', </span> <span>'Content-Length: ' . strlen($json_data))); </span> <span>$result = curl_exec($ch); </span> <span>$f_data = json_decode($result,true); </span> <span>echo 'Welcome'. $f_data['usersname']; </span> <span>$s->log($f_data,"log"); </span> <span>$s->log(error_get_last(),"error");</span>anda boleh mendapatkan kesilapan PHP teras untuk membantu anda dengan debugging.
<span><span><span><script> type<span >="text/javascript"</script></span>></span><span> </span></span><span><span> <span>(function() { </span></span></span><span><span> <span>var s = document.createElement("script"); </span></span></span><span><span> s<span>.type = "text/javascript"; </span></span></span><span><span> s<span>.async = true; </span></span></span><span><span> s<span>.src = '//api.usersnap.com/load/'+ </span></span></span><span><span> <span>'your-api-key-here.js'; </span></span></span><span><span> <span>var x = document.getElementsByTagName('script')[0]; </span></span></span><span><span> x<span>.parentNode.insertBefore(s, x); </span></span></span><span><span> <span>})(); </span></span></span><span><span> </span></span><span><span> <span>var _usersnapconfig = { </span></span></span><span><span> <span>loadHandler: function() { </span></span></span><span><span> <span><span><?php </span></span></span></span><span><span><span> <span>//just print all errors collected from the buffer. </span></span></span></span><span><span><span> <span>$s->out(); ?></span> </span></span></span><span><span> <span>} </span></span></span><span><span> <span>}; </span></span></span><span><span></span><span><span></span>></span></span></span>pelanggan anda hanya perlu mengklik butang sekali dan anda akan mendapat semua yang anda perlukan untuk melawan bug lebih cepat:
- ralat dan log (seperti yang ditunjukkan di atas)
- tangkapan skrin anotasi - jika masalahnya lebih kompleks daripada contoh mudah ini
- saiz skrin, versi penyemak imbas, OS dan plugin yang dipasang di penyemak imbas
Kesimpulan
Ini bukan alat pemantauan skrip dan tidak akan memberikan maklumat secara automatik apabila dan jika masalah itu muncul. Pendekatan ini akan berfungsi hanya jika pengguna atau pelanggan melaporkan pepijat dan anda sebagai pemaju atau QA memerlukan lebih banyak maklumat tentang cara melawan bug. Bayangkan ia sebagai debugger jauh, tetapi untuk peristiwa dan data kesilapan pelanggan yang anda hantar dari PHP ke JavaScript.
Saya suka menjawab semua soalan anda! Tinggalkan maklum balas anda di bawah!
Soalan Lazim (Soalan Lazim) Mengenai Pelaporan Pepijat Side Pelanggan dengan UserNap
Bagaimanakah pengguna berfungsi untuk pelaporan pepijat klien? Ia berfungsi dengan menangkap tangkapan skrin isu bersama dengan maklumat penyemak imbas penting, yang kemudiannya dihantar ke pasukan pembangunan. Ini menghapuskan keperluan untuk komunikasi back-and-forth dan mempercepatkan proses penetapan pepijat. UsersNap juga mengintegrasikan dengan alat pengurusan dan komunikasi projek yang popular, menjadikannya penyelesaian yang serba boleh untuk pelbagai pasukan. alat untuk pelaporan pepijat. Ini termasuk penangkapan tangkapan skrin, pengumpulan maklumat penyemak imbas, rakaman log konsol, dan koleksi maklum balas pengguna. Ia juga menawarkan integrasi dengan alat popular seperti Slack, Jira, dan Trello, antara lain. Di samping itu, UsersNap menyediakan API untuk penyesuaian dan integrasi selanjutnya dengan sistem lain.
Bagaimana saya boleh mengintegrasikan pengguna ke dalam aplikasi web saya?
Mengintegrasikan UserNap ke dalam aplikasi web anda adalah mudah. Anda perlu mendaftar untuk akaun UsersNap, membuat projek baru, dan kemudian tambahkan kod JavaScript yang disediakan ke aplikasi web anda. Kod ini akan memuatkan widget pengguna pada aplikasi anda, yang membolehkan pengguna melaporkan pepijat secara langsung.
Bolehkah saya menggunakan UsersNap untuk pelaporan pepijat mudah alih? Widget UserNap responsif dan berfungsi dengan baik pada peranti mudah alih. Ini membolehkan pengguna anda melaporkan pepijat terus dari pelayar mudah alih mereka, memberikan anda maklum balas yang berharga untuk meningkatkan aplikasi web mudah alih anda. Untuk maklum balas visual dan maklumat penyemak imbas terperinci, yang membuat pelaporan pepijat dan penetapan lebih cekap. Ia juga menawarkan pelbagai pilihan penyesuaian dan integrasi dengan alat yang popular. Walaupun alat lain mungkin menawarkan ciri -ciri yang sama, kesederhanaan dan fleksibiliti UserNap menjadikannya pilihan pilihan untuk banyak pasukan. Ini termasuk dokumentasi terperinci, rujukan API, dan contoh untuk membantu anda memulakan dan memanfaatkan sepenuhnya alat ini. UsersNap juga menyediakan sokongan e -mel untuk sebarang pertanyaan atau isu yang mungkin anda miliki.
Atas ialah kandungan terperinci Melaksanakan pelaporan pepijat pelanggan dengan usernap. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Phpsessionscanstorestrings, nombor, tatasusunan, andobjects.1.strings: textdatalikeusernames.2.numbers: integersorfloatsforcounters.3.Arrays: ListsLikeshoppingCarts.4.Objects: complextructureSturesthatareserialized.

Tostartaphpsession, usesession_start () atthescript'sbeginning.1) placeitbeforeanyoutputtosetthesessioncookie.2) usesessionsforusererdatalikeloginstatusorshoppingcarts.3)

Penjanaan semula sesi merujuk kepada menjana ID sesi baru dan membatalkan ID lama apabila pengguna melakukan operasi sensitif dalam kes serangan tetap sesi. Langkah-langkah pelaksanaan termasuk: 1. Mengesan Operasi Sensitif, 2. Menjana ID Sesi Baru, 3. Memusnahkan ID Sesi Lama, 4. Kemas kini maklumat sesi pengguna.

Sesi PHP mempunyai kesan yang signifikan terhadap prestasi aplikasi. Kaedah pengoptimuman termasuk: 1. Gunakan pangkalan data untuk menyimpan data sesi untuk meningkatkan kelajuan tindak balas; 2. Mengurangkan penggunaan data sesi dan hanya menyimpan maklumat yang diperlukan; 3. Gunakan pemproses sesi yang tidak menyekat untuk meningkatkan keupayaan konkurensi; 4. Laraskan masa tamat tempoh sesi untuk mengimbangi pengalaman pengguna dan beban pelayan; 5. Gunakan sesi berterusan untuk mengurangkan bilangan data membaca dan menulis masa.

Phpsessionsareserver-side, whilecookiesareclient-side.1) Sessionsstoredataontheserver, aremoresecure, andhandlelargerdata.2) cookiesstoredataontheclient, arelesssecure, andlimiteShorsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsionsforsions

Phpidentifierauser'sSessionusingSessionCookiesandSessionIds.1) whensession_start () ISCALLED, phpGeneratesAuniquesessionIdstoredinacookienamedPhpsessidontheUserer'sBrowser.2) ThisIdallowsPhptoretRievesSessionDataFromtheserver.

Keselamatan sesi PHP boleh dicapai melalui langkah -langkah berikut: 1. Gunakan session_regenerate_id () untuk menjana semula ID sesi apabila pengguna log masuk atau merupakan operasi penting. 2. Sulitkan ID sesi penghantaran melalui protokol HTTPS. 3. Gunakan session_save_path () untuk menentukan direktori selamat untuk menyimpan data sesi dan menetapkan kebenaran dengan betul.

PhpsessionFileSarestoredIntHedirectorySpecifiedBySession.save_path, biasanya/tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomethis: 1) usession_save_path ()


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.
