新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
JSSE是一个SSL和TLS的纯Java实现,通过JSSE可以很容易地编程实现对HTTPS站点的访问。但是,如果该站点的证书未经权威机构的验证,JSSE将拒绝信任该证书从而不能访问HTTPS站点。
创新互联建站,专注为中小企业提供官网建设、营销型网站制作、响应式网站开发、展示型成都做网站、网站制作等服务,帮助中小企业通过网站体现价值、有效益。帮助企业快速建站、解决网站建设与网站营销推广问题。
PKI 目前使用最多的非对称算法是 RSA。对于基于 RSA 的 PKI 而言,CA 应有一对 RSA 的公私钥对,私钥是 CA 的生命,严格保密,而公钥则发布给使用方。CA 签发一张证书的话,主要是使用 CA 的 RSA 私钥对证书进行签名,并将签名结果保存在证书当中。使用者通过 CA 发布的公钥来验证证书中的签名值,就可以确定该证书是否是由该 CA 签发的。自己要做的就是从证书中提取签名数据和用于签名的原始数据,再使用 CA 的公钥验证这个签名就可以了。
楼上答主说的其实没错,只是描述的不太清楚。比如说有两个X509Certificate类型的证书对象caCert和userCert。
//获取CA根证书中的公钥
PublicKey publicKey = caCert.getPublicKey();
//使用用户证书验证根证书的公钥,如果验证通过说明这个用户证书是这个根证书签发的,验证不过就不是这个根证书签发的。
userCert.verify(publicKey);
如果只要判断有非法的字符(除0-9和Xx外)可用正则表达式publicstaticvoidmain(String[]args){//TODOcodeapplicationlogichereStrings="2142213weqrwe32";StringregEx="[^0-9Xx]";Patternpat=Pattern.compile(regEx);Matchermat=pat.matcher(s);booleanrs=mat.find();if(rs){System.out.print("有非法字符");}另外,校验身份证号码有专门程序的,可直接校验身份证号是否正确,在自己在网上找下
public class MyException extends Exception{
private static final long serialVersionUID = 6159733913043328242L;
public MyException(String ErrorMessage) {
super(ErrorMessage);
}
}
import java.util.Scanner;
/*
* 实现检查驾驶证考试年龄的异常(要求使用自定义异常)driver's license
*/
public class DriveLicense {
//定义方法,抛出异常
static int getAge(int age) throws MyException{
if (age18 || age70) {
throw new MyException("年龄不符合规定!");
} else {
System.out.println("可以参加考试。");
}
return age;
}
public static void main(String[] args) {
System.out.println("请输入年龄:");
Scanner scan = new Scanner(System.in);
int age = scan.nextInt();
try {
getAge(age);
} catch (MyException e) {
System.out.println(e);
//e.printStackTrace();
}
}
}