WeChatパブリックプラットフォーム開発 - データベース操作_PHPチュートリアル
【PHP WeChatパブリックプラットフォーム開発シリーズ】
01. WeChatインターフェースを設定する
02. パブリックプラットフォームのサンプルコード解析
03. サブスクリプションイベント(subscribe)処理
04. 簡易返信機能の開発
05.天気予報機能開発
06. 翻訳機能開発
07. チャットボット機能開発
08.カスタマイズメニュー機能
09. データベース操作
この記事のURL: http://www.phpchina.com/archives/view-43411-1.html
このシリーズは、PHPChina の特別招待著者である @David_Tang によって寄稿されたものです。転載する場合は、著者の情報とこの記事のアドレスを明記してください。
1. はじめに
先ほど説明した機能開発は、データベースを操作せずにAPIを呼び出すだけで完了します。その後の高度な機能の開発ではデータベースを使用する必要があるため、この記事では読者の参考として MySQL データベースの操作について簡単に紹介します。
2. アイデア分析
Baidu Developer Center は、強力なクラウド データベース (MySQL、MongoDB、Redis を含む) を提供します。このチュートリアルでは、WeChat とデータベース間の対話を実現するための使い慣れた MySQL データベースの操作をデモンストレーションします。
BAE アプリケーションでクラウド データベースを使用するのは非常に簡単です。データベース リスト内の名前は、データベースに接続するときの dbname です。ユーザー名、パスワード、接続アドレス、およびポートは、アプリケーションの環境変数を通じて取得されます。
標準の PHP Mysql または PHP Mysqli 拡張機能を使用してデータベースにアクセスできます。これら 2 つの拡張機能は BAE の PHP ですでに提供されており、アプリケーションで直接使用できます。
公式ドキュメントについては、http://developer.baidu.com/wiki/index.php?title=docs/cplat/rt/mysql
を参照してください。3. BAE MySQL データベースを作成します
3.1 Baidu 開発者センターにログイン -> 管理センター -> アプリケーションを選択 -> MySQL (クラウド データベース) -> データベースを作成
注: 各アプリケーションには、1G の無料割り当てを享受できるデータベースが 1 つだけあり、他のデータベースは無料割り当ての割引を受けられません。このオファーは、無料クォータを使用したデータベースが削除された場合にのみ再度使用できます。
3.3 作成成功ここでデータベースの名前 (dbname) が確認できます。これは後で使用します。
「phpMyadmin」をクリックしてデータベースにアクセスします。
新しいデータテーブルを作成し、テーブル名とフィールド数を入力して「実行」をクリックするとテーブルが作成されます。
フィールド名とフィールドタイプを入力したら、下の「保存」をクリックするとテーブルの作成が完了します。
id フィールドを主キーとして変更し、AUTO_INCREMENT を追加し、from_user フィールドを一意 (UNIQUE) に変更して、テーブルの変更を完了します。
リーリー


4. 公式サンプル(PHP MySQL)
BAE が公式に提供するデモ (PHP MySQL) の例は次のとおりです:
mysql/basic.php ファイルの内容
リーリー


リーリー
テスト使用:
5. 呼び出し可能な関数形式(PHP MySQL)に修正します
5.1 データテーブルの作成
リーリー
5.2 データを挿入するリーリー


リーリー


//修改数据 function _update_data($sql){ if(!mysql_query($sql)){ return 0; //更新数据失败 }else{ if(mysql_affected_rows()>0){ return 1; //更新成功; }else{ return 2; //没有行受到影响 } } }

5.5 检索数据
//检索数据 function _select_data($sql){ $ret = mysql_query($sql) or die('SQL语句有错误,错误信息:'.mysql_error()); return $ret; }
5.6 删除数据表
//删除表 function _drop_table($sql){ mysql_query($sql) or die('删除表失败,错误信息:'.mysql_error()); return "删除表成功"; }
将以上函数和连接数据库的代码结合起来,生成mysql_bae.func.php 文件,供下面测试使用。
六、测试MySQL 函数使用
6.1 新建文件dev_mysql.php 在同一目录下并引入mysql_bae.func.php 文件
require_once './mysql_bae.func.php';
6.2 测试创建表
将上面使用phpMyAdmin 创建的test_mysql 表删除,测试语句如下:

