图片上传oss--先拿server端签名再上传oss,返回id值

目前项目oss阿里云存储图片,图片上传主要步骤是:前端从服务端拿到签名signature,再上传到oss上busket里,上传成功返回图片id (imgId),最后再给server端;

注:官网上有个例子,也有封装的插件一个,可参考使用,[服务端签名直传并设置上传回调](https://help.aliyun.com/document_detail/31927.html?spm=5176.doc31923.2.2.RseG9d);但因技术有限,未使用;

项目使用angularjs开发的,常用方法$http请求上传都会报跨域问题,加入使用cors解决跨域但报405 不支持该方法
在使用postman测试接口,可以实现提交无误,问题出在哪呢?   后发现postman提交是以form-data格式,对,它使用form表单提交的;


之后写了个简单demo,可以实现,后采用一下该方法form表单提交上传图片,(后发现某宝亦使用该方法,这都是后话了) 

再存在问题,就是使用form表单提交后会跳转页面问题,相信很多伙伴都遇到,也有自己的解决方案,

常用方法为 跳转空的iframe  和  jquery-form.js插件 的方法, 某宝用后者,这里我们用后者;
注意事项:
- 使用form表单提交 该form再该页面外部不能有form进行包裹,否则无效
- 使用 jquery-form.js方法  必须再页面再加载一次,才有效果,否则报错  ajaxSubmit is not undefind
 目前解决方案,代码优化如下:
 1 <form id="fromName" enctype="multipart/form-data"
 2                           action="http://******-shanghai.aliyuncs.com"
 3                           onsubmit="return saveFormImg();"
 4                           method="post" style="padding-bottom: 100px;">
 5
 6     <input type="hidden" name="key" ng-value="key"/>
 7     <input type="hidden" name="policy" ng-value="policy"/>
 8     <input type="hidden" name="OSSAccessKeyId" ng-value="ossid"/>
 9     <input type="hidden" name="signature" ng-value="sign"/>
10     <input type="hidden" name="callback" ng-value="call"/>
11     <input type="hidden" name="x:openid" ng-value="od"/>
12     <input type="file" name="file"/>
13     <input type="submit" value="上 传"/>
14
15 </form>
16     <script type="text/javascript" src="http://malsup.github.io/jquery.form.js"></script>
17     <script>
18         function saveFormImg() {
19
20             $("#fromName").ajaxSubmit(function (message) {
21     //      console.log(message);
22                 if (message.code == ‘200‘) {
23                     var detailImgID = message.data.imgId;
24
25                     if (window.localStorage) {
26                         localStorage.setItem("OssDetailImgId2", detailImgID);
27                     } else {
28                         Cookie.write("OssDetailImgId2", detailImgID);
29                     }
30                  } else {
31                      alert(‘图片有误,请重新选择并提交‘);
32                  }
33
34          });
35               return false;   //阻止跳转
36
37         }
38     </script>

注释: action 为你oss的url;input上ng-value为angularjs的数据绑定一种方法;

x:openid 是项目认证的id,您可能用不到;
form表单配置  *
   id  | enctype   |action  | method  |onsubmit
   ----|---------- |--------|---------|---------
   id名| 提交格式    | 地址   |   方式   | 事件
 *加上action 和input,上传oss共需要8个参数,数据通过第一次请求服务端拿签名得到,通过数据绑定到form表单input上提交*
返回的id需要传给server端,因页面作用域的原因,controller层拿不到每次页面form提交返回的id;这里使用页面传参通过localStotage写入读出,考虑到浏览器有可能不支持H5 localStorage,可存Cookie中
使用方法: 先按照你的借口需求,写一个简单的form提交,包含必要的key-value值, 然后在输入框中填入数据,测试,成功的话,便可修改,简化,数据绑定,等等;

最初的demo:
<form id="fromName" enctype="multipart/form-data"                   action="http://******-shanghai.aliyuncs.com"                   onsubmit="return saveFormImg();" method="post">   

      <label for= "keyName">keyName</label> <input id="keyName" type="text"> 

    /* ... 多个input,具体看你的接口...*/  
    <input type="file" name="file"/>     <input type="submit" value="上 传"/>
 </form>
 <script type="text/javascript" src="http://malsup.github.io/jquery.form.js"></script>
 <script>
 function saveFormImg() {
     $("#fromName").ajaxSubmit(function (message) {
         console.log(message);

     });
     return false;   //阻止跳转

  } </script>

目前初步实现了功能开发,有什么不足之处,望大家指点,共同进步,目前时间,能力有限,后期尝试打算做成指令,或者封装成插件使用;

如您有更好的办法,还望不吝赐教!

				
时间: 2024-10-04 14:31:33

图片上传oss--先拿server端签名再上传oss,返回id值的相关文章

SQL SERVER 分页查询 和 Inser 添加并返回Id

--第一种分页 SELECT * FROM ( select ROW_NUMBER() over(order by id) as rows,* from [dbo].[M_User] --WHERE Id>1 ) AS T where rows BETWEEN 0 AND 2 --第二种分页 需SQL SERVER 2012以上支持 select * from [M_Role] order by Id offset 0 rows fetch next 10 rows only ; --执行Ins

怎么在yar的server端任何地方获得client请求调用的方法

先说下碰到的问题吧:上周调查个问题发现,在rpc server端解析client上传上来的post数据,解包,找函数,执行都在Yar_Server的函数handle中执行了.没有向后面的系统或者服务传递上下文的方法.为了调查问题我们只能在函数调用里面记录哪个方法被调用了. 那么是不是可以在Yar_Server里面试着增加个静态变量保存内容,限于自身能力,现只增加了一个方法,返回了调用的method,用于server端向后面传递. 如下, 小改之后就可以通过 Yar_Server::getCall

查找SQL Server 自增ID值不连续记录

在很多的时候,我们会在数据库的表中设置一个字段:ID,这个ID是一个IDENTITY,也就是说这是一个自增ID.当并发量很大并且这个字段不是主键的时候,就有可能会让这个值重复:或者在某些情况(例如插入数据的时候出错,或者是用户使用了Delete删除了记录)下会让ID值不是连续的,比如1,2,3,5,6,7,10,那么在中间就断了几个数据,那么我们希望能在数据中找出这些相关的记录,我希望找出的记录是3,5,7,10,通过这些记录可以查看这些记录的规律来分析或者统计:又或者我需要知道那些ID值是没有

Base64实现android端图片上传到server端

首先要下载Base64.java文件http://iharder.sourceforge.net/current/java/base64/ 将代码复制到project中. 然后上代码: android端代码: private void setPicToView(Intent picdata) { Bundle extras = picdata.getExtras(); if (extras != null) { mBitmap = extras.getParcelable("data"

Ali OSS服务端签名直传并设置上传回调

服务端签名直传并设置上传回调 背景 请参考 Web端直传实践 里的背景介绍. 当采用服务端签名后直传方案后,问题来了,用户上传数据后,很多场景下,应用服务器都要知道用户上传了哪些文件,文件名字,甚至如果是图片的话,图片的大小等.为此OSS开发了上传回调功能. 用户的请求逻辑 用户向应用服务器取到上传policy和回调设置. 应用服务器返回上传policy和回调. 用户直接向OSS发送文件上传请求. 等文件数据上传完,OSS给用户Response前,OSS会根据用户的回调设置,请求用户的服务器.

Android端通过HttpURLConnection上传文件到server

一:实现原理 近期在做Androidclient的应用开发,涉及到要把图片上传到后台server中.自己选择了做Spring3 MVC HTTP API作为后台上传接口,androidclient我选择用HttpURLConnection来通过form提交文件数据实现上传功能,本来想网上搜搜拷贝一下改改代码就好啦,发现根本没有现成的样例,多数的样例都是基于HttpClient的或者是基于Base64编码以后作为字符串来传输图像数据,于是我不得不自己动手.參考了网上一些资料,终于实现基于HttpU

ASP.NET MVC在服务端把异步上传的图片裁剪成不同尺寸分别保存,并设置上传目录的尺寸限制

我曾经试过使用JSAjaxFileUploader插件来把文件.照片以异步的方式上传,就像"MVC文件图片ajax上传轻量级解决方案,使用客户端JSAjaxFileUploader插件01-单文件上传"中说的,这种方法足够轻.足够好.但今天,要在前面的基础上再增加2个需求: 1.异步判断上传的图片是否超过最大限制2.把上传的图片裁剪成大中小3张图片,分别保存,删除的时候一块被删除 上传图片如果超出最大尺寸限制,终止上传,并报错误信息. 前台上传图片,显示缩略图. 在项目根目录下的指定文

在OneThink(ThinkPHP3.2.3)中整合阿里云OSS的PHP-SDK2.0.4,实现Web端直传,服务端签名直传并设置上传回调的实现流程

在OneThink(ThinkPHP3.2.3)中整合阿里云OSS的PHP-SDK2.0.4,实现本地文件上传流程 by shuijingwan · 2016/01/13 1.SDK安装 github地址:https://github.com/aliyun/aliyun-oss-php-sdk 2.复制aliyun-oss-php-sdk-master\src\OSS至passport.hmwis.com\ThinkPHP\Library\Vendor\OSS,如图1.2 复制aliyun-os

使用.net在服务端进行图片下载后再上传

最近做了阿里的视频接口,很蛋疼,阿里的视频获取封面图片是有时间限制的,过期就无法访问了,只能先下载后上传. 废话不多说,直接上代码 public ActionResult UploadvideoImg(String url) { WebRequest request = WebRequest.Create(url); WebResponse response = request.GetResponse(); Stream reader = response.GetResponseStream()