ホームページ バックエンド開発 PHPチュートリアル PHP バージョンの WeChat パブリック プラットフォーム アカウントのカスタム メニュー class_PHP チュートリアル

PHP バージョンの WeChat パブリック プラットフォーム アカウントのカスタム メニュー class_PHP チュートリアル

Jul 13, 2016 am 10:43 AM
php プラットホーム 微信 仕える 適用する 親切 カスタマイズ メニュー アカウント

WeChat パブリック プラットフォーム サービス アカウントはカスタム メニューを申請できますが、現時点では他のアカウントはカスタム メニューをサポートしていません。これは API を使用して操作できるだけでなく、メニューやパラメータをバックグラウンドで直接定義することもできます。

カスタムメニューを申し込む

サービス アカウントはカスタム メニューに適用でき、QQ を使用してログインする公開アカウントは電子メール ログインにアップグレードでき、電子メールを使用してログイン グループ メッセージを Tencent Weibo に同期できます。

PHP バージョンの WeChat パブリック プラットフォーム アカウントのカスタム メニュー class_PHP チュートリアル

WeChatパブリックプラットフォームアカウントAPIプログラム

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

// トークンを定義します
define("TOKEN", "chenxiang");//独自のTOKENに変更
define('APP_ID', '');//独自のAPPIDに変更します
define('APP_SECRET', '');//独自のAPPSECRETに変更します


$wechatObj = 新しい wechatCallbackapiTest(APP_ID,APP_SECRET);
$wechatObj->Run();


クラスwechatCallbackapiTest
{
プライベート $fromユーザー名;
プライベート $toユーザー名;
プライベート $times;
プライベート $キーワード;
プライベート $app_id;
プライベート $app_secret;


パブリック関数 __construct($appid,$appsecret)
{
# コード...
$this->app_id = $appid;
$this->app_secret = $appsecret;
}

パブリック関数 valid()
{
$echoStr = $_GET["echostr"];
if($this->checkSignature()){
echo $echoStr;
終了します;
}
}

/**
* プログラムを実行します
* @param string $value [説明]
​​*/
パブリック関数 Run()
{
$this->responseMsg();
$arr[]= "こんにちは、これは自動返信です。私は今ここにいません。何かありましたらメッセージを残してください。できるだけ早く返信します^_^";
echo $this->make_xml("text",$arr);
}

パブリック関数responseMsg()
{
$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];//返信データを返す
if (!empty($postStr)){
$access_token = $this->get_access_token();// access_token を取得します
$ This-& gt; createmenu ($ acces_token) // メニューを作成します
//$this->delmenu($access_token);//メニューを削除
$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
$this->fromUsername = $postObj->FromUserName;//送信者 ID
$this->toUsername = $postObj->ToUserName;//受信者 ID $this->keyword = trim($postObj->Content);//ユーザーから送信されたメッセージ
$ This-> 回 = 時間 () // 送信時間
; $MsgType = $postObj->MsgType;//メッセージタイプ
If($MsgType=='イベント'){
$MsgEvent = $postObj->Event;// イベント タイプを取得します
If ($MsgEvent=='subscribe') {//イベントを購読します
​​​​​​​​​ echo $this->make_xml("text",$arr);
終了します;
}elseif ($MsgEvent=='CLICK') {//クリックイベント
$ EventKey = $POSTOBJ-& GT; // メニューのカスタマイズされたキー値は、この値に従ってユーザーがクリックする内容を決定し、さまざまな情報をプッシュします
$arr[] = $EventKey;
echo $this->make_xml("text",$arr);
終了します;
}
}
}else {
echo "これは weixin API 用のファイルです!";
終了します;
}
}

/**

* access_token を取得します

​​*/

プライベート関数 get_access_token()
    {
        $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$this->app_id."&secret=".$this->app_secret;
        $data = json_decode(file_get_contents($url),true);
        if($data['access_token']){
            return $data['access_token'];
        }その他{

return "获取access_token错误";
        }
    }

/**
*メニューを作成します
* @param $access_token ACCESS_TOKENを取得しました
​​*/
パブリック関数 createmenu($access_token)
{
$url = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token=".$access_token;
$arr = array(
「ボタン」 =>array(
配列(
'name'=>urlencode("ライフクエリ"),
「sub_button」=>array(
配列(
‘name’=>urlencode("天気クエリ"),
'タイプ'=>'クリック',
'key'=>'VCX_WEATHER'
)、
配列(
‘name’=>urlencode("IDカードクエリ"),
'タイプ'=>'クリック',
「キー」=>「VCX_IDENT」
)
)
)、
配列(
「作られていることになっている」 「sub_button」=>array(
配列(
'名前' = & gt; urlencode (「音楽のスクレイピング」)、
'タイプ'=>'クリック',
'key'=>'VCX_GUAHAPPY'
)、
配列(
‘name’=>urlencode("ラッキーホイール"),
'タイプ'=>'クリック',
'キー'=>'VCX_LUCKPAN'
)
)
)、
配列(
に 「sub_button」=>array(
配列(
'name'=>urlencode("私について"),
'タイプ'=>'クリック',
「キー」=>「VCX_ABOUTME」
)、
配列(
‘name’=>urlencode("求人情報"),
'タイプ'=>'クリック',
'key'=>'VCX_JOBINFORMATION'
)
)
)
)
);
$jsondata = urldecode(json_encode($arr));
$ch =curl_init();
curl_setopt($ch,CURLOPT_URL,$url);
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_POST,1);
curl_setopt($ch,CURLOPT_POSTFIELDS,$jsondata);
curl_exec($ch);
curl_close($ch);

}

