検索
ホームページバックエンド開発PHPチュートリアルPHPトークン(トークン)の設計_PHPチュートリアル
PHPトークン(トークン)の設計_PHPチュートリアルJul 21, 2016 pm 03:53 PM
phpsessiontokenトークン存在するどうやってどうやって提出する配列欲しいデザインこれ避ける繰り返す



目標を達成する方法:

繰り返しの送信を回避するには?
SESSION に配列を保存します。バックグラウンド処理中に、この配列にトークンが存在するかどうかを最初に確認します。 , 繰り返し送信であることを示します。
ソースを確認する方法は?
オプションで、このトークンが生成されると、送信時に他の人が HTML (トークンのコピー) をコピーすると、理論的にはトークンに次の情報が追加されます。 session_id が現在の session_id と等しくない場合、この送信は外部送信であると判断できます。
実行するアクションを一致させるにはどうすればよいですか?
トークン化するときに、このトークンのアクション名をトークンに書き込む必要があります。を処理するときに、このアクションを解決して比較するだけです。
以前に書いた GToken は、上記の 2 番目の点を満たしていませんでした。今日、それを修正して機能 2 を追加しました。個人的には、これは大丈夫だと思います。何か無理があるような気がしますので、教えてください

ネットで暗号化の方法を見つけたので、




コードをコピーしました。次のように:

class GEncrypt extends GSuperclass { protected static function keyED($txt,$encrypt_key){
$encrypt_key = md5($encrypt_key);
$tmp = " " ; t, $i,1) ^ substr($encrypt_key,$ctr,1); function encrypt($txt,$key){
//$encrypt_key = d(0,32000));
ctr=0; $tmp = "";
for ($i=0;$i if ($ctr==strlen($encrypt_key)) $ctr=0;
$tmp.= substr($encrypt_key,$ctr,1) . (substr($txt,$i,1) ^ substr($encrypt_key,$ctr,1)); ); ";
$tmp.= (substr($txt ,$i,1) ^ $md5)

GToken.inc.php
メソッド:

a,granteToken パラメーター: formName、アクション名、key は暗号化/復号化キーです。
encryption(formName:session_id)

b の形式で文字列を返します。 isToken パラメータ: token は、grantToken、formName、アクション名によって生成された結果であり、fromCheck がオリジンをチェックするかどうか、また、true の場合は、トークン内の session_id が現在の session_id、dropToken、と一致するかどうかも判断します。アクションが正常に実行された後、この関数を呼び出し、このトークンをセッションに記録します



コードをコピーします コードは次のとおりです:

/**
* 原則: トークンの割り当てをリクエストするときは、一意のトークン、base64(time + rand + action) を割り当てる方法を見つけてください。
* 送信された場合は、このトークンが以前に使用されたことを示すためにこのトークンを記録します。重複送信を避けるためです。
*
*/
class GToken {

/**
*現在のすべてのトークンを取得します*/
public static function getTokens(){
$tokens = $_SESSION[GConfig::SESSION_KEY] _トークン ]; 
if (empty($tokens) && !is_array($tokens)) {
$tokens = array(); 
}
$tokens を返します。 
}

/**
*新しいトークンを生成します*/

public static function granteToken($formName,$key = GConfig::ENCRYPT_KEY ){
$token = GEncrypt::encrypt($formName.":".session_id() ,$キー); 
$token を返す; 
}

/**
* トークンを削除すると、実際にはセッション内の配列に要素が追加され、データの繰り返しの送信を避けるためにそのトークンが以前に使用されたことを示します。
**/
public static function dropToken($token){
$tokens = self::getTokens(); 
$tokens[] = $token; 
GSession::set(GConfig::SESSION_KEY_TOKEN ,$tokens); 
}

/**️ medium 追加 session_id が現在の session_id と同じかどうか
* @param string $key 暗号化キー
* @return boolean
*/

public static function isToken($token,$formName,$fromCheck = false,$key = GConfig::ENCRYPT_KEY){
$tokens = self::getTokens(); 

if (in_array($token,$tokens)) //如果存在、说明是使用过的トークン
return false; 

$source = split(":", GEncrypt::decrypt($token,$key)); 

if($fromCheck)
return $source[1] == session_id() && $source[0] == $formName; 
else
return $source[0] == $formName; 
}
}
?> 

例:

まずは$_POSTからトークンを取り出してisTokenで判定

PHPトークン(トークン)の設計_PHPチュートリアル このファイルをダウンロードすれば問題なさそうです
一致するアクションかどうかを判定したい場合はisTokenのformNameを変更すればOKです。実行後は正常に動作しますが、一致するものはありません。これで成功したことがわかります。

繰り返しの送信を回避できるかどうかは検証していません。あとはソースチェックを行うかどうかです。は正常に動作しています。
上記を入力します。 例によって生成された HTML をローカル Web ページにコピーし (さまざまなドメインの目的を達成するため)、それを実行し、ソースが不明であることを確認し、アクションを実行しません (isToken の 3 番目のパラメーターが必要です)。
isToken を変更します。3 番目のパラメータが false に設定され、送信され、指定されたアクションが実行されます。

さて、これまでのところ、どこかにバグがあるかどうかはわかりません。長期使用するとデバッグや変更が遅くなります



http://www.bkjia.com/PHPjc/318686.html

tru​​ehttp://www.bkjia.com/PHPjc/318686.html技術記事目標を達成する方法: 繰り返しの送信を回避するには? 配列は、正常に送信されたトークンを保存する必要があります。まず、トークンがこの配列にあるかどうかを確認します。
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php怎么设置implode没有分隔符php怎么设置implode没有分隔符Apr 18, 2022 pm 05:39 PM

在PHP中,可以利用implode()函数的第一个参数来设置没有分隔符,该函数的第一个参数用于规定数组元素之间放置的内容,默认是空字符串,也可将第一个参数设置为空,语法为“implode(数组)”或者“implode("",数组)”。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。