base64编码与解码

import java.awt.image.BufferedImage;
import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.ByteArrayOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.MalformedURLException;
import java.net.URL;

import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.codec.binary.Base64;

import comat.common.utils.StrUtil;

import sun.misc.BASE64Encoder;
import sun.net.www.protocol.http.HttpURLConnection;

 1.base64通用转码类:

public static String GetImageStr(){
    String imgFile = "http://h.hiphotos.baidu.com/image/pic/item/024f78f0f736afc3be94256bb119ebc4b7451227.jpg";
    URL url;
    HttpURLConnection conn = null;
    byte[] data;
    String base64Img;
    String lines = null;
    BufferedInputStream bis = null;
    byte[] in_b = null;
    byte[] buffer;
    try {
    //创建URL对象
       url = new URL(imgFile);
       //返回一个URLConnection对象,它表示到URL所引用的远程对象的连接
       conn = (HttpURLConnection) url.openConnection();
       //设定请求方式
       conn.setRequestMethod("GET");
      //建立到远程对象的实际连接
       conn.connect();
         //返回打开连接读取的输入流
     //输出流
    InputStream in = conn.getInputStream();
       int size = conn.getContentLength(); // 取HTTP请求流长度
       buffer = new byte[size]; // 用于缓存每次读取的数据
       in_b = new byte[size]; // 用于存放结果的数组
       int count = 0;
       int rbyte = 0;
       // 循环读取
       while (count < size){
        rbyte = in.read(buffer); // 每次实际读取长度存于rbyte中 sflj
        for (int i = 0; i < rbyte; i++){
         in_b[count + i] = buffer[i];
        }
        count += rbyte;
       }
    }catch(Exception e){
     System.out.println("null");
    } 
       base64Img = new String(Base64.encodeBase64(in_b));
       System.out.println(base64Img);
   return base64Img;
    }

2.base64通用解码类:

 public static String GenerateImage(String imgStr)
    {     
         byte[] b = Base64.decodeBase64(imgStr);
      String path="D:\\aa.jpg";
         OutputStream out;
   try {
    out = new FileOutputStream(path);
    out.write(b);
    out.flush();
    out.close();
   } catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }   
            System.out.println("上传文件成功!");
   return path;
          
    }

源码地址: https://pan.quark.cn/s/a741d0e96f0e 在Android应用开发过程中,构建具有视觉吸引力的用户界面扮演着关键角色,卡片效果(CardView)作为一种常见的设计组件,经常被应用于信息展示或实现滑动浏览功能,例如在Google Play商店中应用推荐的部分。 提及的“一行代码实现ViewPager卡片效果”实际上是指通过简便的方法将CardViewViewPager整合,从而构建一个可滑动切换的卡片式布局。 接下来我们将深入探讨如何达成这一功能,并拓展相关的Android UI设计及编程知识。 首先需要明确CardView和ViewPager这两个组件的功能。 CardView是Android支持库中的一个视图容器,它提供了一种便捷定制的“卡片”样式,能够包含阴影、圆角以及内容间距等效果,使得内容呈现为悬浮在屏幕表面的形式。 而ViewPager是一个支持左右滑动查看多个页面的控件,通常用于实现类似轮播图或Tab滑动切换的应用场景。 为了实现“一行代码实现ViewPager卡片效果”,首要步骤是确保项目已配置必要的依赖项。 在build.gradle文件中,应加入以下依赖声明:```groovydependencies { implementation androidx.recyclerview:recyclerview:1.2.1 implementation androidx.cardview:cardview:1.0.0}```随后,需要设计一个CardView的布局文件。 在res/layout目录下,创建一个XML布局文件,比如命名为`card_item.xml`,并定义CardView及其内部结构:```xml<and...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值