鍍金池/ 問答/ PHP問答
小曖昧 回答

個人推薦保存到日志文件中,日志量大,你每次保存數(shù)據(jù)庫會增加數(shù)據(jù)庫的寫負擔(dān),而且放在日志文件中,后期可以做類似Logstash應(yīng)用來做日志采集,進行數(shù)據(jù)可視化分析,這個時候就不用擔(dān)心多余的數(shù)據(jù)庫讀負擔(dān),畢竟數(shù)據(jù)庫的讀寫資源是非常重要的。

旖襯 回答
packagist.phpcomposer.com 這個不太穩(wěn)定,經(jīng)常會掛掉,建議更換一個鏡像,執(zhí)行如下命令即可:
composer config -g repo.packagist composer https://packagist.laravel-china.org
# 更新 composer 版本
composer selfupdate
真難過 回答

js 文件會被服務(wù)器當做靜態(tài)文件直接返回給瀏覽器的,所以你放在.js文件里PHP是不會被解析的

局外人 回答
  1. 正式版必須https
  2. 開發(fā)環(huán)境的開發(fā)者工具可以勾選“不驗證https”
笨笨噠 回答

1.第一種寫法錯誤的原因是setField()只能更新一個字段,你卻給了兩個字段。
2.第二種寫法是正確的
3.save是有兩個參數(shù)的 第一個是更新的數(shù)據(jù),第二個是更新的條件

蔚藍色 回答

ws 訪問的應(yīng)該是服務(wù)器的IP地址。另外查看端口9502 是否被websocket占用,命令 netstat -anp | grep 9502

墨沫 回答

驗證過簽名一致那么你的算法就沒錯。接下來驗證一下輸入信息。
可能出錯的地方:

  1. 一個公眾號可能對應(yīng)多個商戶號,檢查是否一致。
  2. 前后端使用的參數(shù)名大小寫是否一致,順序可以不同。
  3. 微信那邊有莫名的緩存,多刷新試試。
鐧簞噯 回答

以每行第九列排序

款爺 回答

下面是按$a中的key$b中的id

<?php

$a = [
    0 => ['num' => 100],
    1 => ['num' => 105],
    3 => ['num' => 253],
];

$b = [
    0 => [
        'id' => 1,
        'num' => 300
    ],
    1 => [
        'id' => 2,
        'num' => 600
    ],
    2 => [
        'id' => 3,
        'num' => 900
    ],
];

$tmp = array_combine(array_column($b,'id'),array_column($b,'num'));
$ids = [];

array_walk($a, function(&$val,$key) use($tmp,&$ids){
    if($val['num'] < 500 && isset($tmp[$key])){
        $val['num'] = $tmp[$key];
        $ids[]      = $key;
    }
});

var_dump($a);
var_dump($ids);
慢半拍 回答

你可能是公眾號沒有認證,所以沒有權(quán)限吧!

以下是2018.3.30修改:

第1:你貼的是源碼,不是錯誤代碼!
第2:你的源碼也是不完整的,別人根本沒有辦法調(diào)試!比如:
$content = $this->request($url);
請問:$this是什么對象?request方法的定義是怎樣的?
第3:你的源碼也是存在明顯的錯誤的。在PHP中,單引號里的變量是當字符串處理的,所以

$url='https://api.weixin.qq.com/cgi-bin/user/get?access_token=.$access_token.&next_openid=NEXT_OPENID
';

這一句,你請求的網(wǎng)址就真的是:

$url='https://api.weixin.qq.com/cgi-bin/user/get?access_token=.$access_token.&next_openid=NEXT_OPENID

這是不對的,應(yīng)該用雙引號。并且,你的參數(shù)NEXT_OPENID應(yīng)該是個變量,而你這里只是一個大寫字母的字符串!
綜上所述,你的代碼無法獲取用戶信息是正常的,和公眾號權(quán)限無關(guān),是代碼級問題!
最后,附上一段可執(zhí)行的代碼,供你參考:

<?php
$appid='';//寫上你的appid
$appsecret='';//寫上你的密鑰
$url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$appsecret";

