Table of Contents
php security filtering
Home Backend Development PHP Tutorial php security filtering_PHP tutorial

php security filtering_PHP tutorial

Jul 12, 2016 am 09:08 AM
android

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 < 60 x3c < << <

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('"'," '","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("/(.*?)< /iframe>/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 of this Website
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

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

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades Sep 12, 2024 pm 12:23 PM

In recent days, Ice Universe has been steadily revealing details about the Galaxy S25 Ultra, which is widely believed to be Samsung's next flagship smartphone. Among other things, the leaker claimed that Samsung only plans to bring one camera upgrade

Samsung Galaxy S25 Ultra leaks in first render images with rumoured design changes revealed Samsung Galaxy S25 Ultra leaks in first render images with rumoured design changes revealed Sep 11, 2024 am 06:37 AM

OnLeaks has now partnered with Android Headlines to provide a first look at the Galaxy S25 Ultra, a few days after a failed attempt to generate upwards of $4,000 from his X (formerly Twitter) followers. For context, the render images embedded below h

IFA 2024 | TCL\'s NXTPAPER 14 won\'t match the Galaxy Tab S10 Ultra in performance, but it nearly matches it in size IFA 2024 | TCL\'s NXTPAPER 14 won\'t match the Galaxy Tab S10 Ultra in performance, but it nearly matches it in size Sep 07, 2024 am 06:35 AM

Alongside announcing two new smartphones, TCL has also announced a new Android tablet called the NXTPAPER 14, and its massive screen size is one of its selling points. The NXTPAPER 14 features version 3.0 of TCL's signature brand of matte LCD panels

Vivo Y300 Pro packs 6,500 mAh battery in a slim 7.69 mm body Vivo Y300 Pro packs 6,500 mAh battery in a slim 7.69 mm body Sep 07, 2024 am 06:39 AM

The Vivo Y300 Pro just got fully revealed, and it's one of the slimmest mid-range Android phones with a large battery. To be exact, the smartphone is only 7.69 mm thick but features a 6,500 mAh battery. This is the same capacity as the recently launc

New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades New report delivers damning assessment of rumoured Samsung Galaxy S25, Galaxy S25 Plus and Galaxy S25 Ultra camera upgrades Sep 12, 2024 pm 12:22 PM

In recent days, Ice Universe has been steadily revealing details about the Galaxy S25 Ultra, which is widely believed to be Samsung's next flagship smartphone. Among other things, the leaker claimed that Samsung only plans to bring one camera upgrade

Samsung Galaxy S24 FE billed to launch for less than expected in four colours and two memory options Samsung Galaxy S24 FE billed to launch for less than expected in four colours and two memory options Sep 12, 2024 pm 09:21 PM

Samsung has not offered any hints yet about when it will update its Fan Edition (FE) smartphone series. As it stands, the Galaxy S23 FE remains the company's most recent edition, having been presented at the start of October 2023. However, plenty of

Motorola Razr 50s shows itself as possible new budget foldable in early leak Motorola Razr 50s shows itself as possible new budget foldable in early leak Sep 07, 2024 am 09:35 AM

Motorola has released countless devices this year, although only two of them are foldables. For context, while most of the world has received the pair as the Razr 50 and Razr 50 Ultra, Motorola offers them in North America as the Razr 2024 and Razr 2

Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Xiaomi Redmi Note 14 Pro Plus arrives as first Qualcomm Snapdragon 7s Gen 3 smartphone with Light Hunter 800 camera Sep 27, 2024 am 06:23 AM

The Redmi Note 14 Pro Plus is now official as a direct successor to last year'sRedmi Note 13 Pro Plus(curr. $375 on Amazon). As expected, the Redmi Note 14 Pro Plus heads up the Redmi Note 14 series alongside theRedmi Note 14and Redmi Note 14 Pro. Li

See all articles