


thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial
thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code
Before introducing the use of thinkphp3.2 verification code, I will introduce the ThinkPHP verification code in detail. The specific content is as follows
ThinkPHP has built-in support for verification codes and can be used directly. To use the verification code, you need to import the ORG.Util.Image class library and ORG.Util.String class library in the extended class library.
Verification code method
We add a verify method to the module class to display the verification code. The simplest example:
Public function verify(){ // 导入Image类库 import("ORG.Util.Image"); Image::buildImageVerify(); }
The import method is ThinkPHP’s built-in class library and file import method. The file imported in the above example is the Lib/ORG/Util/Image.class.php file in the ThinkPHP system directory. If the Image class library has been copied to the current project, such as Lib/ORG, you can use:
import("@.Util.Image");
The import method is ThinkPHP’s built-in class library and file import method. The file imported in the above example is the Lib/ORG/Util/Image.class.php file in the ThinkPHP system directory.
Access verification code
You can access the verification code method directly in the browser to determine whether the verification code can be displayed normally:
http://127.0.0.1/index.php/Public/verify
If everything goes well, the verification code will appear as follows:
Use verification code in form
To use the verification code in the form page, it is called with the html img tag:
<input type="text" name="verify"> <img src="/static/imghw/default1.png" data-src="-Article-verify" class="lazy" id="verifyImg" onClick="changeVerify()" title="点击刷新thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial" / alt="thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial" >
The src attribute value is the verification code method access address, which varies depending on the actual situation.
Verification code refresh
When the verification code image is clicked, the JavaScript changeVerify() function is triggered to re-read the verification code, thereby refreshing the verification code. The function reference is as follows:
<script language="JavaScript"> function changeVerify(){ var timenow = new Date().getTime(); document.getElementById('verifyImg').src='-Article/verify/'+timenow; } </script>
Verification code verification
When calling the verification code verify, buildImageVerify will record the MD5 information of this verification code. In the form verification operation, use the following method to check whether the verification code is correct:
if($_SESSION['verify'] != md5($_POST['verify'])) { $this->error('thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial错误!'); }
The verify name in $_SESSION['verify'] is the default SESSION registration name of the buildImageVerify method. For details, see the buildImageVerify syntax.
The above example demonstrates the simplest way to use ThinkPHP verification code. The verification code in the above example is 4 digits. If you want to use more styles of verification codes and Chinese verification codes, see the rest of this section: "ThinkPHP uses different styles and Chinese verification codes".
The reason why the verification code is not displayed
It is found that the verification code cannot be displayed. The possible reasons are as follows:
1. Whether PHP has installed GD library support.
2. Is there any output before output (especially UTF8 BOM header information output).
3. Whether the Image class library is imported correctly.
4. If it is a form page, please check whether the verification code display method is correctly called.
The following will introduce to you how to generate the verification code and click to refresh the verification code in thinkphp3.2. The specific content is as follows
1. Instantiate the class that generates the verification code (this method is placed in IndexController for easy access)
/** * * thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial生成 */ public function verify_c(){ $Verify = new \Think\Verify(); $Verify->fontSize = 18; $Verify->length = 4; $Verify->useNoise = false; $Verify->codeSet = '0123456789'; $Verify->imageW = 130; $Verify->imageH = 50; //$Verify->expire = 600; $Verify->entry(); }
2. The src attribute of the image that the front desk needs to generate a verification code points to
<p class="top15 captcha" id="captcha-container"> <input name="verify" width="50%" height="50" class="captcha-text" placeholder="thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial" type="text"> <img class="left15 lazy" src="/static/imghw/default1.png" data-src="{:U('Home/Index/verify_c',array())}" style="max-width:90%" style="max-width:90%" alt="thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial"Home/Index/verify_c',array())}" title="点击刷新"> </p>
3. After writing the above, the verification code for page initialization will appear. What is written next is to refresh the new verification code image after clicking on the verification code image (this is done by modifying the src attribute of the image through jquery. The request processing function is the same, except that a random number is added after the request to distinguish the request for the previous picture)
// thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial生成 var captcha_img = $('#captcha-container').find('img') var verifyimg = captcha_img.attr("src"); captcha_img.attr('title', '点击刷新'); captcha_img.click(function(){ if( verifyimg.indexOf('?')>0){ $(this).attr("src", verifyimg+'&random='+Math.random()); }else{ $(this).attr("src", verifyimg.replace(/\?.*$/,'')+'?'+Math.random()); } });
4. Verify whether the verification code is entered correctly
a. Add a global function to function.php in the common directory
/** * thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial检查 */ function check_verify($code, $id = ""){ $verify = new \Think\Verify(); return $verify->check($code, $id); }
b. Add the check code in the processing method corresponding to the controller of the form submission
// 检查thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial $verify = I('param.verify',''); if(!check_verify($verify)){ $this->error("亲,thinkphp3.2 click refresh to generate verification code, thinkphp3.2 verification code_PHP tutorial输错了哦!",$this->site_url,9); }
Now you can use the tp3.2 verification code.
Supplement: When I was writing, I put the fourth step b into an ajax for verification and returned a test result. Then it is determined whether to submit the form based on the returned results. However, after the verification code passes the first verification, the second time will not work. I haven’t figured out the reason yet.
This is the entire content of this article. There is a small question at the end of the article. I hope you can come up with a solution. I also hope this article will be helpful to your study.
Articles you may be interested in:
- A concise tutorial on how to use ThinkPHP verification code
- Solutions for thinkphp verification code not showing up
- ThinkPHP verification code and Pagination example tutorial
- ThinkPHP implementation of file upload function with verification code example
- Perfect solution to the problem that thinkphp verification code error cannot be displayed
- Solution to the problem that ThinkPHP opens the verification code page and displays garbled characters Method
- Simple method of using verification code in thinkPHP

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



What should I do if Google Chrome does not display the verification code image? Sometimes you need a verification code to log in to a web page using Google Chrome. Some users find that Google Chrome cannot display the content of the image properly when using image verification codes. What should be done? The editor below will introduce how to deal with the Google Chrome verification code not being displayed. I hope it will be helpful to everyone! Method introduction: 1. Enter the software, click the "More" button in the upper right corner, and select "Settings" in the option list below to enter. 2. After entering the new interface, click the "Privacy Settings and Security" option on the left. 3. Then click "Website Settings" on the right

To run the ThinkPHP project, you need to: install Composer; use Composer to create the project; enter the project directory and execute php bin/console serve; visit http://localhost:8000 to view the welcome page.

ThinkPHP has multiple versions designed for different PHP versions. Major versions include 3.2, 5.0, 5.1, and 6.0, while minor versions are used to fix bugs and provide new features. The latest stable version is ThinkPHP 6.0.16. When choosing a version, consider the PHP version, feature requirements, and community support. It is recommended to use the latest stable version for best performance and support.

Steps to run ThinkPHP Framework locally: Download and unzip ThinkPHP Framework to a local directory. Create a virtual host (optional) pointing to the ThinkPHP root directory. Configure database connection parameters. Start the web server. Initialize the ThinkPHP application. Access the ThinkPHP application URL and run it.

The virtual number can receive the verification code. As long as the mobile phone number filled in during registration complies with the regulations and the mobile phone number can be connected normally, you can receive the SMS verification code. However, you need to be careful when using virtual mobile phone numbers. Some websites do not support virtual mobile phone number registration, so you need to choose a regular virtual mobile phone number service provider.

Performance comparison of Laravel and ThinkPHP frameworks: ThinkPHP generally performs better than Laravel, focusing on optimization and caching. Laravel performs well, but for complex applications, ThinkPHP may be a better fit.

"Development Suggestions: How to Use the ThinkPHP Framework to Implement Asynchronous Tasks" With the rapid development of Internet technology, Web applications have increasingly higher requirements for handling a large number of concurrent requests and complex business logic. In order to improve system performance and user experience, developers often consider using asynchronous tasks to perform some time-consuming operations, such as sending emails, processing file uploads, generating reports, etc. In the field of PHP, the ThinkPHP framework, as a popular development framework, provides some convenient ways to implement asynchronous tasks.

ThinkPHP installation steps: Prepare PHP, Composer, and MySQL environments. Create projects using Composer. Install the ThinkPHP framework and dependencies. Configure database connection. Generate application code. Launch the application and visit http://localhost:8000.
