Base64加密/解密(前台和后台)

一个demo示例,内部包含所需要的jar包:
https://download.csdn.net/download/su1573/10656061

前台加密:

js前台实现Base64加密/解密(encoder/decoder)

在js文件中编写以下代码

function btn_test(){
    window.wxc.xcConfirm('成功!', window.wxc.xcConfirm.typeEnum.success);

    var pwd = $("#pwd_id").val();
    alert("111:"+pwd);

    //md5加密后,不可逆转,已变成密文
//  var pwd_en = $.base64.btoa($.md5(pwd));    

    /*
     * $.base64.btoa(str)  加密
     * $.base64.atob(str)  解密
     */

    //使用encodeURIComponent对中文进行编码,然后加密
    var pwd_en = $.base64.btoa(encodeURIComponent(pwd));
    alert("222:"+pwd_en);

    //使用 decodeURIComponent对解密后的数据编码,然后就还原成了中文
    var pwd_de = decodeURIComponent($.base64.atob(pwd_en));
    alert("333:"+pwd_de);
}

前提是需要在jsp文件中引入

<head>
    <script type="text/javascript" src="../common/jquery/jquery.base64.js"></script>
    <script type="text/javascript" src="../common/jquery/jquery.md5.js"></script>
</head>
<!-- 只展示body标签 -->
<body>
    <div style="margin: 200px 400px" border="1">
        <input id="btn_id" class="sgBtn" name="btn_name" type="button" onclick="btn_test()" value="按下"  />
        文本:<textarea rows="10" cols="50"  id="pwd_id"></textarea>
    </div>
</body>

java后台实现Base64加密/解密(encoder/decoder)

有两种方式:
第一种:
在java 7 及以下
使用com.sun.org.apache.xerces.internal.impl.dv.util.Base64

代码如下:

import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;

public class TestBase64 {
    public static void main(String[] args) throws Exception{

        //第一种
        Base64 base64 = new Base64();
        String pwd = "加密文字";
        byte[] byData = pwd.getBytes("UTF-8");
        String pwdEn = base64.encode(byData);
        System.out.println("加密:"+pwdEn);
        String pwdDe = new String (base64.decode(pwdEn),"UTF-8");
        System.out.println("解密:"+pwdDe);
    }
}

在使用时,要处理异常,一种是throws Exception,另一种是try{}catch(){};


第二种:
Java 8及以上
使用java.util.Base64

代码如下:

import java.util.Base64;

public class TestBase64 {
    public static void main(String[] args) throws Exception{    

        //第二种
        Base64.Encoder encoder = Base64.getEncoder();
        Base64.Decoder decoder = Base64.getDecoder();
        String pwd = "加密文字";
        byte[] byData = pwd.getBytes("UTF-8");
        String pwdEn = encoder.encodeToString(byData);
        System.out.println("加密:"+pwdEn);
        String pwdDe = new String(decoder.decode(pwdEn),"UTF-8");
        System.out.println("解密:"+pwdDe);

    }
}

在使用时,要处理异常,一种是throws Exception,另一种是try{}catch(){};


效果展示

在页面输入值,可以看到加密后的密文
这里写图片描述

这里写图片描述
这里写图片描述

Java Native Interface(JNI)是Java平台的一项技术,它允许Java代码与本地代码(如C、C++)进行交互。在这种情况下,我们可以使用JNI来实现Base64加密解密。 以下是一个示例代码,演示如何使用JNI实现Base64加密解密: 1.创建一个名为"Base64.c"的C文件,其中包含以下代码: #include<jni.h> #include<stdlib.h> #include<stdio.h> #include<errno.h> #include<string.h> #include<android/log.h> #include "android/bitmap.h" #include "android/log.h" #include "libjpeg/jpeglib.h" #include "com_example_bitmaptest_utils_CImageUtils.h" //Base64加密函数 JNIEXPORT jstring JNICALL Java_com_example_bitmaptest_utils_CImageUtils_encrypt(JNIEnv *env, jobject obj, jstring str) { const char *src = (*env)->GetStringUTFChars(env, str, NULL); if(src == NULL){ return NULL; } jsize len = (*env)->GetStringUTFLength(env, str); int mod = len % 3; int new_len = len + (mod == 0 ? 0 : (3 - mod)); unsigned char *input = (unsigned char *)malloc(new_len); memset(input, 0, new_len); memcpy(input, src, len); int i = 0, j = 0; unsigned char *output = (unsigned char *)malloc(new_len * 4 / 3); memset(output, 0, new_len * 4 / 3); while(i < new_len){ int c = input[i++] << 16 | input[i++] << 8 | input[i++]; output[j++] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"[c >> 18]; output[j++] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"[(c >> 12) & 0x3f]; output[j++] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"[(c >> 6) & 0x3f]; output[j++] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"[c & 0x3f]; } if(mod > 0){ output[new_len * 4 / 3 - 1] = '='; } if(mod == 1){ output[new_len * 4 / 3 - 2] = '='; } (*env)->ReleaseStringUTFChars(env, str, src); jstring result = (*env)->NewStringUTF(env, output); free(input); free(output); return result; } //Base64解密函数 JNIEXPORT jstring JNICALL Java_com_example_bitmaptest_utils_CImageUtils_decrypt(JNIEnv *env, jobject obj, jstring str) { const char *src = (*env)->GetStringUTFChars(env, str, NULL); if(src == NULL){ return NULL; } jsize len = (*env)->GetStringUTFLength(env, str); int new_len = len / 4 * 3; if(src[len - 1] == '='){ new_len--; } if(src[len - 2] == '='){ new_len--; } unsigned char *input = (unsigned char *)malloc(len); memset(input, 0, len); memcpy(input, src, len); int i = 0, j = 0; unsigned char *output = (unsigned char *)malloc(new_len); memset(output, 0, new_len); while(i < len){ unsigned char c[4]; int k = 0; while(k < 4 && i < len){ if(input[i] != '\n' && input[i] != '\r'){ c[k++] = input[i++]; }else{ i++; } } if(k == 4){ output[j++] = (c[0] << 2) | (c[1] >> 4); output[j++] = (c[1] << 4) | (c[2] >> 2); output[j++] = (c[2] << 6) | c[3]; } } (*env)->ReleaseStringUTFChars(env, str, src); jstring result = (*env)->NewStringUTF(env, output); free(input); free(output); return result; } 2.使用javac编译CImageUtils.java文件,生成CImageUtils.class文件。 3.使用javah命令生成.h头文件,命令为:javah -classpath . com.example.bitmaptest.utils.CImageUtils 4.将生成的CImageUtils.h文件拷贝到C文件所在目录下,并在C文件中包含该头文件。 5.使用ndk-build命令编译C文件,生成动态库文件。 6.将生成的动态库文件拷贝到Android项目的libs目录下。 7.在Java代码中调用JNI函数,例如: public class MainActivity extends AppCompatActivity { static { System.loadLibrary("base64"); } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); String str = "hello, world"; String encryptStr = CImageUtils.encrypt(str); Log.i("MainActivity", "encryptStr: " + encryptStr); String decryptStr = CImageUtils.decrypt(encryptStr); Log.i("MainActivity", "decryptStr: " + decryptStr); } } 通过以上步骤,我们就可以在Android项目中使用JNI实现Base64加密解密
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ssy03092919

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值