php mysqliの前処理パラメータをバインドする方法
/** * php中预处理执行sql * $sql[String] sql语句 * $args[array] 参数 */ public function exeSql($sql,$args){ $mysqli_stmt=$mysqli->prepare($sql); //由于$sql由调用者传入,所以sql语句和参数个数都不确定 //疑问1:怎么获取参数类型呢?php中有没有相应的函数呢? //如果没有我用如下方法:getParamTypeStr($arr)是否可行呢?有什么好的建议吗? //疑问2:怎么绑定参数呢?如下为参数个数确定时的绑定方法。 //$mysqli_stmt->bind_param("ssi","xx","xx",20); $mysqli_stmt->execute(); $mysqli->close(); } private function getParamTypeStr($arr){ $count = count($arr); $typestr = ""; for($i = 0; $i<$count; $i++){ $type = gettype($arr[$i]); switch($type){ case "integer": $typestr.= "i"; break; case "float": case "double": $typestr.= "d"; break; case "string": $typestr.= "s"; break; } } return $typestr; }
Java では次の方法で実装されることは知っています:
//java中预处理执行sql public void exeSql(String sql,Object[] args){ PreparedStatement preparedStatement = connection.prepareStatement(sql); for(int i =0;i<args.length;i++){ preparedStatement.setObject(i+1, args[i]); } preparedStatement.executeUpdate(); connection.close(); }
上記の 2 つの質問に答えるのを手伝ってくれる人はいますか? 私はちょうど PHP に切り替えてドキュメントを読んだところですが、リフレクションについて説明していました。友人の中には、SQL の「?」を置き換えることで詳細なガイダンスを提供できることを期待しており、コア コードを提供するのが最善であると述べた人もいます。どうもありがとうございます!
ディスカッションへの返信 (解決策)
2.
$callback = array($mysqli_stmt, 'bind_param');// 将参数类型描述加入数组array_unshift($args, getParamTypeStr($args)); call_user_func_array($callback, $args);// 它的调用类似:$mysqli_stmt->bind_param(getParamTypeStr($args), $args[0], $args[1], $args[2] ...);
mysqli のこの関数は、非常に直感的に使用することができます
http:/ /www.php.net/manual/en/pdostatement.bindparam.php
自分で書いた PHP PDO クラスがあります。 直接使用できます。
<?php/* 连接数据库类 MysqlConnect */class MysqlConnect{ private $dbhost=null; private $dbuser=null; private $dbpwd=null; private $dbname=null; private $dbport=null; private $ifpdo=null; private $dburi=null; private $handler=null; function __construct($dbhost,$dbuser,$dbpwd,$dbname,$dbport,$ifpdo,$dburi){ $this->dbhost=$dbhost; $this->dbuser=$dbuser; $this->dbpwd=$dbpwd; $this->dbname=$dbname; $this->dbport=$dbport; $this->ifpdo=$ifpdo; $this->dburi=$dburi;//PDO的URI参数,可以查手册 if($this->ifpdo==1){//表示调用PDO来操作数据库 $this->handler=$this->CreatePdo(); }elseif($this->ifpdo==0){//这里可以写MYSQLI的方法 $this->handler=null; } } /* ----------------这里是入口--------------------- */ //@param sql:外部调用时传递的完整SQL语句 //@param bindArray:绑定的参数数组,与sql语句有关,如果没有PDO占位符此处为空 //@param action:传递操作参数,"select"/"update"/"delete"/"insert" public function exeSql($sql,$bindArray=array(),$action=""){ $stmt=$this->handler->prepare($sql); $stmt->execute($bindArray); switch($action){ case "select": return $stmt->fetch(PDO::FETCH_ASSOC); break; case "selectAll": return $stmt->fetchAll(PDO::FETCH_ASSOC); break; case "update": case "delete": return $stmt->rowCount(); break; case "insert": return $this->handler->lastInsertId(); break; case "count": return $stmt->rowCount(); default: return ""; } } public function query($sql){ return $this->handler->query($sql); } private function CreatePdo(){ try{ $handler=new PDO($this->dburi,$this->dbuser,$this->dbpwd); $handler->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); return $handler; }catch(PDOException $e){ $e->getMessage(); $this->handler=null; } } private function __get($args){ if($args=='handler'){ return $this->handler; } }}require(NEO_A_P.'\data\sqlconfig.php');//这里是sql的连接文件,下面创建对象的时候需要的变量就是这个文件里要有的$handler=new MysqlConnect($dbhost,$dbuser,$dbpwd,$dbname,$dbport,$ifpdo,$dburi);?>
私が書いた PHP PDO クラスがあります。直接使用できます:
PHP コード?123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 57585960616263646566676869707172737475767778...
呼び出すときは、このクラスを含めるように直接要求すると、$handler が操作オブジェクトになります
上の階の熱心な友人 2 人に感謝します。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。
