ホームページ php教程 php手册 php中防xss攻击和sql注入详解

php中防xss攻击和sql注入详解

May 25, 2016 pm 04:47 PM
php SQLインジェクション xss攻撃を防ぐ

本文章简单的讲述了关于在php中防xss攻击和sql注入详解,有需了解的朋友可以参考一下下.

XSS攻击实例代码如下:

任意执行代码  
    文件包含以及CSRF.  
}
ログイン後にコピー

关于SQL攻击有很多文章还有各种防注入脚本,但是都不能解决SQL注入的根本问题

实例代码如下:

<?php  
    mysql_connect("localhost","root","123456")or die("数据库连接失败!");  
    mysql_select_db("test1");  
    $user=$_post[&#39;uid&#39;];  
    $pwd=$_POST[&#39;pass&#39;];  
    if(mysql_query("SELECT * from where  
    admin  
    = `username`=&#39;$user&#39; or `password`=&#39;$pwd&#39;"){  
    echo "用户成功登陆..";  
    } eles {  
    echo "用户名或密码出错";  
    }  
?>
ログイン後にコピー

很简单的一段代码,功能是用于检测用户名或密码是否正确,可是在一些恶意攻击者中提交一些敏感代码.后果可想而知.. post判断注入的方式有2种.

1.在form表单的文本框输入 "or'1'=1"或者"and 1=1"

在查询数据库的语句就应该是:

SELECT admin from where login = `user`=''or'1'=1' or `pass`='xxxx'

当然也不会出现什么错误,因为or在sql的语句中代表和,或的意思.当然也会提示错误.

当时我们已经发现了可以执行SQL语句之后就可以查询当前表的所有信息.例如:正确的管理员账户和密码进行登录入侵..

修复方式1:

使用javascript脚本过滤特殊字符(不推荐,指标不治本)

如果攻击者禁用了javascript还是可以进行SQL注入攻击..

修复方式2:

使用mysql的自带函数进行过滤.

实例代码如下:

<?php  
    // 省略连接数据库等操作..  
    $user=mysql_real_escape_string($_POST[&#39;user&#39;]);  
    mysql_query("select * from admin whrer `username`=&#39;$user&#39;");  
?>
ログイン後にコピー

既然前面说道了xss攻击,我们再来说说XSS攻击以及防范吧..

提交表单实例代码如下:

<form method="post" action="">  
    <intup tyep="text" name="test">  
    <intup tyep="submit" name="sub" value="提交">  
</form>
ログイン後にコピー

接收文件实例代码如下:

if(emptyempty($_POST[&#39;sub&#39;])){  
    echo $_POST[&#39;test&#39;];  
}
ログイン後にコピー

很简单的一段代码,在这里只是模拟了下使用场景..

加入攻击者提交实例代码如下:

<script>alert(document.cookie);</script>

在返回的页面就应该显示当前页面的cookie信息.

我们可以运用到某些留言板上(提前是没过滤的),然后当管理员审核改条信息时盗取COOKIE信息,并发送到攻击者的空间或者邮箱..攻击者可以使用cookie修改器进行登陆入侵了..

当然解决方案也有很多..下面就介绍一个最常用的方式吧.

修复方案1:使用javascript进行转义

修复方案2:使用php内置函数进行转义

实例代码如下:

if(emptyempty($_POST[&#39;sub&#39;])){  
    $str=$_POST[&#39;test&#39;];  
    htmlentities($srt);  
    echo $srt;  
}
ログイン後にコピー

好了,关于SQL注入攻击和XSS攻击的案例与修复方法就讲的差不多了.


文章地址:

转载随意^^请带上本文地址!

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

See all articles