IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Node.js操作阿里云OSS——跨域设置&上传图片&获取响应图片URL -> 正文阅读

[JavaScript知识库]Node.js操作阿里云OSS——跨域设置&上传图片&获取响应图片URL

Node.js操作阿里云OSS——跨域设置&上传图片&获取响应图片URL

安装和引入依赖

在终端安装


 1. npm i ali-oss --save
 2. npm i path --save

后引入const OSS = require('ali-oss') const path = require('path')

跨域设置

想要在node中使用阿里云oss,首先需要进行跨域设置

        const client = new OSS({
            // 以华南3(广州)为例,region填写为oss-cn-guangzhou。
            region: '你的region',
            // 阿里云账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM用户进行API访问或日常运维,请登录RAM控制台创建RAM用户。
            accessKeyId: '你的accessKeyId',
            accessKeySecret: '你的AccessKeySecret',
            // 填写待配置跨域资源共享规则的Bucket名称。
            bucket: '你创建的bucket名'
        });

找不到accessKeyId和accessKeySecret,请先在

权限管理——Bucket 授权策略——设置——新增授权
在这里插入图片描述

里进行新增授权,后获取这两个值

然后

const rules = [{
            // 指定允许跨域请求的来源,支持通配符星号(*),表示允许所有的来源域。
            allowedOrigin: '你的bucket url路径 例如www.test.com',
            // 指定允许的跨域请求方法,支持GET、PUT、DELETE、POST和HEAD方法。
            allowedMethod: 'GET',
            // 指定允许跨域请求的响应头。建议无特殊情况下将此项设置为通配符星号(*)。
            allowedHeader: '*',
            // 指定允许用户从应用程序中访问的响应头,例如一个JavaScript的XMLHttpRequest对象。不允许使用通配符星号(*)。
            exposeHeader: 'Content-Length',
            // 指定浏览器对特定资源的预取(OPTIONS)请求返回结果的缓存时间,单位为秒。
            maxAgeSeconds: '你喜欢~'
        }];
        // 最多允许设置10条跨域资源共享规则。如果配置了相同的规则,则已存在的规则将被覆盖。
        const putResult = await client.putBucketCORS('bucket名', rules);

console.log(putResult.res);一下,没报错就证明配置成功啦!!!~~~

上传图片

进行跨域设置之后,就可以进行上传图片啦!!!

        //上传图片到oss
        async function put() {
            try {
                // 填写OSS文件完整路径和本地文件的完整路径。OSS文件完整路径中不能包含Bucket名称。
                // 如果本地文件的完整路径中未指定本地路径,则默认从示例程序所属项目对应本地路径中上传文件。
                const result = await client.put('存在oss的名称,可不带后缀', path.normalize('本地图片所在路径 比如'C:\\user\\ming\1.jpg''));;   
                console.log(result);
            } catch (e) {
                console.log(e);
            }
        }
     	put()// 调用

请注意!!!path.normalize里面路径一定要用双斜杠

执行代码后,发现oss里有新的图片文件,就成功啦!!!

获取文件url

        //获取图片url
        async function getUrl() {
            try {
                const imgUrl = client.signatureUrl('图片名称', { expires: 600, 'process': 'image/resize,w_300' })
                console.log(imgUrl);
                ctx.body = {
                    imgUrl
                }
            } catch (e) {
                console.log(e);
            }
        }
        getUrl()

返回的imgUrl,在浏览器地址栏上输入,图片正确就成功啦!!!!

参考文档

OSS Node.js文档

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:16:14  更:2022-04-01 23:17:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:17:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码