签名文件签名(java代码)

代码签名  时间:2021-04-08  阅读:()

package encryptdecrypt;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;import java.security.KeyPair;import java.security.KeyPairGenerator;import java.security.PrivateKey;import java.security.PublicKey;import javax.swing.JFileChooser;import javax.swing.JFrame;import javax.swing.JMenu;import javax.swing.JMenuBar;import javax.swing.JMenuItem;import javax.swing.JOptionPane;import javax.swing.JScrollPane;import javax.swing.JTextArea;import javax.swing.ScrollPaneConstants;publicclass FileSignature {

/**

* @param args

*/publicstaticvoid main(String[ ] args) {// TODO Auto-generated method stub

DemoWindow5 dw = new DemoWindow5("文件签名");dw.setBounds(dw.getToolkit() .getScreenSize() .width / 3,dw.getToolkit()

.getScreenSize() .height / 3,dw.getToolkit() .getScreenSize() .width / 3,dw.getToolkit()

.getScreenSize() .height / 3);dw.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);dw.setVisible(true) ;

}

}classDemoWindow5extends JFrame implements ActionListener {JMenuBar menuBar = new JMenuBar();

JMenu fileMenu = new JMenu("文件");

JMenuItem openMenuItem = new JMenuItem("打开文件");

JMenuItem saveMenuItem = new JMenuItem("保存文件");

JMenu signMenu = new JMenu("签名验证");

JMenuItem generateItem = new JMenuItem("生成密钥对");JMenuItem signItem = new JMenuItem("签名文件") ;

JMenuItem validateItem = new JMenuItem("验证文件");

JTextArea jta = new JTextArea();intv = Sc rollPaneConstants.VERTICAL_SCROLLBAR_AS_NEEDED;inth = Sc rollPaneConstants.HORIZONTAL_SCROLLBAR_AS_NEEDED;JScrollPane jsp = new JScrollPane(jta, v, h) ;public DemoWindow5(String title) {super(title);fileMenu.add(openMenuItem);fileMenu.add(saveMenuItem);signMenu.add(generateItem);signMenu.add(signItem);signMenu.add(validateItem);menuBar.add(fileMenu);menuBar.add(signMenu);this.setJMenuBar(menuBar);add(jsp);openMenuItem.addActionListener(this);saveMenuItem.addActionListener(this);

generateItem.addActionListener(this);signItem.addActionListener(this);validateItem.addActionListener(this);

}publicvoid actionPerformed(ActionEvent e) {

// TODO Auto-generated method stubif (e.getSource() == openMenuItem) {openFile();

} elseif (e.getSource() == saveMenuItem) {saveFile();

} elseif (e.getSource() == generateItem) {generateKeys();

} elseif (e.getSource() == signItem) {sign();

} elseif (e.getSource() == validateItem) {validateSign();

}

}publicvoid openFile() {

String fileName = null;

// System.getProperty("user.dir")是获得用户当前的工作目录JFileChooser jfc = new

JFileChooser(System.getProperty("user.dir") ) ;jfc.setDialogTitle("打开文件");

//如果选中获取选择的文件的完整路径if (jfc.showOpenDialog(this) ==

J FileChooser.APPROVE_OPTION) {fileName = jfc.getSelectedFile() .getPath();

System.out.println(fileName);

}if (fileName == null)return;try {

FileInputStream fis = new FileInputStream(fileName);byte[ ] text = newbyte[f is.available()] ;f is.read(text);fis.close();

jta.setText(new String(text) );

} catch (Exception e1) {e1.printStackTrace();

}

}publicvoid saveFile() {

String fileName = null;

JFileChooser jfc = new

JFileChooser(System.getProperty("user.dir") ) ;jfc.setDialogTitle("保存文件");if (jfc.showSaveDialog(this) ==

J FileChooser.APPROVE_OPTION) {fileName = jfc.getSelectedFile() .getPath();

}if (fileName == null)return;try {

FileOutputStream fos = new FileOutputStream(fileName,false) ;fos.write(jta.getText() .getBytes()) ;fos.close();

} catch (Exception e1) {e1.printStackTrace();

}

}publicvoid generateKeys() {try {

String fileName = null;

JFileChooser jfc = new JFileChooser();jfc.setDialogTitle("生成密钥对");jfc.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY);if (jfc.showSaveDialog(this) ==

J FileChooser.APPROVE_OPTION) {

fileName = jfc.getSelectedFile() .getPath();}if (fileName == null)return;

File file = new File(fileName);if ( !file.exists() ) {file.mkdir();

}

//创建DSA密钥对生成器

KeyPairGenerator keygen =

KeyPairGenerator.getInstance("DSA");

//采用1024位DSA密钥keygen.initialize(1024);

//得到密钥对

KeyPair keys = keygen.generateKeyPair();

PublicKey pubkey = keys.getPublic();

PrivateKey prikey = keys.getPrivate();

ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(fileName + "/公钥.dat") );out.writeObject(pubkey);out.close();out = new ObjectOutputStream(new

FileOutputStream(fileName

+ "/私钥.dat") );out.writeObject(prikey);out.close();

} catch (Exception e1) {e1.printStackTrace();

}

}publicvoid sign() {try {

String fileName = null;

JFileChooser jfc = new JFileChooser();jfc.setDialogTitle( "导入私钥文件");

if (jfc.showOpenDialog(this) ==

J FileChooser.APPROVE_OPTION) {fileName = jfc.getSelectedFile() .getPath();}if (fileName == null)return;

//获取私钥

ObjectInputStream ois = new ObjectInputStream(newFileInputStream(f ileName) );

PrivateKey prikey = (PrivateKey) ois.readObject() ;//创建SHAlwithDSA签名类java.security.Signature dsa =java.security.Signature.getInstance(

"SHA1withDSA", "SUN");

//设置生成摘要的私钥dsa.initSign(prikey);

//对文本区的文本进行签名验证dsa.update(jta.getText() .getBytes( "UTF-8"));

//得到签名后的签名摘要值byte[ ] signText = dsa.sign();jfc = new JFileChooser();jfc.setDialogTitle("保存签名文件");if (jfc.showSaveDialog(this) ==

J FileChooser.APPROVE_OPTION) {fileName = jfc.getSelectedFile() .getPath();}if (fileName == null)return;

