快乐每一天

自己选择的路,跪着也要走下去...

分类 技能进阶 下的文章

VisualSVN项目管理技巧

第一步:找一台电脑,内存足够大,用来搭建局域网svn主机

安装VisualSVN教程:
https://jingyan.baidu.com/article/870c6fc36a31d0b03fe4be3f.html

汉化版svn下载
http://www.mycodes.net/70/1544.htm

2019-03-18T06:29:18.png

第二步:在VisualSVN里面选择Users创建所有开发人员的账号密码,用文本记录好
第三步:创建对应的项目分组,比如说我要创建一个电商的项目分组,可以直接创建对应的电商名称简写,勾选相关开发人员到对应的分组即可。
第四步:点击Reositories 创建对应的项目名称,可以用中文命名,创建项目的时候就可以直接勾选项目权限分组,切记千万别允许所有人访问。
1)第一步
2019-03-18T06:29:28.png
2)第二步:
2019-03-18T06:29:34.png
3)第三步:
2019-03-18T06:29:39.png
4)第四步:
2019-03-18T06:29:46.png
5)第五步:
2019-03-18T06:36:01.png
6)第六步:
2019-03-18T06:34:51.png

在每个项目下面分别有trunk跟tags两个目录。
Trunk目录为开发目录,tags目录为稳定的项目版本目录。下面分别对这两个目录的格式做一下规范。

上面就是一个完整项目的所有步骤,以及目录结构,每一个目录都可以单独设置权限,只有tags目录有最高管理权限,开发人员只有trunk目录的权限,项目经理或者项目负责人才有tags的权限,一旦项目结束,删除对应的开发人员的目录权限。
Db目录放置的是可以直接执行的sql文件,如果项目sql文件过大,需要另附上说明文档讲明导入方案。
Doc目录是项目相关的所有文件,包括线上线下项目安装运行的的详细步骤,以及psd图,项目确认函,功能表文档。
Html 静态html文件目录
Project 源码目录
MiniProgram 小程序源码目录

Tags里面的目录结构也是一样的,含义也是一样的。最外层包了一个版本号,主要是方便项目回退以及代码版本管理。

做这个的目的也是为了提高项目质量,严格做好codereview工作。

阅读全文

小程序推广分享带参数二维码生成

一、二维码生成类库

<?php
/**
 * Created by PhpStorm.
 * User: 项羽
 * Date: 2019/1/22
 * Time: 22:55
 * 生成小程序码接口地址    https://developers.weixin.qq.com/miniprogram/dev/api/getWXACodeUnlimit.html
 */

namespace app\api\controller;

class Spreadcode
{
//    获取accesstoken
    public function getAccesstoken(){

        $appid = '';                     /*小程序appid*/
        $srcret = '';      /*小程序秘钥*/

        $tokenUrl="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$appid."&secret=".$srcret;
        $getArr=array();
        $tokenArr=json_decode($this->send_post($tokenUrl,$getArr,"GET"));

        $access_token=$tokenArr->access_token;

        return $access_token;
    }

    public function send_post($url, $post_data,$method='POST') {
        $postdata = http_build_query($post_data);
        $options = array(
            'http' => array(
                'method' => $method, //or GET
                'header' => 'Content-type:application/x-www-form-urlencoded',
                'content' => $postdata,
                'timeout' => 15 * 60 // 超时时间(单位:s)
            )
        );
        $context = stream_context_create($options);
        $result = file_get_contents($url, false, $context);
        return $result;
    }



    public function api_notice_increment($url, $data){
        $ch = curl_init();
        $header=array('Accept-Language:zh-CN','x-appkey:114816004000028','x-apsignature:933931F9124593865313864503D477035C0F6A0C551804320036A2A1C5DF38297C9A4D30BB1714EC53214BD92112FB31B4A6FAB466EEF245710CC83D840D410A7592D262B09D0A5D0FE3A2295A81F32D4C75EBD65FA846004A42248B096EDE2FEE84EDEBEBEC321C237D99483AB51235FCB900AD501C07A9CAD2F415C36DED82','x-apversion:1.0','Content-Type:application/x-www-form-urlencoded','Accept-Charset: utf-8','Accept:application/json','X-APFormat:json');
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
        curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
        curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
        curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        $tmpInfo = curl_exec($ch);
        //         var_dump($tmpInfo);
        //        exit;
        if (curl_errno($ch)) {
            return false;
        }else{
            // var_dump($tmpInfo);
            return $tmpInfo;
        }
    }

