我把一段代碼從thinkphp 3.1 移植到 thinkphp 3.2 ,然後調整的時候出現了這麼一個錯誤,找了好多都沒找到。
public function init() { $config = M ( "Wxconfig" )->where ( array ( "id" => "1" ) )->find (); $options = array ( 'token' => $config ["token"], // 填寫你設定的key 'encodingaeskey' => $config ["encodingaeskey"], // 填寫加密用的EncodingAESKey 'appid' => $config ["appid"], // 填寫進階調用功能的app id 'appsecret' => $config ["appsecret"], // 填寫進階調用功能的密鑰 ); $weObj = A('Api/Wechat ( $options )'); return $weObj; } public function index() { $weObj = $this->init(); $weObj -> valid ();
下面是Api/Wechat中的那個 valid方法:
/** * For weixin server validation * @param bool $return 是否返回 */ public function valid($return=false) { $encryptStr=""; if ($_SERVER['REQUEST_METHOD'] == "POST") { $postStr = file_get_contents("php://input"); $array = (array)simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); $this->encrypt_type = isset($_GET["encrypt_type"]) ? $_GET["encrypt_type"]: ''; if ($this->encrypt_type == 'aes') { //aes加密 $this->log($postStr); $encryptStr = $array['Encrypt']; $pc = new Prpcrypt($this->encodingAesKey); $array = $pc->decrypt($encryptStr,$this->appid); if (!isset($array[0]) || ($array[0] != 0)) { if (!$return) { die('decrypt error!'); } else { return false; } } $this->postxml = $array[1]; if (!$this->appid) $this->appid = $array[2];//為了沒有appid的訂閱號。 } else { $this->postxml = $postStr; } } elseif (isset($_GET["echostr"])) { $echoStr = $_GET["echostr"]; if ($return) { if ($this->checkSignature()) return $echoStr; else return false; } else { if ($this->checkSignature()) die($echoStr); else die('no access'); } } if (!$this->checkSignature($encryptStr)) { if ($return) return false; else die('no access'); } return true; }
這是什麼問題TAT
回複內容:
我把一段代碼從thinkphp 3.1 移植到 thinkphp 3.2 ,然後調整的時候出現了這麼一個錯誤,找了好多都沒找到。
public function init() { $config = M ( "Wxconfig" )->where ( array ( "id" => "1" ) )->find (); $options = array ( 'token' => $config ["token"], // 填寫你設定的key 'encodingaeskey' => $config ["encodingaeskey"], // 填寫加密用的EncodingAESKey 'appid' => $config ["appid"], // 填寫進階調用功能的app id 'appsecret' => $config ["appsecret"], // 填寫進階調用功能的密鑰 ); $weObj = A('Api/Wechat ( $options )'); return $weObj; } public function index() { $weObj = $this->init(); $weObj -> valid ();
下面是Api/Wechat中的那個 valid方法:
/** * For weixin server validation * @param bool $return 是否返回 */ public function valid($return=false) { $encryptStr=""; if ($_SERVER['REQUEST_METHOD'] == "POST") { $postStr = file_get_contents("php://input"); $array = (array)simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); $this->encrypt_type = isset($_GET["encrypt_type"]) ? $_GET["encrypt_type"]: ''; if ($this->encrypt_type == 'aes') { //aes加密 $this->log($postStr); $encryptStr = $array['Encrypt']; $pc = new Prpcrypt($this->encodingAesKey); $array = $pc->decrypt($encryptStr,$this->appid); if (!isset($array[0]) || ($array[0] != 0)) { if (!$return) { die('decrypt error!'); } else { return false; } } $this->postxml = $array[1]; if (!$this->appid) $this->appid = $array[2];//為了沒有appid的訂閱號。 } else { $this->postxml = $postStr; } } elseif (isset($_GET["echostr"])) { $echoStr = $_GET["echostr"]; if ($return) { if ($this->checkSignature()) return $echoStr; else return false; } else { if ($this->checkSignature()) die($echoStr); else die('no access'); } } if (!$this->checkSignature($encryptStr)) { if ($return) return false; else die('no access'); } return true; }
這是什麼問題TAT
$weObj = A('Api/Wechat ( $options )');
Thinkphp A 函數不是這樣調用吧
意思是說現在版本的TP的init方法在你這裡的代碼中沒有返回對象,而是返回了布爾值,很可能是false;
跟蹤一下3.2版本的A方法: