hdjs framework


Keywords
hdjs, houdunwang, 向军大叔, 后盾人, 后盾网
License
MIT
Install
npm install hdjs@4.0.18

Documentation

hdjs

基本模块化的前端组件库

##后台签名

<?php
class Oss
{
    //生成供前台使用的签名
    public static function sign()
    {
        //阿里云 AccessKeyId
        $id = 'xxxxxx';
        //阿里云  AccessKeySecret
        $key = 'xxxxx';
        //OSS外网域名: 在阿里云后台OSS bucket中查看
        $host = 'http://hdxj.oss-cn-hangzhou.aliyuncs.com';
        //oss中本次上传存放文件的目录
        $dir = $_GET['dir'];
        function gmt_iso8601($time)
        {
            $dtStr      = date("c", $time);
            $mydatetime = new \DateTime($dtStr);
            $expiration = $mydatetime->format(\DateTime::ISO8601);
            $pos        = strpos($expiration, '+');
            $expiration = substr($expiration, 0, $pos);
            return $expiration."Z";
        }

        $now        = time();
        $expire     = 30; //设置该policy超时时间是10s. 即这个policy过了这个有效时间,将不能访问
        $end        = $now + $expire;
        $expiration = gmt_iso8601($end);

        //最大文件大小.用户可以自己设置
        $condition    = [0 => 'content-length-range', 1 => 0, 2 => 1048576000];
        $conditions[] = $condition;

        //表示用户上传的数据,必须是以$dir开始, 不然上传会失败,这一步不是必须项,只是为了安全起见,防止用户通过policy上传到别人的目录
        $start        = [0 => 'starts-with', 1 => '$key', 2 => $dir];
        $conditions[] = $start;

        $arr = ['expiration' => $expiration, 'conditions' => $conditions];
        //return;
        $policy         = json_encode($arr);
        $base64_policy  = base64_encode($policy);
        $string_to_sign = $base64_policy;
        $signature      = base64_encode(hash_hmac('sha1', $string_to_sign, $key, true));

        $response              = [];
        $response['accessid']  = $id;
        $response['host']      = $host;
        $response['policy']    = $base64_policy;
        $response['signature'] = $signature;
        $response['expire']    = $end;
        //这个参数是设置用户上传指定的前缀
        $response['dir'] = $dir;
        return json_encode($response);
    }
}
echo Oss::sign();

##前台

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>OSS上传</title>
    <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.css" rel="stylesheet">
    <script>
        //模块配置项
        var hdjs = {
            //框架目录
            'base': '../../',
        };
    </script>
    <script src="../../app/util.js"></script>
    <script src="../../require.js"></script>
    <script src="../../config.js"></script>
</head>
<body>
<div class="input-group">
    <input type="text" class="form-control" v-model="v.path">
    <span class="input-group-btn">
        <button class="btn btn-default" type="button" id="pickVideo">上传文件</button>
   </span>
</div>
</div>
<script>
    function upload() {
        require(['oss'], function (oss) {
            var id = '#pickVideo';
            var uploader = oss.upload({
                //获取签名
                serverUrl: 'sign.php?',
                //上传目录
                dir: 'houdunwang/',
                //按钮元素
                pick: id,
                accept: {
                    title: 'Images',
//                  extensions: 'mp4',
//                  mimeTypes: 'video/mp4'
                }
            });
            //上传开始
            uploader.on('startUpload', function () {
                console.log('开始上传');
            });
            //上传成功
            uploader.on('uploadSuccess', function (file, response) {
                console.log('上传完成,文件名:' + oss.oss.host + '/' + oss.oss.object_name);
            });
            //上传中
            uploader.on('uploadProgress', function (file, percentage) {
                console.log('上传中,进度:' + parseInt(percentage * 100));
            })
            //上传结束
            uploader.on('uploadComplete', function () {
                console.log('上传结束');
            })
        });
    }
    upload();
</script>
</body>
</html>