search
HomeBackend DevelopmentPHP Tutorialphp security filtering_PHP tutorial

php security filtering

/*ansic code-Url code table: http://www.w3school.com.cn/tags/html_ref_urlencode.html

-------------------------------------------------- -------------------------------------------------- -------------

1. Validate and filter user input

Even the most common alphanumeric input may be dangerous. It is easy to list a few Characters that cause security issues:

!$ ^ & * ( ) ~ [ ] | { } ' " ; ? - `

Characters that may have special meaning in the database :

'" ;

There are also some non-printing characters:

character x00 or ASCII 0, NULL or FALSE

character x10 and x13, Or ASCII 10 and 13, n r

character x1a or ASCII 26, indicating the end of the file

Entering the wrong parameter type may also cause unexpected errors in the program.

Entering too many parameter values ​​may lead to overflow and other errors.

2. Filtering of file paths and names

File names cannot contain binary data, otherwise it may cause problems.

Some systems allow Unicode multi-byte encoded file names, but this should be avoided and ASCII characters should be used instead.

Although Unix systems can use almost any symbol in the file name setting, you should try to use - and _ and avoid using other characters.

At the same time, the length of the file name needs to be limited.

3. Prevent SQL injection

Check the type of user input. When the user input is a number, you can use the following method:

Use the is_int() function (or is_integer( ) or is_long() function)

Use gettype() function

Use intval() function

Use settype() function

to check user input characters The length of the string is determined using the strlen() function.

To check whether the date or time is valid, you can use the strtotime() function

4. Prevent XSS attacks

A common method for xss attacks is to inject HTML elements to execute js Scripts, PHP has built-in some defensive functions (such as htmlentities or htmlspecialchars)

5. Filter URLs submitted by users

If the user is allowed to enter a URL to call an image or link, You need to ensure that he does not pass in non-http protocols such as javascript: or vbscript: or data:.

You can use PHP's built-in function parse_url() function to split the URL and then make a judgment.

6. Prevent remote execution--The following table lists some characters related to Shell:

Remote execution usually uses PHP code to execute such as eval() function, or calls Command execution such as exec(), passthru(), proc_open(), shell_exec(), system() or popen().

Inject PHP code: PHP provides developers with many ways to call PHP scripts. We need to pay attention to filtering user-controllable data.

7. Shell command execution

PHP provides some functions that can directly execute system commands, such as the exec() function or ` (backtick).

PHP's safe mode will provide some protection, but there are also some ways to bypass the safe mode:

1. Upload a Perl script, or Python or Ruby, etc., to the environment supported by the server. Executing scripts in other languages ​​can bypass PHP's safe mode.

2. Use the buffer overflow vulnerability of the system to bypass the safe mode.

Some characters related to Shell:

Name Character ASCII Hexadecimal URL encoding HTML encoding

Line feed 10 x0a

Exclamation mark! 33 x21 ! !

Double quote " 34 x22 " " or "

Dollar sign $ 36 x24 $ $

Connector & 38 x26 & & or amp

Single quote ' 39 x27 ' '

Left bracket ( 40 x28 ( (

right bracket) 41 x29 ) )

asterisk * 42 x2a * *

hyphen - 45 x2d - -

Semicolon; 59 x3b ; ;

Left angle bracket

Right angle bracket > 62 x3e > >

Question mark ? 63 x3f ? ?

left square bracket [ 91 x5b [ [

backslash 92 x5c \

right square bracket] 93 x5d ] ]

caret ^ 94 x5e ^ ^

backtick ` 96 x60 ` `

left curly brace { 123 x7b { {

pipe character | 124 x7c | |

right curly brace} 125 x7d } }

tilde ~ 126 x7e ~ ~

------------------------------------------------ -------------------------------------------------- ---------------

Security filtering function code*/

/**

* Safe filtering input [jb]

*/

function check_str($string, $isurl = false)

