170 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			170 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html lang="zh">
 | |
| <head>
 | |
|     <meta charset="UTF-8">
 | |
|     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | |
|     <meta http-equiv="X-UA-Compatible" content="ie=edge">
 | |
|     <title>上传文件</title>
 | |
|     <style>
 | |
|         * {
 | |
|             margin: 0;
 | |
|             padding: 0;
 | |
|             height: 100%;
 | |
|             width: 100%;
 | |
|         }
 | |
| 
 | |
|         .head-btn {
 | |
|             text-align: center;
 | |
|             height: 100%;
 | |
|             width: 100%;
 | |
|         }
 | |
| 
 | |
|         .file {
 | |
|             position: relative;
 | |
|             display: flex;
 | |
|             justify-content: center;
 | |
|             align-items: center;
 | |
|             height: 100%;
 | |
|             width: 100%;
 | |
|             text-decoration: none;
 | |
|             text-indent: 0;
 | |
|             overflow: hidden;
 | |
|             color: transparent;
 | |
|         }
 | |
| 
 | |
|         .fileName {
 | |
|             display: flex;
 | |
|             justify-content: center;
 | |
|             align-items: center;
 | |
|         }
 | |
| 
 | |
|         .file input {
 | |
|             position: absolute;
 | |
|             font-size: 20px;
 | |
|             right: 0;
 | |
|             top: 0;
 | |
|             opacity: 0;
 | |
|         }
 | |
|     </style>
 | |
| </head>
 | |
| <body>
 | |
| <div class="head-btn">
 | |
|     <form action="" method="post">
 | |
|         <a href="javascript:;" class="file" id="selectFile">
 | |
|             <span class="fileName"></span>
 | |
|             <input type="file" name="uploadFile" id="uploadFile">
 | |
|         </a>
 | |
|     </form>
 | |
| </div>
 | |
| 
 | |
| <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.js"></script>
 | |
| <script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js">
 | |
| </script>
 | |
| <script src="https://cdn.jsdelivr.net/npm/cos-js-sdk-v5/dist/cos-js-sdk-v5.min.js"></script>
 | |
| <script>
 | |
| 
 | |
|     var files = []
 | |
|     var options = {}
 | |
|     var cos = new COS({
 | |
|         getAuthorization: function (options, callback) {
 | |
|             // 使用 fetch 发送请求
 | |
|             fetch('http://122.51.230.86:48080/admin-api/cos/sts',{
 | |
|                 headers: {
 | |
|                     'Content-Type': 'application/json', // 指定 JSON 格式
 | |
|                     'Tenant-Id': '180' // 添加 tenantId 头部
 | |
|                 }
 | |
|             })
 | |
|                 .then(response => response.json()) // 解析 JSON 数据
 | |
|                 .then(data => {
 | |
|                     if (!data || !data.credentials) {
 | |
|                         return console.error('credentials invalid:\n' + JSON.stringify(data, null, 2));
 | |
|                     }
 | |
|                     const { credentials } = data;
 | |
|                     callback({
 | |
|                         TmpSecretId: credentials.tmpSecretId,
 | |
|                         TmpSecretKey: credentials.tmpSecretKey,
 | |
|                         SecurityToken: credentials.sessionToken,
 | |
|                         StartTime: data.startTime, // 时间戳,单位秒
 | |
|                         ExpiredTime: data.expiredTime, // 时间戳,单位秒
 | |
|                         ScopeLimit: true
 | |
|                     });
 | |
|                 })
 | |
|                 .catch(error => {
 | |
|                     console.error('获取临时密钥失败', error);
 | |
|                 });
 | |
|         }
 | |
|     });
 | |
| 
 | |
|     function passInfo(info) {
 | |
|         options = info;
 | |
|         console.log('接口相关参数' + JSON.stringify(info))
 | |
|     }
 | |
| 
 | |
|     function setStyle(info) {
 | |
|         console.log('样式' + info.fileStyle)
 | |
|         for (let k in info.fileStyle) {
 | |
|             $(".file").css(k, info.fileStyle[k])
 | |
|         }
 | |
|         $('.fileName').html(info.fileTitle)
 | |
|     }
 | |
| 
 | |
|     // console.log(44456,getQuery('token')); // 调用获取参数
 | |
|     $(".file").on("change", "input[type='file']", function () {
 | |
|         files = [];
 | |
|         let filePath = $(this).val();
 | |
|         console.log(filePath)
 | |
|         uni.postMessage({
 | |
|             data: {
 | |
|                 filePath: filePath,
 | |
|             }
 | |
|         })
 | |
|         console.log(document.getElementById('uploadFile').files[0])
 | |
|         let file = document.getElementById('uploadFile').files[0];
 | |
|         files.push(file)
 | |
|         console.log(JSON.stringify(files))
 | |
|         if (options.url) {
 | |
|             upload()
 | |
|         }
 | |
|         console.log(files.length)
 | |
|     });
 | |
| 
 | |
|     function upload() {
 | |
|         if (!files || files.length === 0) {
 | |
|             console.error("未选择文件");
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         const file = files[0]; // 获取第一个文件
 | |
|         const fileName = file.name; // 获取文件名
 | |
|         const Bucket = 'lanan-1319802091'; // 请替换成你的 COS 存储桶名称
 | |
|         const Region = 'ap-chengdu'; // 请替换成你的 COS 地域,如 'ap-shanghai'
 | |
|         const Key = 'uploads/' + fileName; // 你希望存储在 COS 中的路径
 | |
| 
 | |
|         console.log("开始上传文件:", fileName);
 | |
| 
 | |
|         cos.uploadFile({
 | |
|             Bucket,
 | |
|             Region,
 | |
|             Key,
 | |
|             Body: file, // 直接使用 File 对象
 | |
|             onProgress: function (progressData) {
 | |
|                 console.log('上传进度:', JSON.stringify(progressData));
 | |
|             }
 | |
|         }, function (err, data) {
 | |
|             if (err) {
 | |
|                 console.error('上传失败:', err);
 | |
|             } else {
 | |
|                 console.log('上传成功:', data);
 | |
|                 uni.postMessage({
 | |
|                     data: {
 | |
|                         files: ['https://' + data.Location] // 返回 COS 上的文件访问 URL
 | |
| 
 | |
|                     }
 | |
|                 });
 | |
|             }
 | |
|         });
 | |
|     }
 | |
| </script>
 | |
| </body>
 | |
| </html>
 | 
