移动应用图片的福音--七牛云存储

简介:   本篇来介绍移动应用图片存储的第三方,官方网址:http://www.qiniu.com/   首先,在七牛上要注册开发者账号,需要认证身份证信息。认证完之后,我们来开始进行安卓端的开发。 一、准备信息   进行图片的上传与下载,我们需要准备几个信息,首先是空间名,然后是域名,再者是密钥对。

  本篇来介绍移动应用图片存储的第三方,官方网址:http://www.qiniu.com/

  首先,在七牛上要注册开发者账号,需要认证身份证信息。认证完之后,我们来开始进行安卓端的开发。

一、准备信息

  进行图片的上传与下载,我们需要准备几个信息,首先是空间名,然后是域名,再者是密钥对。如下图:

二、安卓端图片上传

  首先我们需要导入JAR包,网址:http://developer.qiniu.com/docs/v6/sdk/android-sdk.html

  现在来编写上传相关的程序:

 private volatile boolean isCancelled = false;// 取消标志    
   static String AccessKey =七牛上的公钥; static String SecretKey =七牛上的私钥; UploadManager uploadManager; /** *uploadManager有两种初始化方法,一种是默认配置,一种的自动逸配置 */ // 默认配置      uploadManager=new UploadManager(); //自定义配置 Configuration config= new Configuration.Builder().chunkSize(256 * 1024) // 分片上传时,每片的大小。 // 默认 // 256K .putThreshhold(512 * 1024) // 启用分片上传阀值。默认 512K .connectTimeout(10) // 链接超时。默认 10秒 .responseTimeout(60) // 服务器响应超时。默认 60秒 // .recorder(recorder) // recorder 分片上传时,已上传片记录器。默认 null // .recorder(recorder, keyGen) // keyGen // 分片上传时,生成标识符,用于片记录器区分是那个文件的上传记录 .build(); // 重用 uploadManager。一般地,只需要创建一个 uploadManager 对象 uploadManager = new UploadManager(config);

  初始化配置搞定了,下面来进行上传操作:

     String _uploadToken = getUploadToken(scope);
     uploadManager.put(SAVE_FILE_DIRECTORY,
// 本地上传路径、文件、字符串 key, // 网站上的名字 _uploadToken, // 验证信息 new UpCompletionHandler() { @Override public void complete(String key, ResponseInfo info, JSONObject response) { Log.e("qiniu", info.toString()); Log.i("是否成功", String.valueOf(info.isOK())); } }, new UploadOptions(null, // 自定义变量,key必须以 x: 开始。 "webp", // 指定文件的mimeType。 false, // 是否验证上传文件。 new UpProgressHandler() { // 上传进度回调。 public void progress(String key, double percent) { Log.i("qiniu", key + ": " + percent); } }, new UpCancellationSignal() { // 取消上传,当isCancelled()返回true时,不再执行更多上传。 public boolean isCancelled() { return isCancelled; } }) );

  在上传的操作中唯一需要我们头疼的就是_uploadToken,下面来介绍如何生成一个_uploadToken令牌信息:

    public String getUploadToken(String scope) {
        // 构造上传策略
        JSONObject json = new JSONObject();
        long dataline = System.currentTimeMillis() / 1000 + 3600;
        String uploadToken = null;
        try {
            json.put("deadline", dataline);// 有效时间为一个小时
            json.put("scope", scope);// 上传空间
            String encodedPutPolicy = UrlSafeBase64.encodeToString(json.toString().getBytes());
            byte[] sign = HmacSHA1Encrypt(encodedPutPolicy, SecretKey);
            String encodedSign = UrlSafeBase64.encodeToString(sign);
            uploadToken = AccessKey + ':' + encodedSign + ':' + encodedPutPolicy;// 登录信息token=公钥:加密的json信息:原始json信息
        } catch (JSONException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return uploadToken;
    }

    /////////////// ************************************/////////////////////////
    /**
     * 使用 HMAC-SHA1 签名方法对对encryptText进行签名
     * 
     * @param encryptText
     *            被签名的字符串
     * @param encryptKey
     *            密钥
     * @return
     * @throws Exception
     */
    private static final String MAC_NAME = "HmacSHA1";
    private static final String ENCODING = "UTF-8";

    private byte[] HmacSHA1Encrypt(String encryptText, String encryptKey) throws Exception {
        byte[] data = encryptKey.getBytes(ENCODING);
        // 根据给定的字节数组构造一个密钥,第二参数指定一个密钥算法的名称
        SecretKey secretKey = new SecretKeySpec(data, MAC_NAME);
        // 生成一个指定 Mac 算法 的 Mac 对象
        Mac mac = Mac.getInstance(MAC_NAME);
        // 用给定密钥初始化 Mac 对象
        mac.init(secretKey);
        byte[] text = encryptText.getBytes(ENCODING);
        // 完成 Mac 操作
        return mac.doFinal(text);
    }

  好了现在我们就可以成功上传了。

三、编写其他操作

  1、取消操作

    /**
     * 点击取消按钮,让 UpCancellationSignal#isCancelled() 方法返回 true ,以停止上传
     */
    public void cancell() {
        isCancelled = true;
    }

  2、删除操作

    /**
     * 删除指定空间、名称的资源
     * 
     * @param bucket 空间名
     * @param fileName 文件名
     * @return
     */
    public boolean deleteFile(String bucket, String fileName) {
        try {
            String entryUrl = bucket + ":" + fileName;
            String encodedEntryURI = UrlSafeBase64.encodeToString(entryUrl.getBytes());
            String host = "http://rs.qiniu.com";
            String path = "/delete/" + encodedEntryURI;
            String url = host + path;
            byte[] sign = HmacSHA1Encrypt(path + "\n", SecretKey);
            String encodedSign = UrlSafeBase64.encodeToString(sign);
            String authorization = AccessKey + ':' + encodedSign;
            HttpClient httpClient = new DefaultHttpClient();
            HttpPost mothod = new HttpPost(url);
            mothod.setHeader("Content-Type", "application/x-www-form-urlencoded");
            mothod.setHeader("Authorization", "QBox " + authorization);
            // 连接超时时间
            httpClient.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT, 20000);
            // 读取超时时间
            httpClient.getParams().setParameter(CoreConnectionPNames.SO_TIMEOUT, 20000);
            HttpResponse response = httpClient.execute(mothod);
            StatusLine statusLine = response.getStatusLine();
            int statusCode = statusLine.getStatusCode();
            if (statusCode == HttpStatus.SC_OK) {
                Log.e("删除结果", "successful");
                return true;
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        Log.e("删除结果", "false");
        return false;
    }

  好了,暂时就先到这里,虽然进行了一些封装,但是对自己的封装不很满意所以暂时不发了,以后封装完善了再发吧,这些已经足够新手理解了。下篇介绍获取网络图片并显示。主要用到目前最好的图片加载框架ImageLoad。

遗失的拂晓
目录
相关文章
|
3月前
|
域名解析 JSON 测试技术
常见移动端APP测试场景
常见移动端APP测试场景
|
8月前
|
关系型数据库 MySQL 应用服务中间件
打造专属照片分享平台:快速上手Piwigo网页搭建
打造专属照片分享平台:快速上手Piwigo网页搭建
|
9月前
|
小程序
微信小程序项目实例——图片处理小工具(自制低配版美图秀秀)
微信小程序项目实例——图片处理小工具(自制低配版美图秀秀)
|
前端开发
前端工作总结123-视频上传和图片编辑功能
前端工作总结123-视频上传和图片编辑功能
73 0
前端工作总结123-视频上传和图片编辑功能
|
移动开发 数据可视化 算法
大公开!动画制作只需要拥有这几款工具!
大公开!动画制作只需要拥有这几款工具!
大公开!动画制作只需要拥有这几款工具!
|
存储 数据可视化 前端开发
这款国外开源框架, 让你轻松构建自己的页面编辑器
前段时间我一直在设计和研究低代码搭建平台,也开源了几款可视化编辑器框架,最近在 github 上发现了一款非常强大的基于自然流布局的页面搭建框架 GrapesJS,接下来我就带大家摸索一下这款框架。
466 0
|
Web App开发 机器学习/深度学习 人机交互
打开摄像头,2D插画实时变动画,中国程序媛出品,Demo在线可玩
画一只狸(jian)克(shang),并让它拍摄一个「催款」的特写,需要几步?
短视频开发、小视频源码制作需要这些技术手段
之前在网上见过一个问题,“制作小视频源码需要什么技术手段,短视频开发需要多少钱?”并设定了范围。清晰度不低于720p、支持观看人数为1w人,带美颜,流畅不卡顿的短视频平台。这个问题是2017年的,到了现在,下面的答案早就不适用了,但我相信还会有人有类似的疑问,所以该讲的还是要讲的。
|
Web App开发 数据可视化 定位技术
分享十款堪称神器的工具APP
作为一个工具控,我推荐几个堪称神器的app,保证你喜欢。 01 思维导图—幕布 这是一个非常好用的写作神器,写文章非常便利。而且它还是一个思维导图工具,可以将文字一键生成思维导图,方便理清文章逻辑。 搭建好逻辑之后,直接往每一个小版块上添加内容就可以了。
1264 0
|
数据安全/隐私保护 Android开发 开发者
小视频app开发后,短视频软件搭建部署教程
小视频app开发后,短视频软件搭建部署教程