我实现了一个例程,当用户提交表单时,会将电子邮件发送给管理员。为此,我使用了Java Mail API。我设置了一个虚拟帐户,用于发送电子邮件。在代码中,我对密码进行了硬编码。我担心在托管网页时这将是一个安全问题。
这是我的代码。
我写了一个私有函数:
private void getSession(){
this.session = Session.getDefaultInstance(properties,
new javax.mail.Authenticator() {
protected PasswordAuthentication
getPasswordAuthentication() {
return new PasswordAuthentication("xxxxxxxxx@outlook.com", "xxxxx_password_xxx");
}
});
}
在我的公共execute()
方法中,我调用该getSession()
方法并生成消息。
public String execute() throws Exception {
getSession();
Message message = new MimeMessage(this.session);
message.setFrom(new InternetAddress("xxxxxxxxxxxxx@outlook.com"));
message.setRecipients(Message.RecipientType.TO,
InternetAddress.parse("admins.email@xxxxx.com"));
message.setSubject("Form submit notification");
//...
}
托管网页时,在会话方法中对密码进行硬编码是否安全?
如果没有,那么一些实现替代方案的指针。
谢谢!
在这种情况下,他无法对密码进行哈希处理。仅当需要检查而不使用密码时,才可以对密码进行哈希处理。使用密码(即后端需要登录到SMTP服务器以发送电子邮件,或登录到另一个数据库以提取数据)意味着需要知道它。
在这种情况下,存在3 +
1级替代方案,基本上将不安全性从代码转移到了其他地方。但是,只要程序具有相同的前提条件,攻击者将始终能够恢复密码。获取它们的可能性衡量了该密码的安全级别。
这些解决方案的风险
0-用srcs硬编码的密码->风险与检索 代码 的容易性有关; 即使在C / C
++中,反编译以提取经编码的字符串也不难,在Java和.NET中是微不足道的,即时的
当然,从1到3,实现变得更加困难。4是HSM的api问题。
问题内容: 我正在开发一个从数据库读取一些数据的应用程序。通过标准登录/密码机制执行与数据库的连接。 问题是:如何存储数据库密码?如果我将其存储为类成员,则可以通过反编译操作轻松检索它。 我认为混淆并不能解决问题,因为在混淆代码中也可以轻松找到字符串密码。 有人有建议吗? 问题答案: 切勿将密码硬编码到您的代码中。最近在最危险的25个编程错误中提到了这一点。 将秘密帐户和密码硬编码到您的软件中非常
从属性文件读取密码后,将其存储在静态变量中是否安全?我看到有一些关于密码不应存储在字符串(java)中的最佳实践,但我找不到有人讨论在应用程序的整个生命周期中如何将密码存储在静态(字符串/字符[])变量中。 将密码存储在静态变量中会导致密码暴露于外部世界的额外威胁吗?是否应该在创建与外部系统的连接后设置密码变量?
我正在使用jQuery mobile和Spring MVC开发一个包含多页模板的移动应用程序。我有一个包含锚链接的jsp;每当我单击链接时,就会调用事件并执行jQuery函数。我从函数中的链接获得了一个id,并将其存储在jQuery变量中。现在我想重用jstltag中jQuery变量的值,该值在核心标记库中可用。如何使用该值?这是我的jsp:
我正在用Firebase和Angular5构建一个web应用程序。我想创建/加入私人房间(受密码保护)。 目前,我正处于数据库设计阶段,无法真正了解如何在不从firebase数据库中实际检索的情况下检查用户输入的正确房间密码(从而使其完全不安全)。 我应该为此使用云功能吗。或者直接用firebase就可以了,而我错过了什么?
我想调用一个名称(带或不带圆括号和参数)存储在字符串变量中的方法,并使用该变量调用该方法。 到目前为止,我发现在Java中,如果您这样做: 这将调用方法。但我认为这是不推荐的。所以,我的问题是: 谢了。
我已经创建了一个自定义用户存储提供程序,它将根据需要将用户从遗留系统迁移到KeyCloak的本地存储。