$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);
$output = curl_exec($ch);
curl_close($ch);
$jsoninfo = json_decode($output, true);
$access_token = $jsoninfo["access_token"];
echo $access_token;

//獲取到openid
userlist($access_token);

//獲取用戶列表
function userlist($access_token){

   $url="https://api.weixin.qq.com/cgi-bin/user/get?access_token=$access_token";
echo 'url'.$url;

   // $content = $this->request($url);
   $content=curl1($url);
   print_r($content);
   $content = json_dcode($content);
   $openidList = $content -> data->openid;
   var_dump($openidList);

   echo '關(guān)注人數(shù)為:'.$content->total.'人.<br/>';
   echo 'openid列表為:<br/>';
   foreach($openidList as $key => $value){
       echo $value.'<br/>';
   }
}

function curl1($url1){

$ch1 = curl_init();
curl_setopt($ch1, CURLOPT_URL, $url1);
curl_setopt($ch1, CURLOPT_SSL_VERIFYPEER, FALSE); 
curl_setopt($ch1, CURLOPT_SSL_VERIFYHOST, FALSE); 
curl_setopt($ch1, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($ch1);
curl_close($ch1);
return $output;
}
涼心人 回答

這兩個瀏覽器偏偏就是解決不了的
可以去msdn查看新的media接口

愛礙唉 回答

xml 這個參數(shù)的值,是被 urlencode 兩次的東西。 php 不懂, Python 的話是用 urllib.unquote 就可以了。

>>> s = '''%3C%3Fxml+version%3D%221.0%22+encoding%3D%22gbk%22+%3F%3E%253Ctask%253E%253Cuser%253E%253Coper%253Emod%253C%252Foper%253E%253Cid%253E14001420%2540private.gb.gov%253C%252Fid%253E%253Cname%253E%25E5%25A7%259A%25E8%25BF%259C%253C%252Fname%253E%253Cusertype%253EUT01%253C%252Fusertype%253E%253Cgrade%253E%25E5%2586%2585%25E9%2583%25A8%253C%252Fgrade%253E%253Cdname%253E%25E6%2596%2587%25E7%2594%25B5%25E5%25A4%2584%253C%252Fdname%253E%253Cdid%253E2021013100%2540private.gb.gov%253C%252Fdid%253E%253Cdorder%253E1%253C%252Fdorder%253E%253Cdcode%253E%253C%252Fdcode%253E%253Csexual%253E0%253C%252Fsexual%253E%253Cduty%253E%253C%252Fduty%253E%253Cpost%253E%253C%252Fpost%253E%253Caccount%253E14001420%253C%252Faccount%253E%253Cpassword%253E%253C%252Fpassword%253E%253Cmail%253E%253C%252Fmail%253E%253C%252Fuser%253E%253C%252Ftask%253E'''
>>> import urllib
>>> urllib.unquote(s)
'<?xml+version="1.0"+encoding="gbk"+?>%3Ctask%3E%3Cuser%3E%3Coper%3Emod%3C%2Foper%3E%3Cid%3E14001420%40private.gb.gov%3C%2Fid%3E%3Cname%3E%E5%A7%9A%E8%BF%9C%3C%2Fname%3E%3Cusertype%3EUT01%3C%2Fusertype%3E%3Cgrade%3E%E5%86%85%E9%83%A8%3C%2Fgrade%3E%3Cdname%3E%E6%96%87%E7%94%B5%E5%A4%84%3C%2Fdname%3E%3Cdid%3E2021013100%40private.gb.gov%3C%2Fdid%3E%3Cdorder%3E1%3C%2Fdorder%3E%3Cdcode%3E%3C%2Fdcode%3E%3Csexual%3E0%3C%2Fsexual%3E%3Cduty%3E%3C%2Fduty%3E%3Cpost%3E%3C%2Fpost%3E%3Caccount%3E14001420%3C%2Faccount%3E%3Cpassword%3E%3C%2Fpassword%3E%3Cmail%3E%3C%2Fmail%3E%3C%2Fuser%3E%3C%2Ftask%3E'
>>> print urllib.unquote(s)
<?xml+version="1.0"+encoding="gbk"+?>%3Ctask%3E%3Cuser%3E%3Coper%3Emod%3C%2Foper%3E%3Cid%3E14001420%40private.gb.gov%3C%2Fid%3E%3Cname%3E%E5%A7%9A%E8%BF%9C%3C%2Fname%3E%3Cusertype%3EUT01%3C%2Fusertype%3E%3Cgrade%3E%E5%86%85%E9%83%A8%3C%2Fgrade%3E%3Cdname%3E%E6%96%87%E7%94%B5%E5%A4%84%3C%2Fdname%3E%3Cdid%3E2021013100%40private.gb.gov%3C%2Fdid%3E%3Cdorder%3E1%3C%2Fdorder%3E%3Cdcode%3E%3C%2Fdcode%3E%3Csexual%3E0%3C%2Fsexual%3E%3Cduty%3E%3C%2Fduty%3E%3Cpost%3E%3C%2Fpost%3E%3Caccount%3E14001420%3C%2Faccount%3E%3Cpassword%3E%3C%2Fpassword%3E%3Cmail%3E%3C%2Fmail%3E%3C%2Fuser%3E%3C%2Ftask%3E
>>> ss = '''%3Ctask%3E%3Cuser%3E%3Coper%3Emod%3C%2Foper%3E%3Cid%3E14001420%40private.gb.gov%3C%2Fid%3E%3Cname%3E%E5%A7%9A%E8%BF%9C%3C%2Fname%3E%3Cusertype%3EUT01%3C%2Fusertype%3E%3Cgrade%3E%E5%86%85%E9%83%A8%3C%2Fgrade%3E%3Cdname%3E%E6%96%87%E7%94%B5%E5%A4%84%3C%2Fdname%3E%3Cdid%3E2021013100%40private.gb.gov%3C%2Fdid%3E%3Cdorder%3E1%3C%2Fdorder%3E%3Cdcode%3E%3C%2Fdcode%3E%3Csexual%3E0%3C%2Fsexual%3E%3Cduty%3E%3C%2Fduty%3E%3Cpost%3E%3C%2Fpost%3E%3Caccount%3E14001420%3C%2Faccount%3E%3Cpassword%3E%3C%2Fpassword%3E%3Cmail%3E%3C%2Fmail%3E%3C%2Fuser%3E%3C%2Ftask%3E'''
>>> urllib.unquote(ss)
'<task><user><oper>mod</oper><id>14001420@private.gb.gov</id><name>\xe5\xa7\x9a\xe8\xbf\x9c</name><usertype>UT01</usertype><grade>\xe5\x86\x85\xe9\x83\xa8</grade><dname>\xe6\x96\x87\xe7\x94\xb5\xe5\xa4\x84</dname><did>2021013100@private.gb.gov</did><dorder>1</dorder><dcode></dcode><sexual>0</sexual><duty></duty><post></post><account>14001420</account><password></password><mail></mail></user></task>'
澐染 回答

一個比較簡單的辦法是,首先將確定的范圍分成n個小區(qū)間,然后在每一區(qū)間中用隨機數(shù)獲取一個點,這樣會相對稀疏一些。給區(qū)間加一個padding可以避免兩個點過于靠近

淺淺 回答

請問您解決了嗎 我目前也遇到這個問題

悶油瓶 回答
我之前一直是用window開發(fā),沒有管過服務(wù)器,只有稍微按照網(wǎng)上的文檔安裝過環(huán)境,之前做編譯什么的,都是在安裝包解壓后的目錄里進行的,但是現(xiàn)在這個好像找不到當初的安裝包,那我是得重新下載一個相同版本的php安裝包進行編譯嗎?

如果存在原來的編譯目錄,則目錄下應(yīng)該有個config.nice文件,里面保存了當時的編譯參數(shù)。如果沒有保留的話就用php -i命令或者phpinfo()函數(shù)可以看到,里面有一項Configure Command是編譯參數(shù)。

至于重新編譯可以下載相同版本的安裝包,小版本可以下最新的,比如現(xiàn)在的是5.6.x,你可以下載最新的5.6.36來編譯。