


Currently, what I use is to set a value in the session. Every time I come in, I check whether the value exists. If it exists, it means it is locked. This request will not be executed. If it does not exist, set the value and perform subsequent operations.
<code>class controller{ function index(){ if(isset($_SESSION['lock'])) return; $_SESSION['lock'] = 1; sleep(1);//这里会查询用户的资格,并给用户发送流量,如果两次同时进来,会造成两次都认为是有资格的,并且会给用户发两次相同流量 unset($_SESSION['lock']); } } </code>
I thought it was possible to do this, and the session is stored in redis very quickly. Until I couldn't sleep and fiddled with it just now, I found that it was still possible for a user to execute multiple requests for the same interface at the same time.
If you want multiple requests from one person at the same time, only the first one will be processed. To determine whether they are the same person, judge based on session.
How do you ensure this?
Reply content:
Currently, what I use is to set a value in the session. Every time I come in, I check whether the value exists. If it exists, it means it is locked. This request will not be executed. If it does not exist, set the value and perform subsequent operations.
<code>class controller{ function index(){ if(isset($_SESSION['lock'])) return; $_SESSION['lock'] = 1; sleep(1);//这里会查询用户的资格,并给用户发送流量,如果两次同时进来,会造成两次都认为是有资格的,并且会给用户发两次相同流量 unset($_SESSION['lock']); } } </code>
I thought it was possible to do this, and the session is stored in redis very quickly. Until I couldn't sleep and fiddled with it just now, I found that it was still possible for a user to execute multiple requests for the same interface at the same time.
If you want multiple requests from a person at the same time, only the first one will be processed. To determine whether they are the same person, judge based on session.
How do you ensure this?
If the database is involved, use locking, or put all requests into a queue and process them one by one
I thought about it and I should write two things, one is the entry time and the exit time.
The access starts writing the start time, and the exit writes the exit time.
Assume that the first visit must be empty, start=02:26:30 end=02:26:50
Then when I re-initiate the visit, judge:
If start>end , indicating that there is another situation during the access, that is, the access is interrupted and there is no time to write the end time, so an initialization judgment must be made here, such as start>end&&start-end>100 to directly change end to the current Time, then it is free, and the access is carried out
If start
You can use the database to process it. Set a
mark. When the user enters the request, check the database first. If the
mark exists, it will not be executed.
Use the cache to store the id of the user being processed, operate the id through the filter, and the user request comes in. If the filter determines that the id is not in the cache, it will be added, and the id will be deleted after processing.
There are many methods. The question is what are your actual needs. I hope you can describe it from the perspective of final data. Maybe it is simpler not to describe it from the perspective of API
Judging from your question, you should have come up with a stupid solution. It is recommended that you state your original needs.
1. If you use Mysql, you can lock Mysql. After a request is completed, the lock must be released before other requests can be executed.
2. You can use a counter. When a request comes in, you can add one to the counter. After the request ends, clear the counter. This method is more recommended
3. In addition, the file session itself is locked. If each request by the same user is not completed, other requests will also be blocked
After typing a file, use File Lock to unlock the file after the operation is completed. The next user can continue to access and continue to lock

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

The reason for using Dependency Injection (DI) is that it promotes loose coupling, testability, and maintainability of the code. 1) Use constructor to inject dependencies, 2) Avoid using service locators, 3) Use dependency injection containers to manage dependencies, 4) Improve testability through injecting dependencies, 5) Avoid over-injection dependencies, 6) Consider the impact of DI on performance.

PHPperformancetuningiscrucialbecauseitenhancesspeedandefficiency,whicharevitalforwebapplications.1)CachingwithAPCureducesdatabaseloadandimprovesresponsetimes.2)Optimizingdatabasequeriesbyselectingnecessarycolumnsandusingindexingspeedsupdataretrieval.

ThebestpracticesforsendingemailssecurelyinPHPinclude:1)UsingsecureconfigurationswithSMTPandSTARTTLSencryption,2)Validatingandsanitizinginputstopreventinjectionattacks,3)EncryptingsensitivedatawithinemailsusingOpenSSL,4)Properlyhandlingemailheaderstoa

TooptimizePHPapplicationsforperformance,usecaching,databaseoptimization,opcodecaching,andserverconfiguration.1)ImplementcachingwithAPCutoreducedatafetchtimes.2)Optimizedatabasesbyindexing,balancingreadandwriteoperations.3)EnableOPcachetoavoidrecompil

DependencyinjectioninPHPisadesignpatternthatenhancesflexibility,testability,andmaintainabilitybyprovidingexternaldependenciestoclasses.Itallowsforloosecoupling,easiertestingthroughmocking,andmodulardesign,butrequirescarefulstructuringtoavoidover-inje

PHP performance optimization can be achieved through the following steps: 1) use require_once or include_once on the top of the script to reduce the number of file loads; 2) use preprocessing statements and batch processing to reduce the number of database queries; 3) configure OPcache for opcode cache; 4) enable and configure PHP-FPM optimization process management; 5) use CDN to distribute static resources; 6) use Xdebug or Blackfire for code performance analysis; 7) select efficient data structures such as arrays; 8) write modular code for optimization execution.

OpcodecachingsignificantlyimprovesPHPperformancebycachingcompiledcode,reducingserverloadandresponsetimes.1)ItstorescompiledPHPcodeinmemory,bypassingparsingandcompiling.2)UseOPcachebysettingparametersinphp.ini,likememoryconsumptionandscriptlimits.3)Ad


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

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

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.