{

$string= preg_replace('/[\x00-\x08\x0B\x0C\x0E-\x1F]/ ','',$string); //Remove control characters

$string= str_replace(array("

empty($isurl)&& $string =preg_replace("/&(?!(#[0-9] |[a-z] );)/si",'&',$string);//Inside HTML You can use xx; to encode some characters, such as (space), ? Unicode characters, etc. A(?!B) means that A is not followed by B, so the author wants to retain ? similar HTML encoding characters and remove other The problem character is

$string= str_replace(array("

$string= str_replace(array(">",'>'),'>',$string);

$string= str_replace(array('"'," '","t",' '),array('"',''','',' '),$string);

returntrim($string);

}

/**

* Security filtering class - filter javascript, css, iframes, object and other unsafe parameters with high filtering level

* @param string $value The value that needs to be filtered

* @ return string

*/

function filter_script($value) {

$value=preg_replace("/(javascript: )?on(click|load|key|mouse|error|abort|move|unload|change|dblclick|move|reset|resize|submit)/i","&111n\2",$value);

$value= preg_replace("/(.*?)/si","",$value);

$value= preg_replace("/(.*?)/si","",$value);

$value= preg_replace ("//iesU", '', $value);

return$value;

}

/**

* Security filtering class - filtering HTML tags

* @param string $value The value to be filtered

* @return string

*/

function filter_html($value) {

if(function_exists('htmlspecialchars ')) return htmlspecialchars($value);

returnstr_replace(array("&", '"', "'", ""), array("&", " "", "'",""), $value);

}

/**

* Security filtering class - underline incoming data to prevent SQL injection

* @param string $value The value to be filtered

* @return string

*/

function filter_sql($value) {

$sql= array("select", 'insert', "update", "delete","'", "/*",". ./", "./","union", "into", "load_file","outfile");

$sql_re=array("","","",""," ","","","","","","","");

returnstr_replace($sql, $sql_re, $value);

}

/**

* Security filtering class - general data filtering

* @param string $value Variables that need to be filtered

* @return string|array

*/

function filter_escape($value) {

if(is_array($value)) {

foreach($value as $k => $v) {

$value[$k]= self::fliter_str($v);

}

}else {

$value= self::fliter_str($value);

}

return$value;

}

/**

* Security filtering class - string filtering to filter special harmful characters

* @param string $value The value to be filtered

* @return string

*/

function filter_str($value) {

$badstr= array("

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1055558.htmlTechArticlephp Security Filter/*ansic code-Url code table: http://www.w3school.com.cn/ tags/html_ref_urlencode.html --------------------------------------------- ---------------------------------------------...
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
How to make PHP applications fasterHow to make PHP applications fasterMay 12, 2025 am 12:12 AM

TomakePHPapplicationsfaster,followthesesteps:1)UseOpcodeCachinglikeOPcachetostoreprecompiledscriptbytecode.2)MinimizeDatabaseQueriesbyusingquerycachingandefficientindexing.3)LeveragePHP7 Featuresforbettercodeefficiency.4)ImplementCachingStrategiessuc

PHP Performance Optimization Checklist: Improve Speed NowPHP Performance Optimization Checklist: Improve Speed NowMay 12, 2025 am 12:07 AM

ToimprovePHPapplicationspeed,followthesesteps:1)EnableopcodecachingwithAPCutoreducescriptexecutiontime.2)ImplementdatabasequerycachingusingPDOtominimizedatabasehits.3)UseHTTP/2tomultiplexrequestsandreduceconnectionoverhead.4)Limitsessionusagebyclosin

PHP Dependency Injection: Improve Code TestabilityPHP Dependency Injection: Improve Code TestabilityMay 12, 2025 am 12:03 AM

Dependency injection (DI) significantly improves the testability of PHP code by explicitly transitive dependencies. 1) DI decoupling classes and specific implementations make testing and maintenance more flexible. 2) Among the three types, the constructor injects explicit expression dependencies to keep the state consistent. 3) Use DI containers to manage complex dependencies to improve code quality and development efficiency.

PHP Performance Optimization: Database Query OptimizationPHP Performance Optimization: Database Query OptimizationMay 12, 2025 am 12:02 AM

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

Simple Guide: Sending Email with PHP ScriptSimple Guide: Sending Email with PHP ScriptMay 12, 2025 am 12:02 AM

PHPisusedforsendingemailsduetoitsbuilt-inmail()functionandsupportivelibrarieslikePHPMailerandSwiftMailer.1)Usethemail()functionforbasicemails,butithaslimitations.2)EmployPHPMailerforadvancedfeatureslikeHTMLemailsandattachments.3)Improvedeliverability

PHP Performance: Identifying and Fixing BottlenecksPHP Performance: Identifying and Fixing BottlenecksMay 11, 2025 am 12:13 AM

PHP performance bottlenecks can be solved through the following steps: 1) Use Xdebug or Blackfire for performance analysis to find out the problem; 2) Optimize database queries and use caches, such as APCu; 3) Use efficient functions such as array_filter to optimize array operations; 4) Configure OPcache for bytecode cache; 5) Optimize the front-end, such as reducing HTTP requests and optimizing pictures; 6) Continuously monitor and optimize performance. Through these methods, the performance of PHP applications can be significantly improved.

Dependency Injection for PHP: a quick summaryDependency Injection for PHP: a quick summaryMay 11, 2025 am 12:09 AM

DependencyInjection(DI)inPHPisadesignpatternthatmanagesandreducesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itallowspassingdependencieslikedatabaseconnectionstoclassesasparameters,facilitatingeasiertestingandscalability.

Increase PHP Performance: Caching Strategies & TechniquesIncrease PHP Performance: Caching Strategies & TechniquesMay 11, 2025 am 12:08 AM

CachingimprovesPHPperformancebystoringresultsofcomputationsorqueriesforquickretrieval,reducingserverloadandenhancingresponsetimes.Effectivestrategiesinclude:1)Opcodecaching,whichstorescompiledPHPscriptsinmemorytoskipcompilation;2)DatacachingusingMemc

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Article

Hot Tools

SecLists

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.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

MantisBT

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.

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version