    /*上面生成的是数量限制10万的二维码,下面重写数量不限制的码*/
    /*getWXACodeUnlimit*/
    /*码一,圆形的小程序二维码,数量限制一分钟五千条*/
    /*45009    调用分钟频率受限(目前5000次/分钟,会调整),如需大量小程序码,建议预生成。
    41030    所传page页面不存在,或者小程序没有发布*/
    public function mpcode($page,$cardid){
        //参数
//        $postdata['scene']="nidaodaodao";
        $postdata['scene']=$cardid;
        // 宽度
        $postdata['width']=430;
        // 页面
        $postdata['page']=$page;
//        $postdata['page']="pages/postcard/postcard";
        // 线条颜色
        $postdata['auto_color']=false;
        //auto_color 为 false 时生效
        $postdata['line_color']=['r'=>'0','g'=>'0','b'=>'0'];
        // 是否有底色为true时是透明的
        $postdata['is_hyaline']=true;

        $post_data = json_encode($postdata);
        $access_token=$this->getAccesstoken();
        $url="https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=".$access_token;
        $result=$this->api_notice_increment($url,$post_data);

        $data='image/png;base64,'.base64_encode($result);
        return $data;
//        echo '<img src="data:'.$data.'">';
    }


    /*码二,正方形的二维码,数量限制调用十万条*/
    public function qrcodes(){
        $path="pages/postcard/postcard";
        // 宽度
        $postdata['width']=430;
        // 页面
        $postdata['path']=$path;
        $post_data = json_encode($postdata);

        $access_token=$this->getAccesstoken();
        $url="https://api.weixin.qq.com/cgi-bin/wxaapp/createwxaqrcode?access_token=".$access_token;
        $result=$this->api_notice_increment($url,$post_data);

        $data='image/png;base64,'.base64_encode($result);
        echo '<img src="data:'.$data.'">';
    }


}

二、php调用方法

$page='pages/postcard/postcard';
$cardid="10";
$class = new \app\api\controller\Spreadcode();
$mpcodeimg=$class->mpcode($page,$cardid);
$dataret['mpcodeimg']=$mpcodeimg;
$this->assign('retdata',$dataret);

三、前端页面调用

<img src="data:{$retdata['mpcodeimg']}" />

阅读全文

解决Iphone手机H5播放器的问题

一、HTML部分:

<div class="col-md-3 .col-xs-6 .col-sm-4 bigwindow" >
    <div class="audio">
<!--                <video class="obgj" poster="https://wx.ahwrkj.com/img/2.jpg" controls="controls" preload="none"  mediagroup="myVideoGroup" >-->
<!--                    <source  src="https://wx.ahwrkj.com/mp4/2.mp4" type="video/mp4">-->
<!--                </video>-->

        <div class="obgj">
            <i class="video-i" data-src="https://wx.ahwrkj.com/mp4/2.mp4">
                <img class="img1" src="https://wx.ahwrkj.com/img/2.jpg"/>
                <img class="img2 video-go" src="https://mstatic.soyoung.com/m/static/img/product/video_go.png"/>
            </i>
        </div>

        <span class="mp4title">宿州皖能党支部_有限空间应急演练</span>
    </div>
    <div class="actions">
        <button class="btn btn-info  btn-lg dianzanBox">投票</button>
        <input type="hidden" value="2">
        <span class="piao"> <span id="num2"><?php
                $cc=$user->counttp(2) ;
                echo $cc;
                ?></span>票   </span>
    </div>
</div>

二、Js部分

