PHP は正しいですが、WeChat に接続すると配列のみが返されます。
$result = mysql_query($sql, $link) // クエリ文を実行します
$res=array()
while($row = mysql_fetch_array() $result)){
if(condition){
$res[] = $row["title"].$row["answer"]
}
}
return $ res;
?>
これを使用すると、PHP は正しいですが、WeChat を受信すると、別の返信配列になります
ディスカッション (解決策) に返信
データを文字列に連結するか、json にエンコードします
return json_encode($ res) ;
return json_encode($res);
これも機能しません、返信は文字化けします
誰か知っていますかそれをマスターするには?
echo json_encode の前に、 header('Content-type:application/json;charset=utf-8');
echo json_encode の前に追加します。 : header( 'Content-type:application/json;charset=utf-8');
$sql = "select * FROM `record` WHERE title like '%$keyword%'"; $ result = mysql_query($ sql、$ link); mysql_close($link);
} 今回返される値は、echo の []
です。 json_encode の前に、header('Content-type:application/json;charset=utf-8) を追加します。 ');
これはエラーですか?
$sql = 「select * FROM `record` WHERE title like '%$keyword%'";
$result = mysql_query($sql, $link); // 执行句询语
$res=array();
while($row = mysql_fetch_array($result))
{
$res[]=$row["title"];
header('Content-type:application/json;charset=utf-8');
return json_encode($res);
mysql_close($link);
} 次の返還は[]
返還は空ですか? 🎜> echo json_encodeの前,加上:header('Content-type:application/json;charset=utf-8');
会わないのはこれですか?
<コンテンツ>コンテンツ>
は、
在echo json_encode之前,加上:header('Content-type:application/json;charset=utf-8');
$sql = 「select * FROM `record` WHERE title like '%$keyword%'";
$result = mysql_query($sql, $link); // 执行句询语
$res=array();
while($row = mysql_fetch_array($result))
{
$res[]=$row["title"];
header('Content-type:application/json;charset=utf-8');
return json_encode($res);
mysql_close($link);
} 次の戻り値は[]
戻り値は空ですか?
申し訳ありませんが、今間違ったコメントをしてしまいました。
何が間違っているのか全く分かりません
/**
* wechat php テスト
*/
// トークンを定義します
function chaxun($keyword){
$dbname = 'app_yqweixiaoxi';
//$host = getenv('HTTP_BAE_ENV_ADDR_SQL_IP'); > // $port = getenv('HTTP_BAE_ENV_ADDR_SQL_PORT');
//$user = getenv('HTTP_BAE_ENV_AK')
//$pwd = getenv('HTTP_BAE_ENV_SK');
mysql_connect() サーバーに接続します*/
$link = mysql_connect ( SAE_MYSQL_HOST_M . ':' . SAE_MYSQL_PORT, SAE_MYSQL_USER, SAE_MYSQL_PASS );
if(!$link) {
die("サーバーの接続に失敗しました: " .mysql_error($link));
}
/*接続が成功した直後に mysql_select_db() を呼び出し、接続するデータベースを選択します*/
if(!mysql_select_db($dbname,$link) )
{
die("データベースの選択に失敗しました: " .mysql_error($link))
}
mysql_query("set names GBK",$link); 🎜>$sql = "select * FROM `record` WHERE title like '%$keyword%'";
$result = mysql_query($sql, $link) // クエリ文を実行します
$res=array ();
while( $row = mysql_fetch_array($result))
🎜> header('Content-type:application/json;charset=utf -8');
return json_encode($res); ;
mysql_close($link); >define("TOKEN", "YQweixiaoxi");
$wechatObj->responseMsg(); >
class wechatCallbackapiTest
{
public function valid()
{
$echoStr = $_GET ["echostr"]
//有効な署名、オプション
if($this->checkSignature()){
echo $echoStr;
exit; exit
}
}
public function responseMsg()
{
//投稿データを取得します。環境が異なる可能性があります。
$postStr = $GLOBALS["HTTP_RAW_POST_DATA"]
//投稿データを抽出します
if (!empty($postStr) )){
$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
$fromUsername = $postObj->FromUserName; $toUsername = $postObj->ToUserName;時間(); $textTpl = "
if(!empty($keyword ))
{
$msgType = "text";
$contentStr= chaxun($keyword);
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
echo $resultStr;
}else{
echo "何かを入力してください...";
}
}else {
echo "";
終了します。
}
}
private function checkSignature()
{
$signature = $_GET["signature"];
$timestamp = $_GET["timestamp"];
$nonce = $_GET["nonce"];
$token = トークン;
$tmpArr = array($token, $timestamp, $nonce);
ソート($tmpArr);
$tmpStr = implode( $tmpArr );
$tmpStr = sha1( $tmpStr );
if( $tmpStr == $signature ){
return true;
}else{
return false;
}
}
}
?>
在echo json_encode之前,加上:header('Content-type:application/json;charset=utf- 8');
$sql = 「select * FROM `record` WHERE title like '%$keyword%'";
$result = mysql_query($sql, $link); // 执行句询语
$res=array();
while($row = mysql_fetch_array($result))
{
$res[]=$row["title"];
header('Content-type:application/json;charset=utf-8');
return json_encode($res);
mysql_close($link);
} 次の戻り値は[]
戻り値は空ですか?
在echo json_encode之前,加上:header('Content-type:application/json;charset=utf-8');
$sql = 「select * FROM `record` WHERE title like '%$keyword%'";
$result = mysql_query($sql, $link); // 执行句询语
$res=array();
while($row = mysql_fetch_array($result))
{
$res[]=$row["title"];
header('Content-type:application/json;charset=utf-8');
return json_encode($res);
mysql_close($link);
} 次の戻り値は[]
戻り値は空ですか?
数据库的是这样的
你的表字段是UTF-8,所以应该 mysql_query("set names utf8",$link);
另外,有个地方稍微改下(改不改都行,不过echo的数据都应该是XML格式的):
if(!empty($keyword )){ $msgType = "text"; $contentStr = chaxun($keyword); $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); echo $resultStr;}else{ $msgType = "text"; $contentStr = "input something..."; $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); echo $resultStr;}
你的表字段是UTF-8,所以应该 mysql_query("set names utf8",$link);
另外,有个地方稍微改下(改不改都行,不过echo的数据都应该是XML格式的):
if(!empty($keyword )){ $msgType = "text"; $contentStr = chaxun($keyword); $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); echo $resultStr;}else{ $msgType = "text"; $contentStr = "input something..."; $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); echo $resultStr;}
都改了,还是不行,烦死了,用return返回array,用echo 回复公众号暂停服务
1、你是在做微信应用,而微信都是 utf-8 编码的
所以你 mysql_query("set names GBK",$link); 是不对的
要 mysql_query("set names utf8",$link);
2、你把传入的 utf-8 数据 $keyword 当做 gbk 解释
这就造成了 chaxun 函数返回空数组
当然确实不存在的时候,也是返回空数组的
3、由
$contentStr= chaxun($keyword);
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
可知,$contentStr 应是一个字符串,而 chaxun 返回的是数组,所以可能需要
$contentStr = json_encode(chaxun($keyword));
或
$contentStr = join(',', chaxun($keyword));
1、用echo 回复公众号暂停服务====》可能是代码有语法错误或者error,在你的域名里运行这个脚本看看有没有报错。
2、试一下,不进行查找数据库,直接让$contentStr = "字符串";然后echo $resultStr; 看看是不是数据取出问题
1、用echo 回复公众号暂停服务====》可能是代码有语法错误或者error,在你的域名里运行这个脚本看看有没有报错。
2、试一下,不进行查找数据库,直接让$contentStr = "字符串";然后echo $resultStr; 看看是不是数据取出问题
问题解决了,谢谢你,大师傅
1、你是在做微信应用,而微信都是 utf-8 编码的
所以你 mysql_query("set names GBK",$link); 是不对的
要 mysql_query("set names utf8",$link);
2、你把传入的 utf-8 数据 $keyword 当做 gbk 解释
这就造成了 chaxun 函数返回空数组
当然确实不存在的时候,也是返回空数组的
3、由
$contentStr= chaxun($keyword);
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
可知,$contentStr 应是一个字符串,而 chaxun 返回的是数组,所以可能需要
$contentStr = json_encode(chaxun($keyword));
或
$contentStr = join(',', chaxun($keyword));
大师啊,大师啊,解决了,佩服啊
太感谢了

ホット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)

ホットトピック











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

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

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

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

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

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

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