「代码签名java」代码签名证书出错
本篇文章给大家谈谈代码签名java,以及代码签名证书出错对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、Java Verified 移动代码签名证书是什么?
- 2、JAVA中 什么是方法签名
- 3、java如何对pdf文件实现数字签名
- 4、如何从java生成签名在AWS问题,怎么解决
- 5、请问这个签名 java 应该怎么解析
Java Verified 移动代码签名证书是什么?
Java Verified 是全球可信的测试及签发项目,用于确保开发者及无线运营商可以安心地开发,传播及货币化移动应用程序。作为一个开放的,行业所需的举措,Java Verified 是由 Unified Testing Initiative(UTI)开发的,建设检测框架的首个项目。Java Verified 是用于申请 Symbian Java 认证(Certified Signed)所须的代码签名证书。Java Verified 证书有效期为一年。比如GlobalSign证书就是这样的。
JAVA中 什么是方法签名
其实对于同名不同类、同类不同名的方法,方法签名的意义并不是很大,但是对于重载方法来说,方法签名的意义就十分巨大了。由于重载方法之间的方法名是相同的,那么我们势必要从构成方法的其他几个要素中找到另一个要素与方法名组成能够唯一标示方法的签名,方法体当然不予考虑。那么就是形参列表和返回值了,但是由于对于调用方法的人来说,方法的形参数据类型列表的重要程度要远远高于返回值,所以方法签名就由方法名+形参列表构成,也就是说,方法名和形参数据类型列表可以唯一的确定一个方法,与方法的返回值一点关系都没有,这是判断重载重要依据,所以,以下的代码是不允许的。
public long aaaa(){
}
public int aaaa(){
}
接下来,就来解释一下,当程序出现NoSuchMethodException时,JVM为我们提供的异常信息究竟是什么意思。首先我们先看几个方法以及他们的方法签名:
public void test1(){} test1()V
public void test2(String str) test2(Ljava/lang/String;)V
public int test3(){} test3()I
从以上三个例子,我们就可以很简单的看出一些小小的规律:
JVM为我们提供的方法签名实际上是由方法名(上文的例子为了简单没有写出全类名)、形参列表、返回值三部分构成的,基本形式就是:
全类名.方法名(形参数据类型列表)返回值数据类型
我们知道了JVM提供的方法签名的结构之后还是不够,因为JVM是并没有特别明确的将数据类型写出来,而是提供了特殊的表示法,下表就是对特殊表示字符、字母与对应数据类型的关系:
Java方法签名中特殊字符/字母含义
特殊字符 数据类型 特殊说明
V void 一般用于表示方法的返回值
Z boolean
B byte
C char
S short
I int
J long
F float
D double
[ 数组 以[开头,配合其他的特殊字符,表示对应数据类型的数组,几个[表示几维数组
L全类名; 引用类型 以L开头、;结尾,中间是引用类型的全类名
java如何对pdf文件实现数字签名
用Spire.Doc for Java 可以添加及验证数字签名,参考代码:
import com.spire.pdf.*;
import com.spire.pdf.graphics.PdfImage;
import com.spire.pdf.graphics.PdfTrueTypeFont;
import com.spire.pdf.security.GraphicMode;
import com.spire.pdf.security.PdfCertificate;
import com.spire.pdf.security.PdfCertificationFlags;
import com.spire.pdf.security.PdfSignature;
import java.awt.*;
import java.awt.geom.Point2D;
import java.awt.geom.Rectangle2D;
public class AddCertificate {
public static void main(String[]args){
//加载PDF文档
PdfDocument doc = new PdfDocument();
doc.loadFromFile("test.pdf");
//加载pfx证书,及证书秘钥
PdfCertificate cert = new PdfCertificate("Cermia.pfx","123654yes!");
//添加数字签名到指定页面,并设置其位置和大小
PdfSignature signature = new PdfSignature(doc, doc.getPages().get(2), cert, "MySignature");
Rectangle2D rect = new Rectangle2D.Float();
rect.setFrame(new Point2D.Float((float) doc.getPages().get(0).getActualSize().getWidth() - 340, (float) doc.getPages().get(0).getActualSize().getHeight() - 230), new Dimension(280, 150));
signature.setBounds(rect);
//设置签名为图片加文本模式
signature.setGraphicMode(GraphicMode.Sign_Image_And_Sign_Detail);
//设置签名的内容
signature.setNameLabel("签字者:");
signature.setName("Mia");
signature.setContactInfoLabel("联系电话:");
signature.setContactInfo("02881705109");
signature.setDateLabel("日期:");
signature.setDate(new java.util.Date());
signature.setLocationInfoLabel("地点:");
signature.setLocationInfo("成都");
signature.setReasonLabel("原因:");
signature.setReason("文档所有者");
signature.setDistinguishedNameLabel("DN: ");
signature.setDistinguishedName(signature.getCertificate().get_IssuerName().getName());
signature.setSignImageSource(PdfImage.fromFile("sign.png"));
//设置签名的字体
signature.setSignDetailsFont(new PdfTrueTypeFont(new Font("Arial Unicode MS", Font.PLAIN, 9)));
//设置文档权限为禁止更改
signature.setDocumentPermissions(PdfCertificationFlags.Forbid_Changes);
signature.setCertificated(true);
//保存文档
doc.saveToFile("AddSignature.pdf");
doc.close();
}
}
数字签名添加效果:
数字签名效果
参考原文
如何从java生成签名在AWS问题,怎么解决
Java2下Applet数字签名实现过程如下:
在代码的分发端:
(1)开发Java源程序并对其进行编译。
(2)用JAR工具对类文件和资源文件进行封装。
(3)用keytool创建公钥和密钥,生成X。509V1签名证书,输出证书。
(4)通过jarsigner工具用生成的密钥对JAR文件进行数字签名。
在代码的接收端:
(1)用keytool输入证书视其为可信任。
(2)用policytool创建和修改安全性策略配置文件,授权请求的访问权限。
(3)从网络取得字节码,用公钥验证数字签名证书和文档代码的完整性。
(4)验证字节码的合法性,根据策略文件分配相应权限。
(5)执行代码,完成后被垃圾回收器回收内存。
在用公钥验证数字签名证书之前,接收方需要确认公钥自身的可靠性,因此通常情况是提供一个包含公钥的证书而不是公钥自身。1个证书包括:
(1)1个公钥。
(2)1个唯一的名字实体(个人或公司),它是证书的所有者,包含用户名字、公司、组织、城市、地址、国家代码、省份等信息。
(3)数字签名:1个证书被1个分发者的实体签名,保证证书确实包含另1个实体(所有者)的公钥。
请问这个签名 java 应该怎么解析
楼主好,MD5签名是消息摘要,用于验证是否被篡改,不能解密.方法是接收方用发送方的签名算法,重新计算一次签名,然后比对结果.
请看示例代码(原创,已通过测试):
import java.io.UnsupportedEncodingException;
import java.util.Map;
import java.util.TreeMap;
import org.springframework.util.DigestUtils;
/**
* 仅用于演示.用于生产需完善细节处理.
* @author breakenkinfe
*/
public class MD5Sign {
static String md5Sign(MapString,String data) throws UnsupportedEncodingException {
String stringSignTemp="";
for(String key:data.keySet()) {
if("sign".equals(key)) {
continue;//sign不参与签名
}
String value=data.get(key);
if(value==null||value.trim().isEmpty()) {
continue;//值为空不参与签名
}
stringSignTemp+=(key+"="+data.get(key)+"");
}
if(!stringSignTemp.isEmpty()) {
stringSignTemp=stringSignTemp.substring(0, stringSignTemp.length()-1);//去掉最后一个''字符
}
// System.out.println("待签明文:"+stringSignTemp);
return DigestUtils.md5DigestAsHex(stringSignTemp.getBytes("UTF-8")).toUpperCase();
}
static void validSign(MapString,String data) throws UnsupportedEncodingException {
String sign=data.get("sign");
boolean rs= sign.equals(md5Sign(data));
if(rs) {
System.out.println("签名正确:"+sign);
}else {
System.out.println("签名错误:"+sign);
}
}
public static void main(String[] args) throws UnsupportedEncodingException {
//报文数据
MapString,String data=new TreeMapString,String();//保证key按ascii升序排列
data.put("key3", "value3");
data.put("key1", "value1");
data.put("key4", " ");
data.put("key2", "value2");
System.out.println("数据集:"+data);
//发送方增加签名
String sign=md5Sign(data);
System.out.println("MD5签名:"+sign);//output:38727F53497BF85E0BA60DE403C61B83
data.put("sign", sign);
//接收方验证签名
validSign(data);//正确
data.put("sign", "38727F53497BF85E0BA60DE403C61B80");
validSign(data);//错误
}
}
/** 输出:
数据集:{key1=value1, key2=value2, key3=value3, key4= }
MD5签名:38727F53497BF85E0BA60DE403C61B83
签名正确:38727F53497BF85E0BA60DE403C61B83
签名错误:38727F53497BF85E0BA60DE403C61B80
*/
关于代码签名java和代码签名证书出错的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
发布于:2022-12-16,除非注明,否则均为
原创文章,转载请注明出处。