WeChat PHPカスタムメニュー
WeChat パブリック プラットフォームでテスト アカウントを申請しました。これをフォローした後、WeChat ID を使用してテスト アカウントにメッセージを送信し、テスト アカウントから正しい応答を取得したいと思います。 WeChat のカスタム メニューを実装するには、* を使用してテスト アカウントの appid とシークレットを置き換えます。問題は何ですか?
<?php/** * wechat php test *///define your tokendefine("TOKEN", "weixin");$token_url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=***&secret=***";$data = "{ "button":[ { "type":"click", "name":"今日歌曲", "key":"V1001_TODAY_MUSIC" }, { "type":"click", "name":"歌手简介", "key":"V1001_TODAY_SINGER" }, { "name":"菜单", "sub_button":[ { "type":"click", "name":"hello word", "key":"V1001_HELLO_WORLD" }, { "type":"click", "name":"赞一下我们", "key":"V1001_GOOD" }] }] }";$wechatObj = new wechatCallbackapiTest();$wechatObj->post($wechatObj->get_access_token(), $data);class wechatCallbackapiTest{ public function get_access_token(){ $json=http_request_json($token_url); $data=json_decode($json,true); if($data['access_token']){ return $data['access_token']; }else{ return "获取access_token错误"; } } public function http_request_json($url){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL,$url); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $result = curl_exec($ch); curl_close($ch); return $result; } public function post($access_token, $jsonData){ $ch = curl_init("https://api.weixin.qq.com/cgi-bin/menu/create?access_token=".$access_token) ; curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($ch, CURLOPT_POSTFIELDS,$jsonData); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json')); $result = curl_exec($ch) ; curl_close($ch) ; return $result; }}?>
ディスカッションへの返信 (解決策)
もう 1 つの質問があります。この種の WeChat PHP 開発をどのようにデバッグすればよいですか。また、サーバー上のログ (エコー値と同様) はどこで確認できますか? = を使用してサーバーを構築しました ここには一重引用符が必要で、もう 1 つの http_request_json は $this->http_request_json に変更されましたが、それでも動作しませんでした。これら 2 つの問題を変更しました
メニューには例があったことを覚えています。公式ドキュメント
デバッグに関しては、エラー番号はあなたが判断するのに便利です
メニューが公式にあることを覚えています ドキュメントには例があります
デバッグに関しては、公式のエラー番号がスローされるので、判断してください
WeChat 公式がスローしたエラーは次のとおりです。私の経験によると、API 呼び出しのたびにコールバックがあるはずです...コールバック
もう 1 つの質問があります。この種の WeChat PHP 開発をデバッグするにはどうすればよいですか? サーバー上のどこでログ (エコーに似た値) を見ることができますか? Out of nowhere を使用してサーバーを構築しました。私は個人的に PHP が好きです。http://www.ihuxu.com でもっと交流を深めたいと思っています。
1. まずこのメソッドをチェックして、トークン値が取得されているかどうかを確認します。
$wechatObj->get_access_token()
2. カスタムメニューを送信すると、どのようなデータが返されますか?エラー コードを使用して、何が問題だったのかを調べます。
明らかに、このメソッドでトークン値を取得する方法がわかりません。 $token_url はどこから来たのでしょうか?
public function get_access_token(){ $json=http_request_json($token_url); $data=json_decode($json,true); if($data['access_token']){ return $data['access_token']; }else{ return "获取access_token错误"; } }
もう一つの質問ですが、この種の WeChat PHP 開発をデバッグするにはどうすればよいですか? サーバー上のログ (エコー値と同様) はどこで確認できますか? Out of nowhere を使用してサーバーを構築しました。私は個人的に PHP が好きです。http://www.ihuxu.com でもっと交流を深めたいと思っています。
現在の問題は、WeChat の公式 Web サイトでデバッグしたところ、プロンプトは成功しましたが、クライアントではそれが表示されないことです
1. まず、このメソッドをチェックして、トークン値が取得されているかどうかを確認します。
$wechatObj->get_access_token()
2. カスタムメニューを送信すると、どのようなデータが返されますか?エラー コードを使用して、何が問題だったのかを調べます。
明らかに、このメソッドでトークン値を取得する方法がわかりません。 $token_url はどこから来たのでしょうか?
public function get_access_token(){ $json=http_request_json($token_url); $data=json_decode($json,true); if($data['access_token']){ return $data['access_token']; }else{ return "获取access_token错误"; } }
token_url は私の投稿の上部にあり、宣言されています
実行したリターンが成功した場合は 24 時間かかりますが、フォローを解除して再度フォローして確認することもできます
実行した場合のリターンは成功しました。24 時間かかるか、フォローを解除して再度フォローして確認してください
サーバー上で直接印刷しているので、問題はわかっていますが、変更方法がわかりません
うわー
これが私が今作成したものですメニューメソッドを印刷して確認しました。トークンは正しく取得されましたが、システム印刷は
{"errcode":-1,"errmsg":"system error"} です。このエラーコードは次のとおりです。 WeChat 公式 私が見た説明では、システムがビジーであるということでしたが、これは問題ではないと思います。なぜなら、誰かが Java を使用して作成しても問題ないからです。PHP の記述にまだ問題があると思います。助けて?
public function post($token, $jsonData){ echo $token; $MENU_URL = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=".$token; $ch = curl_init() ; curl_setopt($ch, CURLOPT_URL, $MENU_URL); curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)'); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_AUTOREFERER, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $jsonData); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($ch) ; if (curl_errno($ch)) { echo 'Error'.curl_error($ch); } curl_close($ch) ; echo $result; //var_dump($result); return $result; }
//创建菜单function createMenu($data){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=".ACCESS_TOKEN); curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)'); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_AUTOREFERER, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $data); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $tmpInfo = curl_exec($ch); if (curl_errno($ch)) { return curl_error($ch); } curl_close($ch); return $tmpInfo;}
あなた これと私の違いは何ですか? $token は、他の場所から取得した変数です。グローバル変数を定義して、トークンの値を記録する必要があります。違いはありませんね?
还有一个问题,我该怎么调试这种微信的php开发,在服务器上哪个地方可以看到日志(就是类似echo的值)?我是用xampp搭建的服务器 error_log("内容",3,"log.txt");
第一个参数是你要输入的内容,
第二个参数不要改,
第三个参数是日志的名称,你可以加一下路径 如"c:\log.txt"你就可以在C盘看到这个文件了
微信菜单,我自己写了个小工具,可以用的 可以用,要的话加QQ970871674
你是不是执行的时候也echo了?
你是不是执行的时候也echo了?
我重新贴下完整代码吧
post($wechatObj->get_access_token(), $data);//$wechatObj->responseMsg();class wechatCallbackapiTest{ public function valid() { $echoStr = $_GET["echostr"]; //valid signature , option if($this->checkSignature()){ echo $echoStr; exit; } } public function get_access_token(){ $json=$this->http_request_json("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=***&secret=***"); $data=json_decode($json,true); if($data['access_token']){ return $data['access_token']; }else{ return "获取access_token错误"; } } public function http_request_json($url){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $result = curl_exec($ch); curl_close($ch); return $result; } public function post($token, $jsonData){ echo $token; $MENU_URL = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=".$token; $ch = curl_init() ; curl_setopt($ch, CURLOPT_URL, $MENU_URL); curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)'); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_AUTOREFERER, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $jsonData); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($ch) ; if (curl_errno($ch)) { echo 'Error'.curl_error($ch); } curl_close($ch) ; echo $result; return $result; }?>
这就是现在代码了,除了真实的appid和secret被我用***代替了
解决了,是菜单中的中文导致的,将文件另存为“UTF-8 无BOM编码格式”就行了,感谢大家

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の 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.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

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

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

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

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

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