React+js 上传

1.设置input框赋予file类型
<div className="App">
     <input type="file" ref={inp_dom} onChange={load}/>
     <img src={url} alt=""/>
</div>

2.引用input DOM并定义响应式url

let inp_dom=useRef([]);
let [url,setUrl]=useState();

3.当点击上传事件时触发选择器并选择图片

let load=()=>{
    // 获取上传文件并上传
    let file=inp_dom.current.files[0]
    if(!file){
      alert('请选择文件')
    }else{
      // 创建formData并添加上传文件
      let formData=new FormData()
      // 追加上传的file到formData中,key为'file',value为上传的file本身。
      formData.append('file',file)
      // 调用api上传文件
      Getload(formData).then(res=>{
        // 获取api返回的url并设置url
        console.log(res);
        // 上传成功后,alert并设置url
        alert('上传成功')
        // 注意:此处的url是api返回的url,并未经过本地url转换。
        setUrl(res.data.url)
      })
    }
  }

4.创建koa框架并找到官网:阿里云登录 - 欢迎登录阿里云,安全稳定的云计算服务平台

拿到我们创建列表时给的AccessKey ID和AccessKey Secret

拿到后我们到操作指南里找到Node.js上传文件:Node.js上传本地文件_对象存储(OSS)-阿里云帮助中心

代码已经帮各位童鞋们复制了

const OSS = require('ali-oss')
const path=require("path")

const client = new OSS({
  // yourregion填写Bucket所在地域。以华东1(杭州)为例,Region填写为oss-cn-hangzhou。
  region: 'yourregion',
  // 从环境变量中获取访问凭证。运行本代码示例之前,请确保已设置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。
  accessKeyId: process.env.OSS_ACCESS_KEY_ID,
  accessKeySecret: process.env.OSS_ACCESS_KEY_SECRET,
  // 填写Bucket名称。
  bucket: 'examplebucket',
});

// 自定义请求头
const headers = {
  // 指定Object的存储类型。
  'x-oss-storage-class': 'Standard',
  // 指定Object的访问权限。
  'x-oss-object-acl': 'private',
  // 通过文件URL访问文件时,指定以附件形式下载文件,下载后的文件名称定义为example.txt。
  'Content-Disposition': 'attachment; filename="example.txt"',
  // 设置Object的标签,可同时设置多个标签。
  'x-oss-tagging': 'Tag1=1&Tag2=2',
  // 指定PutObject操作时是否覆盖同名目标Object。此处设置为true,表示禁止覆盖同名Object。
  'x-oss-forbid-overwrite': 'true',
};

async function put () {
  try {
    // 填写OSS文件完整路径和本地文件的完整路径。OSS文件完整路径中不能包含Bucket名称。
    // 如果本地文件的完整路径中未指定本地路径,则默认从示例程序所属项目对应本地路径中上传文件。
    const result = await client.put('exampleobject.txt', path.normalize('D:\\localpath\\examplefile.txt')
    // 自定义headers
    ,{headers}
    );
    console.log(result);
  } catch (e) {
    console.log(e);
  }
}

put();

然后我们修改成自己的AccessKey ID和AccessKey Secret即可

const client = new OSS({
    // yourregion填写Bucket所在地域。以华东1(杭州)为例,Region填写为oss-cn-hangzhou。
    region: 'oss-cn-beijing',
    // 从环境变量中获取访问凭证。运行本代码示例之前,请确保已设置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。
    accessKeyId:'xxxxxxxxxx',
    accessKeySecret:'xxxxxxxxxxxxxx',
    // 填写Bucket名称。
    bucket: 'xxxx',
  });

最后我们写一个post将数据与前端连接

router.post('/upload',async(ctx)=>{
    const file=ctx.request.files.file
    // console.log(file);
    try {
        // 填写OSS文件完整路径和本地文件的完整路径。OSS文件完整路径中不能包含Bucket名称。
        // 如果本地文件的完整路径中未指定本地路径,则默认从示例程序所属项目对应本地路径中上传文件。
        const result = await client.put(file.originalFilename,file.filepath);
        console.log(result);
        // 上传成功后返回url
        return ctx.body={
            code:200,
            msg:'上传成功',
            url:result.url
        }
      } catch (e) {
        console.log(e);
      }
})

到这里我们想要的效果就完成了

在我们的阿里云平台上就可以看到我们上传的图片

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值