记录 – 测试支付宝订单回调

http://wanai.a.cc/branch/alipay_return
?body=
(房费:¥449++浪布商品:¥0+-+注册优惠:¥14+-+优惠券:¥434)
1
&buyer_email=
jollyfon%40gmail.com
&buyer_id=2088302755117180
&exterface=create_direct_pay_by_user
&is_success=T
&notify_id=RqPnCoPT3K9%252Fvwbh3Ih0HKJQ19cGsAbOdMSD7dWSs8LKeS%252BoKKifC52WXqRmTkFBrwzS
&notify_time=2018-05-31+11%3A00%3A18&notify_type=trade_status_sync&out_trade_no=000
&payment_type=1
&seller_email=wanaihotel%40163.com&seller_id=2088911951177304
&subject=测试订单&total_fee=0.01
&trade_no=2018053121001004180521188593
&trade_status=TRADE_SUCCESS
&sign=6e5f48b4ed3d00baa9592ded58faabf6
&sign_type=MD5

 

微信支付 fopen(/tmp/logs/.log): failed to open stream: No such file or directory 与 curl出错,错误码:60 解决方法

调试微信支付发生错误

错误1:

A PHP Error was encountered
Severity: Warning
Message: fopen(/tmp/logs/2018-05-30.log): failed to open stream: No such file or directory
Filename: lib/log.php
Line Number: 16

解决方法:在硬盘的根目录下新建 tmp/logs/ 文件夹,不是在网站根目录下新建文件夹

错误2:

An uncaught Exception was encountered
Type: WxPayException
Message: curl出错,错误码:60
Filename: D:\wwwroot\wanaiweb\wanai\application\third_party\wxpay\lib\WxPay.Api.php
Line Number: 564

修改文件 WxPay.Api.php 解决:

第537行

curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,TRUE);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验

改为

curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,FALSE);//严格校验2

 

CI CodeIgniter 添加打印 dump 公共函数(自定义函数)

CodeIgniter 公共函数通过 helper 辅助函数实现。

创建 common_helper.php 文件,定义所需公共函数,存放至 application/helpers 目录中。

<?php
  function dump($arr){
    echo "<pre>";
    var_dump($arr);
    echo "</pre>";
  }
  function dd($arr){
    echo "<pre>";
    print_r($arr);
    echo "</pre>";
  }
?>

在 application/config/autoload.php 中配置 $autoload[‘helper’] = array(‘common’);

PHP GET 调用企查查 API 示例

/* PHP CURL HTTPS GET*/
function curl_get_https($url){
    $curl = curl_init(); // 启动一个CURL会话
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_HEADER, 0);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);  // 从证书中检查SSL加密算法是否存在
    $tmpInfo = curl_exec($curl);     //返回api的json对象
    //关闭URL请求
    curl_close($curl);
    return $tmpInfo;    //返回json对象
}
public function test(){
    $url = 'http://i.yjapi.com/ECIV4/Search?';
    $key = '';
    $keyword = '小桔科技';
    $get = http_build_query(array('key'=>$key,'keyword'=>$keyword));
    $rs = $this->curl_get_https($url.$get);
    echo $rs;
}

返回值:

{
"Status": "202",
"Message": "传入参数有误,请检查",
"OrderNumber": null,
"Paging": null,
"Result": null
}

 

阔道物联智能门锁存在的问题及解决方案

阔道物联可以使用阔道物联公司公网服务器,也可使用自己架设内网服务器。

若使用阔道物联公司公网服务器,存在的问题

1、如果门店网络状况不佳(如断网),门店将无法制作卡片、密码、电子钥匙,新进店客人将无法完成入住。(已制作的卡片,密码不受影响,但电子钥匙无法使用)。

解决方案:每个房间配备一个长时效的备用门卡或长时效密码

2、如果门店没有电(部分电脑可以有电),存在问题与解决方案同上

3、没有公网和内网兼容模式,当公网存在问题时无法及时切换到内网,即无法通过公网切换内网的方式解决上述存在的问题。

若使用自己架设的内网服务器,存在的问题

1、在每家门店假设阔道内网服务器,我公司原有的管理后台无法接入门店的无卡制卡、密码管理。

解决方案:每家门店需架设单独的Web服务器环境,将我公司的制作的“开锁密码短信通知后台”安装在门店。(网络正常时可以发送短信密码,网络存在问题时无法发送短信密码)

2、若每家门店安装“开锁密码短信通知后台”,易出现死机或其他技术问题。

解决方案:购买TeamViewer或其他的远程访问软件,技术人员远程控制解决问题。

其他问题

