您正在查看: yhbin 发布的文章

linux学习

1、gpasswd -a 用户名 用户组
2、查看登录的用户属于哪些组   groups
3、读ls可用,写touch、mkdir可用,执行cd可用
4、读写执行权限{1.浏览器,只针对拥有者,   2.命令行,只针对当前登录用户,先后顺序是拥有者>所属组>其他人,即是拥有者则判断拥有者权限,其次是如果当前用户跟文件所属组是一个组,则判断所属组权限,再就是判断其他人权限}
3、命令行当前登录用户,上级目录没有写权限,但是子目录里有个文件夹有写权限,则进入其中也是可以写文件的,不受上级目录权限限制

e.target

$(e.target)是jQuery对象,e.target是DOM对象,比如$(e.target)可以通过$(e.target).html()获取元素内容,e.target可以通过e.target.innerHTML获取元素内容
.val() 能够取到 针对text,hidden可输入的文本框的value值。

而 .attr('value') 可以取到html元素中所设置的属性 value的值,不能获取动态的如input type="text" 的文本框手动输入的值。

Tp5开发规范

命名规范

ThinkPHP5遵循PSR-2命名规范和PSR-4自动加载规范,并且注意如下规范:

目录和文件

目录使用小写+下划线;
类库、函数文件统一以.php为后缀;
类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致;
类文件采用驼峰法命名(首字母大写),其它文件采用小写+下划线命名;
类名和类文件名保持一致,统一采用驼峰法命名(首字母大写);

函数和类、属性命名

类的命名采用驼峰法(首字母大写),例如 User、UserType,默认不需要添加后缀,例如UserController应该直接命名为User;
函数的命名使用小写字母和下划线(小写字母开头)的方式,例如 get_client_ip;
方法的命名使用驼峰法(首字母小写),例如 getUserName;
属性的命名使用驼峰法(首字母小写),例如 tableName、instance;
以双下划线“__”打头的函数或方法作为魔术方法,例如 __call 和 __autoload;

常量和配置

常量以大写字母和下划线命名,例如 APP_PATH和 THINK_PATH;
配置参数以小写字母和下划线命名,例如 url_route_on 和url_convert;

数据表和字段

数据表和字段采用小写加下划线方式命名,并注意字段名不要以下划线开头,例如 think_user 表和 user_name字段,不建议使用驼峰和中文作为数据表字段命名。
应用类库命名空间规范
应用类库的根命名空间统一为app(不建议更改,可以设置app_namespace配置参数更改,V5.0.8版本开始使用APP_NAMESPACE常量定义);
例如:appindexcontrollerIndex和appindexmodelUser。

宝塔添加网站,git更新

1.宝塔添加网站、ftp、数据库等
2.修改网站伪静态、配置文件的根目录
3.ssh到服务器网站目录下,运行git clone 出代码
4.git config --global credential.helper store
接下来输入的账号密码就会被保存
5.git config --global core.autocrlf false
转义

微信支付

1.获取prepay_id
2.根据prepay_id获取支付参数

后台

$wx_pay_config                   = [];
       $wx_pay_config['appid']          = config('appid');
       $wx_pay_config['appsecret']      = config('appsecret');
       $wx_pay_config['token']          = config('token');
       $wx_pay_config['encodingaeskey'] = config('encodingaeskey');
       $wx_pay_config['mch_id']         = config('mch_id');
       $wx_pay_config['partnerkey']     = config('partnerkey');
       $wx_pay_config['cert_key']       = config('cert_key');
       $wx_pay_config['cert_cert']      = config('cert_cert');

       $wechatpay    = new WechatPay( $wx_pay_config );
       $openid       = $order_info['openid'];
       $body         = $order_info['product_name'];
       $out_trade_no = $order_info['order_sn'];
       $total_fee    = $order_info['total_price'] * 100;
       $notify_url   = config('url_domain_root') .'mobile/Notify/index';
       $prepayid     = $wechatpay->getPrepayId( $openid, $body, $out_trade_no, $total_fee, $notify_url );
       $wx_res       = $wechatpay -> createMchPay( $prepayid );

      $jsticket    = new WechatScript( $this->option );
      $protocol    = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
      $url         = $protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
      $jssign_info = $jsticket -> getJsSign( $url );
      //return view( 'index', [ 'data'=> json_encode( $wx_res ) ] );
      return view( 'index', [ 'title' => '支付订单', 'data'=> $wx_res, 'obj'=> $jssign_info, 'order_info'=>$order_info] );

前台

<script src="http://res.wx.qq.com/open/js/jweixin-1.1.0.js"></script>
        <script>
          wx.config({
            debug: false,
            appId: '{$obj["appId"]}',
            timestamp: '{$obj["timestamp"]}',
            nonceStr: '{$obj["nonceStr"]}',
            signature: '{$obj["signature"]}',
            jsApiList: [
              // 所有要调用的 API 都要加到这个列表中
                'chooseWXPay',
              ]
          });
        </script>
        <script type="text/javascript">
            function getOrder(){
                wx.chooseWXPay({
                    timestamp: '{$data["timestamp"]}', // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
                    nonceStr: '{$data["nonceStr"]}', // 支付签名随机串,不长于 32 位
                    package: '{$data["package"]}', // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id =***)
                    signType: '{$data["signType"]}', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
                    paySign: '{$data["paySign"]}', // 支付签名
                    success: function (res) {
                        // 支付成功后的回调函数
                        alert('支付成功!');
                        window.location.href = "{:url('Mycenter/index')}";
                    },
                    fail: function (res) {
                        alert(JSON.stringify(res));
                    }
                });
            }
        </script>

注意事项:
1.商户后台填写授权支付域名,如果带参数,最好带一个,其余参数可以根据这个去获取,如:http://xxxxxx/mobile/wxpay/index/order_id/33.html
这时候授权支付域名就是 http://xxxxxx/mobile/wxpay/index/order_id/
2.支付成功异步回调,一定不能继承逻辑代码的父类,最好单独一个类

微信获取config参数及共享地址

后台

$jsticket     = new WechatScript( $this->option );
        $protocol     = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
        $url          = $protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
        $jssign_info  = $jsticket -> getJsSign( $url );

前台

<script src="http://res.wx.qq.com/open/js/jweixin-1.1.0.js"></script>
     <script>
      wx.config({
        debug: false,
        appId: '{$obj["appId"]}',
        timestamp: '{$obj["timestamp"]}',
        nonceStr: '{$obj["nonceStr"]}',
        signature: '{$obj["signature"]}',
        jsApiList: [
          // 所有要调用的 API 都要加到这个列表中
            'checkJsApi',
            'openAddress',
            'editAddress'
          ]
      });
    </script>
    <script language="javascript">
        function callpay()
        {
            wx.openAddress({
                trigger: function (res) {
                   // alert('用户开始拉出地址');
                },
                success: function (res) {
                   var address_info = res.detailInfo + ' ' + res.userName + ' ' + res.telNumber;
                   $('#address').html( address_info );
                   $('#link_people').val( res.userName );
                   $('#link_phone').val( res.telNumber );
                },
                cancel: function (res) {
                   alert('地址拉取取消');
                },
                fail: function (res) {
                   alert('地址拉取失败');
                }
            });
        }
    </script>

二维数组去除重复的一维数组,及按照某一值分组

public function array_unique_fb($array2D){   
        foreach ($array2D as $v){ 
            $v=join(',',$v);//降维,也可以用implode,将一维数组转换为用逗号连接的字符串 
            $temp[]=$v; 
        } 
        $temp=array_unique($temp);//去掉重复的字符串,也就是重复的一维数组 
        foreach ($temp as $k => $v){ 
            $temp[$k]=explode(',',$v);//再将拆开的数组重新组装 
        } 
        return $temp; 
    }
$combine_tem = $this->array_unique_fb( $combine_order );
            foreach ((array)$combine_tem as $key => $value) {
                $store_tem[ $value[0] ][] = $value[1];
            }

tp5隐藏index.php入口文件

Apache

location / { // …..省略部分代码
    if (!-e $request_filename) {
        rewrite  ^(.*)$  /index.php?s=/$1  last;
        break;
    }
}

Phpstudy

<IfModule mod_rewrite.c> 
Options +FollowSymlinks -Multiviews 
RewriteEngine on 
RewriteCond %{REQUEST_FILENAME} !-d 
RewriteCond %{REQUEST_FILENAME} !-f 
RewriteRule ^(.*)$ index.php [L,E=PATH_INFO:$1] 
</IfModule>

Nginx

location / { // …..省略部分代码
    if (!-e $request_filename) {
        rewrite  ^(.*)$  /index.php?s=/$1  last;
        break;
    }
}

判断当前数组是几维数组

if (!empty($service_child_order_list)) {

           foreach ($service_child_order_list as $service_child_order) {
                if( is_array( $service_child_order ) ){
                    $child_order_amount += $service_child_order['order_amount'];
                }else{
                    $child_order_amount = $service_child_order_list['order_amount'];
                }
                //$child_order_amount += $service_child_order['order_amount'];
            }
      }

nginx配置文件

server
    {
        listen 80;
        #listen [::]:80;
        server_name 自己的域名;
        index index.html index.htm index.php default.html default.htm default.php;
        root 路径;

        include none.conf;
        #error_page   404   /404.html;
        #include enable-php.conf;
        include enable-php-pathinfo.conf;
        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
        }

        location ~ .*\.(js|css)?$
        {
            expires      12h;
        }

        location ~ /\.
        {
            deny all;
        }

        access_log 日志;
    }