集成阿里云的对象存储,跟着文档一步一步的来。
1、导包
2、获取stsToken(阿里云让网上获取,但调试的时候也可以客户端自己生成)
3、初始化OssClient
4、异步上传文件到服务器
最开始都好好的,上传成功,回调也显示上传成功,去控制台也看到了自己上传的文件。
但是,等我把其他逻辑写完再测试的时候,然后出现了问题,点击上传之后,没反应。
很奇怪啊,刚刚都是可以的。
打开阿里云的debug日志(OSSLog.enableLog()),报403(权限问题嘛)
然后想起我换了存储控间,之前生成的STSToken参数不对。
但是,报错就报错,为啥上传监听(OSSCompletedCallback)没有报错的回调呢?
打个断点跟一下,发现在源码中有一个监听的代理,这个代理的代码都已经执行到了,但就是没有返回到我们自己的监听
这就很奇怪啊,都到这儿了,按理说就会回调啊。但是回调里面日志都打不出来,更别说逻辑了。应该是已经报错了,但是又没有错误日志输出。就很懵
然后寻求阿里云人工服务,答非所问,老是让我确认配置,让我好好看demo,我可去%#¥%&*
然后我就去GitHub上把他们源码拉下来(文档里面有GitHub的地址),然后在源码里面的最后一步回调(就是那个监听代理的地方)外面加了一个try catch,运行起来看一看(不得不说,这个demo是真难,跑都跑不起来,最后只能通过make project的方式编了一个sdk的arr,然后依赖到自己项目里面)
就抓到了异常,空指针
什么原因呢,阿里云文档里面的代码是Java的,我们项目是kotlin的
当我把代码复制下来的时候,自动转成了kotlin的代码,kotlin里面如果这个返回对象可能为空,你得在对象后面加个“?”
当阿里云那边调用回调的时候,因为没有加这个“?”号,所以kotlin抛了一个空指针,阿里云catch到了,但它也没说(没打印输出),对我们的现象就是一点反应都没有。
在回调的三个参数后面上都加一个“?”号,问题就解决了
如果你成功或者失败也没有返回,也尝试加个“?”号吧