1、阔道物联的发卡原理为将卡片的八位十六进制号码和使用时间通知门锁,门锁接收信息保存门锁本地。如有人复制卡片,则可以开锁,安全性稍差。

解决方案:控制外来人员进入。

存在的BUG

1、阔道公司提供的读卡器和客户端会将读出的卡片八位十六进制编号前面加上ffffffff,需手动去除ffffffff才可制卡,但去除ffffff后,也无法读取该卡的钥匙信息。

2、当网络状况不佳时(网络不好),存在制作卡片、制作密码、取消卡片、取消密码等信息已通知服务器,但服务器未通知到门锁的情况,该情况会提示钥匙状态为部分有效、部分撤销,即制作了卡片,但无法开锁,或撤销了卡片,但依然可以开锁的情况。这时需人工手动点击再试一次或修复撤销,无法自动重做。

不影响功能的BUG

1、同一把锁可以多次添加到项目,后面添加的会将前面添加的覆盖,只有最后一次添加的锁可以使用,但前面的锁并未提示失效。

2、客户端的钥匙管理分页有误,页与页之间为按ID升序,每页的条与条之间为ID降序,造成的问题是钥匙管理界面的首页并不是最新的信息。

API接口未完善的地方

1、钥匙管理API缺少按时间筛选的功能

2、缺少阔道桥管理API、设备管理API、子账号列表API,该功能客户端有

3、接口返回错误信息时缺少详细信息。

请实现一个显示层级目录的函数 – 一道 PHP 面试题

题有问题暂且不说,说一下解题思路,未总结成方法

<?php
$dir = [
    '0'=>['','主目录'],
    '1'=>['0','第一级目录1'],
    '2'=>['0','第一级目录2'],
    '3'=>['0','第一级目录3'],
    '4'=>['','主目录2'],
    '5'=>['1','第二级目录1'],
    ];
  
foreach($dir as $k => &$v){
    $v['id']= $k;
    $v['pid'] = $v[0];
    $v['title'] = $v[1];
    unset($dir[$k][0],$dir[$k][1]);
}

echo '<pre>';
print_r($dir);
echo '</pre>';

#递归方法实现无限极分类
function getTree($list,$pid=0,$level=0) {
  static $tree = array();
  foreach($list as $row) {
      if($row['pid'] !== ''){
    		if($row['pid']==$pid) {
        		$row['level'] = $level;
        		$tree[] = $row;
        		getTree($list, $row['id'], $level + 1);
        	}
      }elseif($row['pid'] === '' && $level == 0){
          $tree[] = $row;
      }
  }
  return $tree;
}

$dir = getTree($dir);

echo '<pre>';
print_r($dir);
echo '</pre>';

foreach($dir as $kk => $vv){
    if($vv['level'] !== NULL){
        $rs[] = str_repeat('--',$vv['level']+1).$vv['title'];
    }else{
        $rs[] = $vv['title'];
    }
}

echo '<pre>';
print_r($rs);
echo '</pre>';

结果是:

Array
(
    [0] => Array
        (
            [id] => 0
            [pid] => 
            [title] => 主目录
        )

    [1] => Array
        (
            [id] => 1
            [pid] => 0
            [title] => 第一级目录1
        )

    [2] => Array
        (
            [id] => 2
            [pid] => 0
            [title] => 第一级目录2
        )

    [3] => Array
        (
            [id] => 3
            [pid] => 0
            [title] => 第一级目录3
        )

    [4] => Array
        (
            [id] => 4
            [pid] => 
            [title] => 主目录2
        )

    [5] => Array
        (
            [id] => 5
            [pid] => 1
            [title] => 第二级目录1
        )

)
Array
(
    [0] => Array
        (
            [id] => 0
            [pid] => 
            [title] => 主目录
        )

    [1] => Array
        (
            [id] => 1
            [pid] => 0
            [title] => 第一级目录1
            [level] => 0
        )

    [2] => Array
        (
            [id] => 5
            [pid] => 1
            [title] => 第二级目录1
            [level] => 1
        )

    [3] => Array
        (
            [id] => 2
            [pid] => 0
            [title] => 第一级目录2
            [level] => 0
        )

    [4] => Array
        (
            [id] => 3
            [pid] => 0
            [title] => 第一级目录3
            [level] => 0
        )

    [5] => Array
        (
            [id] => 4
            [pid] => 
            [title] => 主目录2
        )

)
Array
(
    [0] => 主目录
    [1] => --第一级目录1
    [2] => ----第二级目录1
    [3] => --第一级目录2
    [4] => --第一级目录3
    [5] => 主目录2

难点在于相较于一般的无限级分类,多了一级 pid == ‘’ ,这一级单独判断。