//创建表 $create_sql = "CREATE TABLE IF NOT EXISTS `test_mysql` ( `id` int(11) NOT NULL AUTO_INCREMENT, `from_user` varchar(40) DEFAULT NULL, `account` varchar(40) DEFAULT NULL, `password` varchar(40) DEFAULT NULL, `update_time` datetime DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `from_user` (`from_user`) )"; echo _create_table($create_sql);

测试正确结果:
到phpMyAdmin中查看
故意将SQL语句写错
测试错误结果:
6.3 测试插入数据
测试语句如下:

//插入数据 $insert_sql = "insert into test_mysql(from_user, account, password, update_time) values('David','860510', 'abcabc', '2013-09-29 17:14:28')"; $res = _insert_data($insert_sql); if($res == 1){ echo "插入成功"; }else{ echo "插入失败"; }

测试结果:
6.4 测试更新数据
测试语句如下:

//更新数据 $update_sql = "update test_mysql set account = 860512 where account = 860510"; $res = _update_data($update_sql); if($res == 1){ echo "更新成功"; }elseif($res == 0){ echo "更新失败"; }elseif($res == 2){ echo "没有行受到影响"; }

测试结果:
再次更新:
6.5 测试删除数据
测试语句如下:

//删除数据 $delete_sql = "delete from test_mysql where account = 860512"; $res = _delete_data($delete_sql); if($res == 1){ echo "删除成功"; }elseif($res == 0){ echo "删除失败"; }elseif($res == 2){ echo "没有该条记录"; }

测试结果:
再次删除:
6.6 测试检索数据
再次执行上面的插入操作做检索测试,测试语句如下:

//检索数据 $select_sql = "select * from test_mysql"; $result = _select_data($select_sql); while($rows = mysql_fetch_array($result,MYSQL_ASSOC)){ echo $rows[id]."--".$rows[from_user]."--".$rows[account]."--".$rows[password]."--".$rows[update_time]; echo "<br />"; }

测试结果:
6.7 测试删除表
测试语句如下:
//删除表 $drop_sql = "drop table if exists test_mysql"; echo _drop_table($drop_sql);
测试结果:
MySQL 函数测试全部成功。
七、实现与微信的交互(Mysql 扩展)
保证数据库中存在test_msyql表,这里测试微信对MySQL数据库的增删改查操作,不考虑特殊情况,只按照下面的方法测试:

1. 绑定+账户+密码 如:绑定+860512+abc123 2. 查询 如:查询 3. 修改+旧密码+新密码 如:修改+abc123+123456 4. 删除 如:删除

7.1 引入mysql_bae.func.php 文件
//引入数据库函数文件 require_once 'mysql_bae.func.php';
7.2 前置操作
A. 将输入的语句拆分成数组,以“+”号分隔
$keywords = explode("+",$keyword);
B. 获取当前时间
//获取当前时间 $nowtime=date("Y-m-d G:i:s");
C. 判断用户是否已经绑定

//判断是否已经绑定 $select_sql="SELECT id from test_mysql WHERE from_user='$fromUsername'"; $res=_select_data($select_sql); $rows=mysql_fetch_array($res, MYSQL_ASSOC); if($rows[id] <> ''){ $user_flag='y'; }

7.3 测试插入操作
测试代码:

if(trim($keywords[0] == '绑定')){ if($user_flag <> 'y'){ $insert_sql="INSERT INTO test_mysql(from_user, account, password, update_time) VALUES('$fromUsername','$keywords[1]','$keywords[2]','$nowtime')"; $res = _insert_data($insert_sql); if($res == 1){ $contentStr = "绑定成功"; }elseif($res == 0){ $contentStr = "绑定失败"; } }else{ $contentStr = "该账户已绑定"; } }

测试结果:
7.4 测试查询操作
测试代码:

