|
@@ -0,0 +1,453 @@
|
|
|
+<template>
|
|
|
+ <div>
|
|
|
+ <div class="web_box vflex acenter jcenter" v-if="flag == 'null'">
|
|
|
+ <img :src="img_title" class="img_title" alt="">
|
|
|
+ <div class="table">
|
|
|
+ <div class="top hflex acenter jbetween">
|
|
|
+ <div class="hflex acenter">
|
|
|
+ <img src="@/assets/image/file.png" class="img" alt="">
|
|
|
+ <div class="vflex">
|
|
|
+ <div class="title">{{ pageData.title }}</div>
|
|
|
+ <div class="text">该文件<span class="blue">有效期{{ effective }}天</span></div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="btn point" @click="down">下载</div>
|
|
|
+ </div>
|
|
|
+ <div class="all">全部文件</div>
|
|
|
+ <el-table ref="multipleTable" :data="tableData" tooltip-effect="dark" style="width: 100%" @selection-change="handleSelectionChange" max-height="700">
|
|
|
+ <el-table-column type="selection" width="50"></el-table-column>
|
|
|
+ <el-table-column label="文件名" max-width="400">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <!-- <a href="scope.row.url" > -->
|
|
|
+ <div class="hflex acenter">
|
|
|
+ <img src="@/assets/image/link.png" class="icon" alt="">
|
|
|
+ <div class="name text_hide">{{ scope.row.file_name }}</div>
|
|
|
+ </div>
|
|
|
+ <!-- </a> -->
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="大小" max-width="400">
|
|
|
+ <template slot-scope="scope">
|
|
|
+ <div class="name">{{ scope.row.file_size }}</div>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column prop="time" label="创建日期" show-overflow-tooltip></el-table-column>
|
|
|
+ </el-table>
|
|
|
+ </div>
|
|
|
+ <Footers></Footers>
|
|
|
+ </div>
|
|
|
+ <div class="content vflex acenter" v-else>
|
|
|
+ <div style="width: 100%">
|
|
|
+ <el-checkbox-group v-model="checkList" @change="handleCheckedCitiesChange">
|
|
|
+ <div class="table">
|
|
|
+ <div class="cell hflex acenter jbetween" v-for="(item,index) in tableData" :key="index" >
|
|
|
+ <div class="hflex acenter" style="width: 50%">
|
|
|
+ <el-checkbox :label="item.file_url"></el-checkbox>
|
|
|
+ <div class="hflex acenter left">
|
|
|
+ <img src="@/assets/image/link.png" class="icon" alt="">
|
|
|
+ <div class="name text_hide">{{ item.file_name }}</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="text">{{ item.file_size }}</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </el-checkbox-group>
|
|
|
+ </div>
|
|
|
+ <div class="bottom hflex jbetween">
|
|
|
+ <div class="hflex" style="height: 20px">
|
|
|
+ <el-checkbox v-model="checkAll" @change="handleCheckAllChange"></el-checkbox>
|
|
|
+ <div class="text2">全选</div>
|
|
|
+ </div>
|
|
|
+ <div class="btn" @click="down">下载文件</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+</template>
|
|
|
+
|
|
|
+<script>
|
|
|
+import download from "downloadjs"
|
|
|
+ import { debounce } from 'lodash';
|
|
|
+ const fileOptions = [];
|
|
|
+ import Footers from '@/components/footer.vue'
|
|
|
+ import FootersWap from '@/components/footerWap'
|
|
|
+ var that = ''
|
|
|
+ import OSS from 'ali-oss';
|
|
|
+ import CryptoJS from 'crypto-js'
|
|
|
+ // import fs from 'fs';
|
|
|
+
|
|
|
+ // const OSS = require('all-oss');
|
|
|
+ const client = new OSS({
|
|
|
+ region: 'oss-cn-qingdao',
|
|
|
+ accessKeyId: 'LTAI5tRFuXFtzysGSy28kvsp',
|
|
|
+ accessKeySecret: 'f7dVzumtHYoKnUwYRRA8ufIUq9DEhU ',
|
|
|
+ bucket: 'ultrahub-ices',
|
|
|
+ })
|
|
|
+ export default{
|
|
|
+ name: 'down_pc',
|
|
|
+ components: { Footers,FootersWap },
|
|
|
+ data() {
|
|
|
+ return{
|
|
|
+ id: '',
|
|
|
+ img_title: require('@/assets/image/pc_title.png'),
|
|
|
+ effective: 14,
|
|
|
+ pageData: {
|
|
|
+ title: '这是一些学习文件'
|
|
|
+ },
|
|
|
+ tableData: [],
|
|
|
+ checkList: [],
|
|
|
+ code: '',
|
|
|
+ flag: '',
|
|
|
+ isIndeterminate: true,
|
|
|
+ checkAll: false,
|
|
|
+ client: null,
|
|
|
+ }
|
|
|
+ },
|
|
|
+ created() {
|
|
|
+ that = this
|
|
|
+ /* this.client = new OSS({
|
|
|
+ region: 'oss-cn-beijing',
|
|
|
+ accessKeyId: 'LTAI5tRFuXFtzysGSy28kvsp',
|
|
|
+ accessKeySecret: 'f7dVzumtHYoKnUwYRRA8ufIUq9DEhU ',
|
|
|
+ bucket: 'ultrahub-ices',
|
|
|
+ }) */
|
|
|
+ this.flag = window.localStorage.getItem('flag')
|
|
|
+ this.id = window.localStorage.getItem('id')
|
|
|
+ this.effective = this.$route.params.effective
|
|
|
+ if(this.$route.params.code) {
|
|
|
+ this.code = this.$route.params.code
|
|
|
+ }
|
|
|
+ this.getData()
|
|
|
+
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ decypt(text) {
|
|
|
+ var key = CryptoJS.enc.Utf8.parse('1463587320654321'); //为了避免补位,直接用16位的秘钥
|
|
|
+ var iv = CryptoJS.enc.Utf8.parse('1758326540123456'); //16位初始向量
|
|
|
+ var encrypted = CryptoJS.AES.decrypt(text, key, {
|
|
|
+ iv: iv,
|
|
|
+ mode:CryptoJS.mode.CBC,
|
|
|
+ padding:CryptoJS.pad.Pkcs7
|
|
|
+ });
|
|
|
+ let url = encrypted.toString(CryptoJS.enc.Utf8)
|
|
|
+ },
|
|
|
+ getData() {
|
|
|
+ let that = this
|
|
|
+ let data = {
|
|
|
+ id: that.id,
|
|
|
+ password: that.code
|
|
|
+ }
|
|
|
+ that.$http.getFile(data).then((res) => {
|
|
|
+ if(res.data.code == 0) {
|
|
|
+ this.$message.error({
|
|
|
+ message: res.data.msg,
|
|
|
+ customClass: 'font20'
|
|
|
+ })
|
|
|
+ this.$router.push('index_pc')
|
|
|
+ } else if(res.data.code == 1) {
|
|
|
+ that.tableData = res.data.data
|
|
|
+ for(var i=0;i<that.tableData.length;i++) {
|
|
|
+ fileOptions.push(that.tableData[i].file_url)
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ })
|
|
|
+ },
|
|
|
+ urlToBold(url){
|
|
|
+ const loading = this.$loading({
|
|
|
+ lock: true,
|
|
|
+ text: 'Loading',
|
|
|
+ spinner: 'el-icon-loading',
|
|
|
+ background: 'rgba(0, 0, 0, 0.7)'
|
|
|
+ });
|
|
|
+ let http = url.split('?')[0];
|
|
|
+ let file = http.split('/');
|
|
|
+ let fileName = file[file.length - 1];
|
|
|
+
|
|
|
+ fetch(url).then(res => res.blob()).then(blob => { // 将链接地址字符内容转变成blob地址
|
|
|
+ if(blob) {
|
|
|
+ loading.close();
|
|
|
+ download(blob,fileName)
|
|
|
+
|
|
|
+ /* const aLink = document.createElement('a')
|
|
|
+ aLink.href = URL.createObjectURL(blob)
|
|
|
+ // 文件名字
|
|
|
+ aLink.download = fileName;
|
|
|
+ document.body.appendChild(aLink)
|
|
|
+ aLink.click()
|
|
|
+ aLink.remove(); */
|
|
|
+ }
|
|
|
+
|
|
|
+ }).catch(error => {
|
|
|
+ })
|
|
|
+ },
|
|
|
+ /*
|
|
|
+ * 获取文件流并处理
|
|
|
+ */
|
|
|
+ async getFileAsStream(key) {
|
|
|
+ try {
|
|
|
+ const result = await client.getStream(key);
|
|
|
+ const blobStream = result.stream;
|
|
|
+ }catch (error) {
|
|
|
+ }
|
|
|
+ },
|
|
|
+ /* getFileAsStream(key) {
|
|
|
+ that.client.getStream(key).then((res) => {
|
|
|
+ console.log(res);
|
|
|
+ }).catch((error) => {
|
|
|
+ console.log('错误',error);
|
|
|
+ })
|
|
|
+ }, */
|
|
|
+ handleSelectionChange(value) {
|
|
|
+ this.checkList = value
|
|
|
+ },
|
|
|
+ handleCheckAllChange(val) {
|
|
|
+ this.checkList = val ? fileOptions : [];
|
|
|
+ this.isIndeterminate = false;
|
|
|
+ },
|
|
|
+ handleCheckedCitiesChange(value) {
|
|
|
+ let checkedCount = value.length;
|
|
|
+ this.checkAll = checkedCount === fileOptions.length;
|
|
|
+ this.isIndeterminate = checkedCount > 0 && checkedCount < fileOptions.length;
|
|
|
+ },
|
|
|
+ timestampToTime(times) {
|
|
|
+ let time = times[1]
|
|
|
+ let mdy = times[0]
|
|
|
+ mdy = mdy.split('/')
|
|
|
+ let month = parseInt(mdy[0]);
|
|
|
+ let day = parseInt(mdy[1]);
|
|
|
+ let year = parseInt(mdy[2])
|
|
|
+ return year + '-' + month + '-' + day + ' ' + time
|
|
|
+ },
|
|
|
+ down:debounce(() => {
|
|
|
+ if(that.checkList.length == 0) {
|
|
|
+ that.$message.error({
|
|
|
+ message: '请先选择要下载的文件',
|
|
|
+ customClass: 'font20'
|
|
|
+ })
|
|
|
+ }
|
|
|
+ let datas = {
|
|
|
+ file_num: that.checkList.length
|
|
|
+ }
|
|
|
+ let time = that.timestampToTime(new Date().toLocaleString('en-US',{hour12: false}).split(" "))
|
|
|
+ let data = {
|
|
|
+ UUID: window.localStorage.getItem('UUID'),
|
|
|
+ name: 'qr_code_download',
|
|
|
+ packageName: window.localStorage.getItem('package_name'),
|
|
|
+ timestamp: time,
|
|
|
+ data: JSON.stringify(datas)
|
|
|
+ }
|
|
|
+ that.$http.getTotal(data).then((res) => {
|
|
|
+
|
|
|
+ })
|
|
|
+
|
|
|
+ if(that.flag !== 'null') {
|
|
|
+ for (let i = 0; i < that.checkList.length; i++) {
|
|
|
+ if (that.checkList[i]) {
|
|
|
+ // that.downloadFile(that.checkList[i])
|
|
|
+ that.urlToBold(that.checkList[i])
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ for (let i = 0; i < that.checkList.length; i++) {
|
|
|
+ if (that.checkList[i].file_url) {
|
|
|
+ // that.downloadFile(that.checkList[i].file_url)
|
|
|
+ that.urlToBold(that.checkList[i].file_url)
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ }, 500),
|
|
|
+ downloadFile(url) {
|
|
|
+ const iframe = document.createElement("iframe");
|
|
|
+ iframe.style.display = "none"; // 防止影响页面
|
|
|
+ iframe.style.height = 0; // 防止影响页面
|
|
|
+ iframe.src = url;
|
|
|
+ document.body.appendChild(iframe); // 这一行必须,iframe挂在到dom树上才会发请求
|
|
|
+ // 5分钟之后删除(onload方法对于下载链接不起作用,就先抠脚一下吧)
|
|
|
+ setTimeout(() => {
|
|
|
+ iframe.remove();
|
|
|
+ }, 5 * 60 * 1000);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+</script>
|
|
|
+
|
|
|
+<style scoped>
|
|
|
+ .web_box {
|
|
|
+ width: 100%;
|
|
|
+ min-height: 100vh;
|
|
|
+ background: url('@/assets/image/pc_bg.png') no-repeat;
|
|
|
+ background-size: 100% 100%;
|
|
|
+ }
|
|
|
+
|
|
|
+ .web_box .img_title {
|
|
|
+ width: 440px;
|
|
|
+ height: 89px;
|
|
|
+ margin: 80px 0 112px;
|
|
|
+ }
|
|
|
+ .web_box .table {
|
|
|
+ /* min-width: 800px; */
|
|
|
+ width: 60%;
|
|
|
+ /* height: 777px; */
|
|
|
+ background: #FFFFFF;
|
|
|
+ border-radius: 10px;
|
|
|
+ box-sizing: border-box;
|
|
|
+ padding: 20px;
|
|
|
+ margin-bottom: 100px;
|
|
|
+ }
|
|
|
+ .web_box .table .top {
|
|
|
+ padding-bottom: 25px;
|
|
|
+ width: 100%;
|
|
|
+ border-bottom: 1px solid #F5F5F5;
|
|
|
+ }
|
|
|
+ .web_box .table .top .img {
|
|
|
+ width: 60px;
|
|
|
+ height: 60px;
|
|
|
+ margin-right: 10px;
|
|
|
+ }
|
|
|
+ .web_box .table .top .title {
|
|
|
+ font-size: 20px;
|
|
|
+ font-family: PingFangSC-Medium, PingFang SC;
|
|
|
+ font-weight: 500;
|
|
|
+ color: #333333;
|
|
|
+ line-height: 28px;
|
|
|
+ padding-bottom: 5px;
|
|
|
+ }
|
|
|
+ .web_box .text {
|
|
|
+ font-size: 16px;
|
|
|
+ font-family: PingFangSC-Medium, PingFang SC;
|
|
|
+ font-weight: 500;
|
|
|
+ color: #999999;
|
|
|
+ line-height: 22px;
|
|
|
+ }
|
|
|
+ .web_box .blue {
|
|
|
+ color: #1677B3;
|
|
|
+ }
|
|
|
+ .web_box .table .top .btn {
|
|
|
+ width: 121px;
|
|
|
+ height: 60px;
|
|
|
+ background: #FFFFFF;
|
|
|
+ border-radius: 10px;
|
|
|
+ border: 1px solid #1677B3;
|
|
|
+ font-size: 20px;
|
|
|
+ font-family: PingFangSC-Medium, PingFang SC;
|
|
|
+ font-weight: 500;
|
|
|
+ color: #1677B3;
|
|
|
+ line-height: 60px;
|
|
|
+ text-align: center;
|
|
|
+ }
|
|
|
+ .web_box .table .all {
|
|
|
+ font-size: 16px;
|
|
|
+ font-family: PingFangSC-Regular, PingFang SC;
|
|
|
+ font-weight: 400;
|
|
|
+ color: #666666;
|
|
|
+ line-height: 22px;
|
|
|
+ padding: 20px 0;
|
|
|
+ }
|
|
|
+ .web_box .icon {
|
|
|
+ width: 20px;
|
|
|
+ height: 20px;
|
|
|
+ margin-right: 10px;
|
|
|
+ }
|
|
|
+
|
|
|
+ /deep/ .el-message {
|
|
|
+ font-size: 20px !important;
|
|
|
+ }
|
|
|
+</style>
|
|
|
+<style>
|
|
|
+ .font20 {
|
|
|
+ font-size: 20px !important;
|
|
|
+ }
|
|
|
+</style>
|
|
|
+
|
|
|
+<style scoped>
|
|
|
+ .content {
|
|
|
+ width: 100%;
|
|
|
+ min-height: 100vh;
|
|
|
+ background: #F5F5F5;
|
|
|
+ }
|
|
|
+
|
|
|
+ .content .table {
|
|
|
+ /* width: 100%; */
|
|
|
+ background: #FFFFFF;
|
|
|
+ border-radius: 10px;
|
|
|
+ box-sizing: border-box;
|
|
|
+ padding: 0 20px;
|
|
|
+ margin-bottom: 100px;
|
|
|
+ }
|
|
|
+ .content .cell {
|
|
|
+ width: 100%;
|
|
|
+ padding: 22px 0;
|
|
|
+ border-top: 1px solid #F5F5F5;
|
|
|
+ }
|
|
|
+ .content .left {
|
|
|
+ padding-left: 23px;
|
|
|
+ max-width: 100%;
|
|
|
+ }
|
|
|
+ .content .text {
|
|
|
+ font-size: 14px;
|
|
|
+ font-family: PingFangSC-Medium, PingFang SC;
|
|
|
+ font-weight: 500;
|
|
|
+ color: #666666;
|
|
|
+ line-height: 20px;
|
|
|
+ }
|
|
|
+ .content .name {
|
|
|
+ font-size: 14px;
|
|
|
+ font-family: PingFangSC-Regular, PingFang SC;
|
|
|
+ font-weight: 400;
|
|
|
+ color: rgba(0,0,0,0.88);
|
|
|
+ line-height: 22px;
|
|
|
+ }
|
|
|
+ .content .icon {
|
|
|
+ width: 16px;
|
|
|
+ height: 16px;
|
|
|
+ margin-right: 4px;
|
|
|
+ }
|
|
|
+ .content .bottom {
|
|
|
+ width: 100%;
|
|
|
+ height: 80px;
|
|
|
+ background: #FFFFFF;
|
|
|
+ padding: 10px 14px;
|
|
|
+ box-sizing: border-box;
|
|
|
+ position: fixed;
|
|
|
+ left: 0;
|
|
|
+ bottom: 0;
|
|
|
+ z-index: 99;
|
|
|
+ }
|
|
|
+ .content .btn {
|
|
|
+ width: 107px;
|
|
|
+ height: 40px;
|
|
|
+ background: #1677B3;
|
|
|
+ border-radius: 20px;
|
|
|
+ font-size: 14px;
|
|
|
+ font-family: PingFangSC-Medium, PingFang SC;
|
|
|
+ font-weight: 500;
|
|
|
+ color: #FFFFFF;
|
|
|
+ line-height: 40px;
|
|
|
+ text-align: center;
|
|
|
+ }
|
|
|
+ .content .text2 {
|
|
|
+ font-size: 14px;
|
|
|
+ font-family: PingFangSC-Medium, PingFang SC;
|
|
|
+ font-weight: 500;
|
|
|
+ color: #666666;
|
|
|
+ line-height: 20px;
|
|
|
+ padding-left: 10px;
|
|
|
+ }
|
|
|
+ .content /deep/ .el-checkbox__label {
|
|
|
+ display: none;
|
|
|
+ }
|
|
|
+ .content /deep/.el-checkbox__inner {
|
|
|
+ border-radius: 50%;
|
|
|
+ }
|
|
|
+</style>
|
|
|
+<style>
|
|
|
+ .font10 {
|
|
|
+ font-size: 15px !important;
|
|
|
+ }
|
|
|
+ .el-icon-loading {
|
|
|
+ font-size: 50px;
|
|
|
+ }
|
|
|
+</style>
|