| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 | <?phpnamespace App\Http\Middleware;use App\Services\Common\CurlService;use App\Wechat\WechatParam;use Closure;use Illuminate\Support\Facades\Cache;use Illuminate\Support\Facades\Log;/** * 公众号检查,获取支付openid * Class OfficialCheck * @package App\Http\Middleware * Auth Zhong * Date 2019/2/22 */class WechatCheck{    /**     * OfficialCheck constructor.     */    public function __construct()    {    }    /**     * Handle an incoming request.     *     * @param  \Illuminate\Http\Request $request     * @param  \Closure $next     * @return mixed     */    public function handle($request, Closure $next)    {        //获取jsapi_ticket        $jsapi_ticket = Cache::get('wechat_jsapi_ticket');        if (empty($jsapi_ticket)) {            $jsapi_ticket = $this->_getJsApiTicket();            if (empty($jsapi_ticket)) {                return $next($request);            }        }        //生成配置        $timestamp = time();        $noncestr  = $this->_generateNonceStr();        $url       = $request->getUri();        $ret       = strpos($url, '#');        if ($ret) {            $url = substr($url, 0, $ret);        }        $url = trim($url);        if (empty($url))            return $next($request);        $arrdata = ["timestamp" => $timestamp, "noncestr" => $noncestr, "url" => $url, "jsapi_ticket" => $jsapi_ticket];        $sign    = $this->_getSignature($arrdata);        if (!$sign)            return $next($request);        WechatParam::instance()->merge([            "nonceStr"  => $noncestr,            "timestamp" => $timestamp,            "url"       => $url,            "signature" => $sign,        ]);        return $next($request);    }    /**     * 获取jsapi_ticket     */    private function _getJsApiTicket()    {        $access_token = $this->_getAccessToken();        if (empty($access_token)) {            return null;        }        $curl = new CurlService();        $res  = $curl->get('https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=' . $access_token . '&type=jsapi');        if (!empty($res)) {            if (isset($res->ticket)) {                Cache::put("wechat_jsapi_ticket", $res->ticket, 100);                return $res->ticket;            }        }        return null;    }    /**     * 获取access_token     */    private function _getAccessToken()    {        $access_token = Cache::get('wechat_access_token');        if (empty($access_token)) {            $curl   = new CurlService();            $wechat = WechatParam::instance()->getParam();            $res    = $curl->get("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$wechat['appid']}&secret={$wechat['appsecret']}");            if (!empty($res)) {//                Log::info('获取token:' . json_encode($res));                if (isset($res->access_token)) {                    Cache::put("wechat_access_token", $res->access_token, 100);                    return $res->access_token;                }            }            return null;        }        return $access_token;    }    /**     * 生成随机字串     * @param number $length 长度,默认为16,最长为32字节     * @return string     */    private function _generateNonceStr($length = 16)    {        // 密码字符集,可任意添加你需要的字符        $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";        $str   = "";        for ($i = 0; $i < $length; $i++) {            $str .= $chars[mt_rand(0, strlen($chars) - 1)];        }        return $str;    }    /**     * 获取签名     * @param array $arrdata 签名数组     * @param string $method 签名方法     * @return boolean|string 签名值     */    private function _getSignature($arrdata, $method = "sha1")    {        if (!function_exists($method)) return false;        ksort($arrdata);        $paramstring = "";        foreach ($arrdata as $key => $value) {            if (strlen($paramstring) == 0)                $paramstring .= $key . "=" . $value;            else                $paramstring .= "&" . $key . "=" . $value;        }        $Sign = $method($paramstring);        return $Sign;    }}
 |