FileOutputStream fos = new FileOutputStream(fileName);fos.write(signText);fos.close();

} catch (Exception e1) {e1.printStackTrace();

}

}

publicvoid validateSign() {try {

String fileName = null;

JFileChooser jfc = new JFileChooser();jfc.setDialogTitle("导入公钥文件");if (jfc.showOpenDialog(this) ==

J FileChooser.APPROVE_OPTION) {fileName = jfc.getSelectedFile() .getPath();}if (fileName == null)return;

ObjectInputStream in = new ObjectInputStream(newFileInputStream(f ileName) );

PublicKey pubkey = (PublicKey) in.readObject();jfc = new JFileChooser();jfc.setDialogTitle("打开签名文件");if (jfc.showOpenDialog(this) ==

J FileChooser.APPROVE_OPTION) {fileName = jfc.getSelectedFile() .getPath();}if (fileName == null)return;

//从签名文件中读取签名摘要

FileInputStream fis = new FileInputStream(fileName);byte[ ] sigToVerfiy = newbyte[fis.available() ] ;f is.read(sigToVerf iy);fis.close();

//创建SHA1withDSA签名类java.security.Signature sig =java.security.Signature.getInstance(

"SHA1withDSA", "SUN");

//设置验证的公钥sig.initVerify(pubkey);

//验证文本区sig.update(jta.getText() .getBytes( "UTF-8"));

//显示验证信息

if (sig.verify(sigToVerfiy)) {

JOptionPane.showMessageDialog(null, "签名正确");} else {

JOptionPane.showMessageDialog(null, "签名不正确");}

} catch (Exception e1) {e1.printStackTrace();

}

}

}

Linode十八周年及未来展望

这两天Linode发布了十八周年的博文和邮件,回顾了过去取得的成绩和对未来的展望。作为一家运营18年的VPS主机商,Linode无疑是有一些可取之处的,商家提供基于KVM架构的VPS主机,支持随时删除(按小时计费),可选包括美国、英国、新加坡、日本、印度、加拿大、德国等全球十多个数据中心,所有机器提供高出入网带宽,最低仅$5/月($0.0075/小时)。This month marks Linod...

Gcorelabs:美国GPU服务器,8路RTX2080Ti;2*Silver-4214/256G内存/1T SSD,1815欧/月

gcorelabs怎么样?gcorelabs是创建于2011年的俄罗斯一家IDC服务商,Gcorelabs提供优质的托管服务和VPS主机服务,Gcorelabs有一支强大的技术队伍,对主机的性能和稳定性要求非常高。Gcorelabs在 2017年收购了SkyparkCDN并提供全球CDN服务,目标是进入全球前五的网络服务商。G-Core Labs总部位于卢森堡,在莫斯科,明斯克和彼尔姆设有办事处。...

Hostodo(年付12美元)斯波坎VPS六六折,美国西海岸机房

Hostodo是一家成立于2014年的国外VPS主机商,现在主要提供基于KVM架构的VPS主机,美国三个地区机房:拉斯维加斯、迈阿密和斯波坎,采用NVMe或者SSD磁盘,支持支付宝、PayPal、加密货币等付款方式。商家最近对于上架不久的斯波坎机房SSD硬盘VPS主机提供66折优惠码,适用于1GB或者以上内存套餐年付,最低每年12美元起。下面列出几款套餐配置信息。CPU:1core内存:256MB...

代码签名为你推荐
深圳route360退出北京时间北京时间校准显示时间cisco2960配置cisco 2960 配置VLAN上网cisco2960cisco2960接入层交换机duplicate500闪拍网闪拍网之类的网站怎么回事?三五互联南京最专业的网站建设公司是哪家?双尚网络做的好不好? 给分求答案discuz伪静态discuz怎么才能把专题目录也实现伪静态的方法详解团购程序什么是团购 团购的目的与流程无忧代理网什么是 ‘无忧在线’ 安全电脑保护专家?
如何注册域名 主机域名 河北服务器租用 万网域名代理 域名解析服务器 132邮箱 韩国俄罗斯 Vultr java主机 tier mediafire下载 轻量 元旦促销 泉州电信 酷番云 免费网页申请 谷歌台湾 主机返佣 创速 七牛云存储 更多