getpassword java_java – 为什么JPasswordField.getPassword()创建一个带有密码的String?

博客围绕Java中Swing的JPasswordField展开,介绍其getPassword()方法可返回char数组,使用后能立即归零,避免敏感信息长时间留存在内存。还提及旧的getText()方法已被弃用,并给出示例代码,同时探讨了使用getText()的潜在危险。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Swing的

JPasswordField有一个返回char数组的

getPassword()方法。我的理解是,数组可以立即归零使用后,所以你没有敏感的东西挂在内存中很长时间。检索密码的旧方法是使用getText(),它返回一个String对象,但它已被弃用。

所以,我的问题是为什么它实际上正在使用的Java在检索过程中使用getPassword()?更清楚的是,我正在调试我的测试应用程序的东西其他**,我跟随调用和轰炸…调用JPasswordField的getText(),当然,一个很好的String对象与我的密码已创建,现在是挂在记忆。

自己尝试:

public class PasswordTest() {

public static void main(String[] args) {

JFrame frame = new JFrame();

frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

JPasswordField passField = new JPasswordField();

pass.addActionListener(new ActionListener() {

public ActionPerformed(ActionEvent evt) {

char[] p = passField.getPassword(); // put breakpoint

// do something with the array

}

});

frame.add(passField);

frame.setVisible(true);

frame.pack();

}

}

后续问题:这是’隐藏’使用getText()危险的任何方式?当然,一个专门的攻击者会得到你的密码,如果它已经危害系统,我说的不太专业的;

**我遇到了这个,而我正在寻找一种方法来实际显示一些敏感数据在Swing组件,而不使用String对象。显然没有办法,除非我愿意重写Swing API的一部分(所有?)。不会发生。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值