java文件加密相关知识
-
Java 加密、解密PPT文档文档加密常通过设置文档打开密码、启用文档编辑时的权限密码等方式;而解密则通过删除原有文档的密码或在此基础上重置新的密码。以下文章内容,将通过Java程序来实现通过以上方式来加密、解密PPT文档。 使用工具:Free Spire.Presentation for Java(免费版)Jar文件获取及导入:方法1:通过官网获取jar文件包。下载文件后,解压,并将lib文件夹下的Spire.Presentation.jar文件导入Java程序。方法2:通过maven仓库安装导入。 Java代码示例【示例1】加密PPTimport com.spire.presentation.*; public class Encrypt { public static void main(String[]args) throws Exce
-
Java 加密、解密Excel文档一、概述本文介绍通过Java程序来实现Excel文档加密以及解密的方法,包括对Excel工作簿加密、解密,对指定工作表加密、解密。程序中使用了免费版Java Excel类库(Free Spire.XLS for Java),可以通过官网下载文件包,并将lib文件夹中的jar文件导入程序;或者通过maven仓库导入,maven仓库路径配置和依赖添加,可参考教程文章。Jar文件导入效果如下:二、代码示例1. 加密、解密Excel工作簿1.1 加密工作簿 import com.spire.xls.*; public class EncryptWorkbook { public static void main(String[] args) { &n
-
Java 加密、解密PDF文档本篇文章将介绍通过Java编程来设置PDF文档保护的方法。我们可以设置仅用于查阅文档的密码,即该通过该密码打开文档仅用于文档阅读,无法编辑;也可以设置文档编辑权限的密码,即通过该密码打开文档时,文档为可编辑状态。使用工具:Free Spire.PDF for Java V2.0.0(免费版) 关于jar文件引用步骤1:在Java程序中新建一个文件夹可命名为Lib。下载安装包后,解压,将解压后的文件夹下的子文件夹lib中的Spire.Pdf.jar和Spire.Common.jar两个文件复制到新建的文件夹下,如下图:步骤 2:建好文件夹后,引用两个文件:选中这两个jar文件,点击鼠标右键,选择“Build Path” – “Add to Build Path”。如下图: 【示例1】加密PDF文档 import java.util.EnumSet; import com.spire.pdf.PdfDocument; import com.s
-
Java代码加密,Java加密方式,Java加密使用说明概述Java2C针对DEX文件进行加密保护,将DEX文件中标记的Java代码翻译为C代码,编译成加固后的SO文件。默认情况只加密activity中的onCreate函数,如果开发者想加密其它类和方法,只需对相关类或函数添加标记代码,在APK加密时会自动对标记的代码进行加密处理【或者找几维的技术支持人员在后台添加Java函数白名单策略来对重要的函数进行加密】。使用步骤1.定义Annotation在Android工程项目中,定义一个名为LDPProtect的Annotation,如以下截图 2.对类进行加密在需要加密的类前面添加@LDPProtect,即可对类中除构造函数之外的其它函数进行安全加固,如下图: 3.对函数进行加密在需要加密的函数前面添加@LDPProtect,即可对该函数进行安全加固,如下图: 4.编译项目,加密APKA.编译项目生成release版本的APK文件B.用正式签名文件对APK包进行签名C.提交APK包到几维安全开发者平台进行安全加固D.下载加密包并再次签
java文件加密相关课程
java文件加密相关教程
- 2.2 对称加密和非对称加密算法 ** 面试官提问:** 既然 HTTPS 协议对通信内容进行了加密,那么涉及到了什么加密算法?题目解析:HTTPS 协议的核心是加密流程,首先我们需要区分三种加密方式:对称加密、非对称加密以及混淆加密。(1)对称加密:加密方和解密方都使用了相同的密钥,只要保证密钥不会泄露给第三方, 整个通信过程就是安全的。 (对称加密算法流程) 因为对称加密算法整个过程共享同一个密钥,所以使用特点也比较明显。优点:算法简单,加密速度快;缺点:安全性低,如果密钥泄露,密文也被中间人拦截,那么信息很容易就会被破解。在企业生产环境下,常用的对称加密算法有 AES 算法。(2)非对称加密:在安全性要求更高的场景下,我们需要使用非对称加密,关于非对称加密算法的流程如下:(非对称加密算法流程)首先定义两种密钥:一种是公钥(Public Key),给任何需要和接收方通信的客户端保存;另一种是私钥(Private Key),只给接收方自己保存。对于要发送的原文文本,发送方通过接收方的公钥对内容加密,加密后的内容只有接收方的私钥可以解密。在整个传输过程中,如果发送方的公钥泄露,加密内容也被窃取,也不会导致传输内容被破解(只要接收方的私钥没有泄露)。常见的非对称加密算法有 RSA 算法(即一种支持变长密钥的公共密钥算法)。另外,面试官可能会提出 MD5 算法的划分,MD5 是非常常见的加密算法,例如在保存用户密码时经常被使用。但是要区分的是,MD5 算法不是对称和非对称算法,MD5 算法不可逆,主要目的是为了文件校验(例如判断文件是否在传输过程中损坏),或者数字签名等途径。
- 2. 加密器 加密器的相关类提供了构造对称加密器的工厂方法。通过该类,我们可以创建 ByteEncryptor 用于加密原始字节流内容,我们也可以构建出 TextEncryptor 用于加密文本字符串,这些加密器都是线程安全的。
- 2.2 加密算法 对称加密算法加密和解密的秘钥使用的是同一个优点加密速度快,计算量小。缺点通信前双方需要协商好密钥,密钥在网络中传输不安全。非对称加密算法公开密钥与私有密钥是一对,如果用公开密钥对数据进行加密,只有用对应的私有密钥才能解密;如果用私有密钥对数据进行加密,那么只有用对应的公开密钥才能解密。优点:私钥不对外公开,公钥可以提前告知对方,密钥不需要在协商中传输,安全性高。缺点:加密算法复杂,效率低。Https 混合加密算法Https 结合了上面两种加密算法的优点,前期通过非对称加密协商好对称加密所需的密钥(保障了密钥的安全性),后面通信的时候就拿着这个密钥采用对称加密进行通信(保障了计算效率)。
- 1. 用户密码加密 上一小节的最后,我们提到用户鉴权服务是需要优化的。大家可以看到我们数据库存储的是明文密码,这是非常不推荐的,在实际的项目中,明文存储用户的密码是非常不安全的,也是不负责任的行为。我们在设计 imooc_user表时,给password设置的类型为固定长度类型char(32),32 位正好是MD5算法加密后的长度。本系统使用 MD5 算法对密码进行加密,下面在 util包下新建一个 MD5Util类并写入如下内容(可直接复制粘贴代码):package com.colorful.util;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;public class MD5Util { public static String md5(String source) { StringBuilder stringBuilder = new StringBuilder(); try { MessageDigest messageDigest = MessageDigest.getInstance("MD5"); // 将一个byte数组进行加密操作,返回的是一个加密的byte数组,二进制的哈西计算,md5加密的第一步 byte[] digest = messageDigest.digest(source.getBytes()); for (byte b : digest) { int result = b & 0xff; // 将得到的int类型的值转化为16进制的值 String hexString = Integer.toHexString(result); if (hexString.length() < 2) { //系统会自动把0省略,所以添加0 stringBuilder.append("0"); } stringBuilder.append(hexString); } } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } return stringBuilder.toString(); } public static void main(String[] args) { String password = "123456"; String s = MD5Util.md5(password); System.out.println(s); }}在主方法中,我们编写了调用md5()加密方法的逻辑,运行代码,屏幕上得到123456加密后的字符串:e10adc3949ba59abbe56e057f20f883e下面我们将imooc_user表中存储的明文密码,更新为上面的结果,大家可以使用SQL语句来进行更新: UPDATE `imooc_user` SET `password` = 'e10adc3949ba59abbe56e057f20f883e' WHERE `id` = 1;这里我直接通过 MySQL 客户端进行更新,如下是操作过程的截图:数据库存储的密码更新后,我们就无法直接通过原本的验证逻辑来验证密码了,需要修改用户鉴权逻辑 —— 将用户输入的密码加密后,再与数据库的密码进行对比。那么这段逻辑要写在service层还是dao层呢?答案肯定是service层,此时service层用于处理业务的特性得到了体现,修改UserService下的login方法,将参数password加密:public User login(String username, String password) { String md5Password = MD5Util.md5(password); return userDAO.selectByUserNameAndPassword(username, md5Password);}再次启动应用程序,验证改写的逻辑是否正确:至此,我们就完成了对用户鉴权服务的优化。
- 3.2 Java 文件编写 以上代码主要实现了两个 Button 及一个 ScrollView,可以看到 ScrollView 中只有一个 LinearLayout,而 LinearLayout 中只有两个 Button,所以我们需要在 Java 代码中动态添加 Button,这里也可以让大家熟悉一下如何动态创建并添加 Button。接下来在 Java 代码中主要做两件事:为两个 Button 设置点击事件,分别实现回到顶部及跳转到底部;往 ScrollView 中添加 View,并绑定点击事件。代码如下:package com.emercy.myapplication;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.widget.Button;import android.widget.LinearLayout;import android.widget.ScrollView;import android.widget.Toast;public class MainActivity extends Activity implements View.OnClickListener { public static final int BUTTON_COUNT = 10; private ScrollView mScrollView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); findViewById(R.id.bt_to_top).setOnClickListener(this); findViewById(R.id.bt_to_bottom).setOnClickListener(this); mScrollView = findViewById(R.id.scrollView); LinearLayout layout = findViewById(R.id.button_group); for (int i = 0; i < BUTTON_COUNT; i++) { Button button = new Button(this); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT); params.topMargin = 100; layout.addView(button, params); button.setOnClickListener(this); button.setText(i + ""); } } @Override public void onClick(View v) { switch (v.getId()) { case R.id.bt_to_top: mScrollView.fullScroll(ScrollView.FOCUS_UP); break; case R.id.bt_to_bottom: mScrollView.fullScroll(ScrollView.FOCUS_DOWN); break; default: Toast.makeText(this, "当前点击的是第" + ((Button) v).getText() + "个Button", Toast.LENGTH_SHORT).show(); break; } }}效果如下:我们在代码中通过 for 循环往 ScrollView 中添加了 10 个 Button,动态添加一个 View 主要有以下 4 步:通过构造器创建 View。设置其属性(宽、高、margin、padding 等)。设置响应事件(比如点击、触摸、滚动等)。添加到相应的 ViewGroup 中。我们在创建 Button 的同时通过setText及setOnClickListener设置了文本及点击事件,然后在点击的时候展示当前 Button 的序号。
- 2.4 密码 密码是一种特殊的文本控件,主要用于登录注册时输入的用户密码,默认显示……,设置 type=password 可以定义一个密码控件,例如:1019
java文件加密相关搜索
-
j2ee
j2ee是什么
jar格式
java
java api
java applet
java c
java jdk
java list
java map
java script
java se
java socket
java swing
java switch
java web
java xml
java 程序设计
java 多线程
java 环境变量