if(trim($keywords[0] == '查询')){ $select_sql="SELECT * FROM test_mysql WHERE from_user='$fromUsername'"; $select_res=_select_data($select_sql); $rows=mysql_fetch_assoc($select_res); if($rows[id] <> ''){ $contentStr="账户:$rows[account]\n"."密码:$rows[password]\n"."From_user:$rows[from_user]\n"."更新时间:$rows[update_time]"; }else{ $contentStr="您还未绑定账户,查询不到相关信息,请先绑定,谢谢!"; } }

测试结果:
7.5 测试更新操作
测试代码:

if(trim($keywords[0] == "修改")){ $old_password=$keywords[1]; $new_password=$keywords[2]; $select_password_sql="SELECT * FROM test_mysql WHERE from_user='$fromUsername'"; $select_res=_select_data($select_password_sql); $rows=mysql_fetch_assoc($select_res); if($old_password == $rows[password]){ $update_sql="UPDATE test_mysql SET password='$new_password' WHERE from_user='$fromUsername'"; $res = _update_data($update_sql); if($res == 1){ $contentStr = "修改成功"; }elseif($res == 0){ $contentStr = "修改失败"; } }else{ $contentStr = "原密码有误,请确认后重试"; } }

测试结果:
7.6 测试删除操作
测试代码:

if(trim($keywords[0] == "删除")){ $delete_sql="DELETE FROM test_mysql WHERE from_user='$fromUsername'"; $res = _delete_data($delete_sql); if($res == 1){ $contentStr = "删除成功"; }elseif($res == 0){ $contentStr = "删除失败"; } }

测试结果:
与微信的交互测试成功。
八、PHP Mysqli 扩展,封装成类
将Mysqli 扩展封装成类使用,代码如下:

<?php require_once 'includes/configure.php'; class MySQLi_BAE{ private $mysqli; private $host; private $user; private $password; private $port; private $database; //在类之外访问私有变量时使用 function __get($property_name){ if(isset($this->$property_name)){ return($this->$property_name); }else{ return(NULL); } } function __set($property_name, $value){ $this->$property_name=$value; } function __construct(){ /*从平台获取查询要连接的数据库名称*/ $this->database = MYSQLNAME; /*从环境变量里取出数据库连接需要的参数*/ $this->host = getenv('HTTP_BAE_ENV_ADDR_SQL_IP'); $this->user = getenv('HTTP_BAE_ENV_AK'); $this->password = getenv('HTTP_BAE_ENV_SK'); $this->port = getenv('HTTP_BAE_ENV_ADDR_SQL_PORT'); $this->mysqli = new mysqli($this->host, $this->user, $this->password, $this->database, $this->port); if($this->mysqli->connect_error){ die("Connect Server Failed:".$this->mysqli->error); } $this->mysqli->query("set names utf8"); } //dql statement function execute_dql($query){ $res = $this->mysqli->query($query) or die("操作失败".$this->mysqli->error); return $res; //$this->mysqli->close(); } //dml statement function execute_dml($query){ $res = $this->mysqli->query($query) or die("操作失败".$this->mysqli->error); if(!$res){ return 0;//失败 }else{ if($this->mysqli->affected_rows > 0){ return 1;//执行成功 }else{ return 2;//没有行受影响 } } //$this->mysqli->close(); } } ?>

九、测试类的使用
9.1 测试DML操作
测试代码:

<?php require_once "MySQLi_BAE.class.php"; $mysqli_BAE=new MySQLi_BAE(); //**************dml******************* $sql="insert into test_mysql (from_user, account, password, update_time) values('David','860510', 'abcabc', '2013-09-27 17:14:28')"; //$sql="update test_mysql set account = 860512 where account = 860510"; //$sql="delete from test_mysql where account = 860512"; $res=$mysqli_BAE->execute_dml($sql); if($res==0){ echo "执行失败"; }elseif($res==1){ echo "执行成功"; }else{ echo "没有行数影响"; } ?>

测试结果:
9.2 测试DQL操作
测试代码:

<?php require_once "MySQLi_BAE.class.php"; $mysqli_BAE=new MySQLi_BAE(); //**************dql****************** $sql="select * from test_mysql"; $res=$mysqli_BAE->execute_dql($sql); while($row=$res->fetch_row()){ foreach($row as $key=>$val){ echo "$val--"; } echo '<br/>'; } $res->free(); ?>

测试结果:
十、实现与微信的交互(Mysqli 扩展)
10.1 前置操作
A. 引入MySQLi_BAE.class.php 文件
//引入数据库函数文件 require_once "MySQLi_BAE.class.php";
B. 实例化对象
public function __construct() { $this->mysqli_BAE=new MySQLi_BAE(); }
10.2 测试插入操作
测试代码:
$insert_sql="INSERT INTO test_mysql(from_user, account, password, update_time) VALUES('$fromUsername','$keywords[1]','$keywords[2]','$nowtime')"; $res = $this->mysqli_BAE->execute_dml($insert_sql);
测试结果:
10.3 测试查询操作
测试代码:
$select_sql="SELECT * FROM test_mysql WHERE from_user='$fromUsername'"; $select_res=$this->mysqli_BAE->execute_dql($select_sql); $rows=$select_res->fetch_array(MYSQLI_ASSOC);
测试结果:
10.4 测试更新操作
测试代码:
$update_sql="UPDATE test_mysql SET password='$new_password' WHERE from_user='$fromUsername'"; $res = $this->mysqli_BAE->execute_dml($update_sql);
测试结果:
10.5 测试删除操作
测试代码:
$delete_sql="DELETE FROM test_mysql WHERE from_user='$fromUsername'"; $res = $this->mysqli_BAE->execute_dml($delete_sql);
测试结果:
与微信交互测试成功。

ホット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で後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。

この記事では、中国のOUYI OKXアプリの安全なダウンロードに関する詳細なガイドを提供します。国内のアプリストアの制限により、ユーザーはOUYI OKXの公式Webサイトからアプリをダウンロードするか、公式Webサイトが提供するQRコードを使用してスキャンおよびダウンロードすることをお勧めします。ダウンロードプロセス中に、公式Webサイトのアドレスを確認し、アプリケーションの許可を確認し、インストール後にセキュリティスキャンを実行し、2要素の検証を有効にしてください。 使用中は、地方の法律や規制を遵守し、安全なネットワーク環境を使用し、アカウントのセキュリティを保護し、詐欺に対して警戒し、合理的に投資してください。 この記事は参照のみであり、投資のアドバイスを構成していません。

PHP8では、一致式は、式の値に基づいて異なる結果を返す新しい制御構造です。 1)Switchステートメントに似ていますが、実行ステートメントブロックの代わりに値を返します。 2)一致式の式は厳密に比較され、セキュリティが向上します。 3)スイッチステートメントの脱落の可能性を回避し、コードのシンプルさと読みやすさを向上させます。

互換性の問題と企業のセキュリティソフトウェアとアプリケーションのトラブルシューティング方法。多くの企業は、イントラネットセキュリティを確保するためにセキュリティソフトウェアをインストールします。ただし、セキュリティソフトウェアが時々...

この記事では、2025年に更新されたBinance Virtual Currencyの売買に関する簡単なガイドを提供し、Binanceプラットフォームでの仮想通貨取引の操作手順を詳細に説明します。このガイドは、フィアット通貨購入USDT、他の通貨の通貨取引購入(BTCなど)、および市場取引や制限取引を含む販売業務をカバーしています。 さらに、このガイドは、Fiat Currency取引の支払いセキュリティやネットワーク選択などの重要なリスクを特に思い出させ、ユーザーが安全かつ効率的にバイナンストランザクションを実施するのに役立ちます。 この記事を通して、Binanceプラットフォームで仮想通貨を売買するスキルをすばやく習得し、トランザクションリスクを減らすことができます。

PHPでは、予測不可能なトークンを使用して、CSRF攻撃を効果的に防ぐことができます。特定の方法には次のものが含まれます。1。フォームのCSRFトークンを生成および埋め込みます。 2.リクエストを処理するときにトークンの有効性を確認します。