<script src="js/jweixin-1.0.0.js"></script>
<script>
    /**
     * 视频加载兼容处理
     */
    var isIPhone = window.navigator.appVersion.match(/iphone/gi);
    var creat_video = function () {
        var _video = document.getElementsByClassName('video-i');
        if (_video.length > 0) {
            for (var i = 0; i < _video.length; i++) {
                var _that = _video[i];
                _that.addEventListener('click', function (e) {
                    var _this = e.currentTarget,
                        _videoUrl = _this.getAttribute('data-src'),
                        _img = _this.children[0].getAttribute('src'),
                        _dom = document.createElement('video'),
                        _autoPlayAllowed = true,
                        _loading = document.createElement('div'),
                        _p,
                        _process = document.createElement('i');
                    _noSound = document.createElement('em');
                    if (_this.getAttribute('data-video')) {
                        var _video = _this.parentNode.querySelectorAll('video');
                        var _noSound = _this.parentNode.querySelectorAll('.no-sound');
                        if (_video.length > 0) {
                            _dom = _video[0];
                            // if (_dom.ended) {
                            if (isIPhone) {
                                //修改Ios11状态不准,视频无法播放的问题
                                if (_dom.src.indexOf('random') > -1) {
                                    _dom.src = _dom.src.split('random=')[0] + 'random=' + _dom.src.split('random=')[1] + 1;
                                } else {
                                    _dom.src = _dom.src + '?random=' + Math.floor(Math.random() * (100 - 10 + 1) + 10);
                                }
                            }
                            _noSound[0].classList.remove('hide');
                            _dom.play();
                            _this.classList.add('hide');
                            _dom.classList.remove('hide');
                            // }
                        }
                        return;
                    }
                    _this.setAttribute('data-video', '1');
                    _process.setAttribute('class', 'vjs-process');
                    _process.innerHTML = '加载中...';
                    _loading.setAttribute('class', 'vjs-loading-spinner');
                    _dom.setAttribute('src', _videoUrl);
                    _dom.setAttribute('controls', 'controls');
                    _dom.setAttribute('autoPlay', 'false');
                    // _dom.setAttribute('x5-video-player-type', 'h5');
                    _this.parentNode.appendChild(_loading);
                    _this.parentNode.appendChild(_process);
                    _this.parentNode.classList.add('vjs-waiting');
                    _noSound.setAttribute('class', 'no-sound');
                    // _noSound.innerHTML = '无声';
                    // _dom.setAttribute('webkit-playsinline', 'webkit-playsinline');
                    // _dom.setAttribute('playsinline', 'playsinline');
                    _dom.setAttribute('poster', _img);
                    _p = _dom.play();
                    console.time("加载毫秒");
                    var _dom_buffered_promise = function () {
                        var _end = _dom.buffered.end(0);
                        var _duration = _dom.duration;
                        var _a = Math.round(_end / _duration * 100);
                        _process.innerHTML = _a + '%';
                        console.log(_end + ' ' + _duration)
                        if (_a < 10) {
                            setTimeout(_dom_buffered, 200);
                        } else {
                            _dom_buffered();
                        }
                    };
                    var _dom_buffered = function () {
                        _this.parentNode.classList.remove('vjs-waiting');
                        _this.classList.add('hide');
                        _process.classList.add('hide');
                        _this.parentNode.appendChild(_dom);
                        _this.parentNode.appendChild(_noSound);
                        _dom.addEventListener('ended', function () {
                            _dom.classList.add('hide');
                            _this.classList.remove('hide');
                            _noSound.classList.add('hide');
                        });
                        _dom.currentTime = 0;
                        console.timeEnd("加载毫秒");
                    };
                    if (_p instanceof Promise) {
                        _p.catch(function (error) {
                            console.log(error.message);
                            if (error.name === 'NotAllowedError') {
                                _autoPlayAllowed = false;
                            }
                        }).then(function (e) {
                            if (_autoPlayAllowed) {
                                _dom_buffered_promise();
                            }
                        });
                    } else {
                        //ios8-9拿不到promise需要给个延时处理
                        setTimeout(function () {
                            _dom_buffered();
                        }, 4000);
                    }
                });
            }
        }
    };
    new creat_video();
</script>
阅读全文