/**

*クエリメニュー
* @param $access_token ACCESS_TOKENを取得しました
​​*/

プライベート関数 getmenu($access_token)
{
# コード...
$url = "https://api.weixin.qq.com/cgi-bin/menu/get?access_token=".$access_token;
$data = file_get_contents($url);
$data を返す;
}

/**
* メニューを削除
* @param $access_token ACCESS_TOKENを取得しました
​​*/
   
    プライベート関数 delmenu($access_token)
    {
        # コード...
        $url = "https://api.weixin.qq.com/cgi-bin/menu/delete?access_token=".$access_token;
        $data = json_decode(file_get_contents($url),true);
        if ($data['errcode']==0) {
            # コード...
            true を返します;
        }その他{
            false を返します;
        }

}
       
    /**
*@param型:テキストテキスト型、ニュースグラフィック型
*@param value_arr 配列(コンテンツ),配列(ID)
*@param o_arr array(配列(タイトル、紹介文、画像、ハイパーリンク),...10項目未満),配列(項目数, ID)
​​*/
   
    プライベート関数 make_xml($type,$value_arr,$o_arr=array(0)){
        //=================xml ヘッダー============
        $con="
                    fromUsername}]]>
                    toUsername}]]>
                    {$this->回}
                    ";
                   
          //=================コンテンツの種類============
        スイッチ($type){
         
            ケース「テキスト」:
                $con.="コンテンツ>
                    {$o_arr}";
            休憩;
           
            ケース「ニュース」:
                $con.="{$o_arr[0]}
                     ";
                foreach($value_arr as $id=>$v){
                    if($id>=$o_arr[0]) ブレーク;それ以外の場合は null; // 判断数組数不超过设置数
                    $con.="
                         タイトル>
                         説明>
                        
                        
                         アイテム>";
                }
                $con.="記事>
                     {$o_arr[1]}";
            休憩;
           
        } //終了スイッチ
         
         //=================エンドリターン============
        $con.="
";
        
        $con を返します;
    }

プライベート関数 checkSignature()
    {
        $signature = $_GET["署名"];
        $タイムスタンプ = $_GET["タイムスタンプ"];
        $nonce = $_GET["nonce"];   
               
        $token = トークン;
        $tmpArr = array($token, $timestamp, $nonce);
        並べ替え($tmpArr);
        $tmpStr = implode( $tmpArr );
        $tmpStr = sha1( $tmpStr );
       
        if( $tmpStr == $signature ){
            true を返します;
        }その他{
            false を返します;
        }
    }
}

?>

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/633154.html技術記事微信公众平台サービス务号は自定菜单了を申請できますが、他の番号は自定菜单了をサポートしていませんが、これは API を使用して操作できます。また、後台定义菜单を直接行うこともできます...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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)

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

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

PHPでの後期静的結合を説明します(静的::)。 PHPでの後期静的結合を説明します(静的::)。 Apr 03, 2025 am 12:04 AM

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

PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? Apr 03, 2025 am 12:03 AM

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

一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 Apr 06, 2025 am 12:03 AM

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

H5とミニプログラムとアプリの違い H5とミニプログラムとアプリの違い Apr 06, 2025 am 10:42 AM

H5。ミニプログラムとアプリの主な違いは次のとおりです。技術アーキテクチャ:H5はWebテクノロジーに基づいており、ミニプログラムとアプリは独立したアプリケーションです。経験と機能:H5は軽量で使いやすく、機能が限られています。ミニプログラムは軽量で、インタラクティブが良好です。アプリは強力で、スムーズな経験があります。互換性:H5はクロスプラットフォーム互換性があり、アプレットとアプリはプラットフォームによって制限されています。開発コスト:H5には、開発コストが低く、中程度のミニプログラム、最高のアプリがあります。適用可能なシナリオ:H5は情報表示に適しており、アプレットは軽量アプリケーションに適しており、アプリは複雑な機能に適しています。

クロスサイトリクエストフォーファリー(CSRF)とは何ですか?また、PHPにCSRF保護をどのように実装しますか? クロスサイトリクエストフォーファリー(CSRF)とは何ですか?また、PHPにCSRF保護をどのように実装しますか? Apr 07, 2025 am 12:02 AM

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

会社のセキュリティソフトウェアがアプリケーションと競合する場合はどうすればよいですか? HUESセキュリティソフトウェアをトラブルシューティングする方法は、一般的なソフトウェアを開きませんか? 会社のセキュリティソフトウェアがアプリケーションと競合する場合はどうすればよいですか? HUESセキュリティソフトウェアをトラブルシューティングする方法は、一般的なソフトウェアを開きませんか? Apr 01, 2025 pm 10:48 PM

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

PHPで厳密なタイプ(declare(strict_types = 1);)を説明します。 PHPで厳密なタイプ(declare(strict_types = 1);)を説明します。 Apr 07, 2025 am 12:05 AM

PHPの厳格なタイプは、declare(strict_types = 1)を追加することで有効になります。ファイルの上部に。 1)関数パラメーターのタイプチェックと戻り値を強制して、暗黙の型変換を防ぎます。 2)厳格なタイプを使用すると、コードの信頼性と予測可能性を改善し、バグを減らし、保守性と読みやすさを向上させることができます。

See all articles