在JavaScript / HTML中,无法通过开发者工具查看DOM元素中input里输入的密码

这是一个很好的前端安全问题。该情况通常是通过以下几种技术实现的:

1. input type="password" 属性

最基础的方法,浏览器会自动隐藏密码值:

html 复制代码
<input type="password" id="password" name="password">

在DOM中你只能看到这个元素,但看不到实际的输入内容。

2. JavaScript 动态处理

更高级的方法包括:

实时替换显示值

javascript 复制代码
const passwordInput = document.getElementById('password');
passwordInput.addEventListener('input', function(e) {
    // 实际值存储在data属性或变量中
    this.setAttribute('data-real-value', e.target.value);
    // 显示值用●或*替换
    this.value = '●'.repeat(e.target.value.length);
});

使用隐藏的input存储真实值

javascript 复制代码
const displayInput = document.getElementById('password-display');
const realInput = document.getElementById('password-real');

displayInput.addEventListener('input', function(e) {
    realInput.value = e.target.value;
    displayInput.value = '●'.repeat(e.target.value.length);
});

3. 框架级别的保护

现代前端框架如React、Vue会:

  • 使用受控组件管理状态
  • 密码值存储在组件状态中,不直接暴露在DOM

4. 浏览器安全机制

即使看到value属性,现代浏览器也会:

  • 在开发者工具中屏蔽password类型的值显示
  • 防止通过脚本轻易获取其他页面的密码输入

如何验证?

你可以尝试:

  1. 在Console中输入:document.querySelector('input[type="password"]').value
  2. 查看Network标签,观察表单提交时的数据
  3. 检查是否有隐藏的input元素

这种设计主要是为了防止肩窥攻击,保护用户的密码安全。

相关推荐
liguojun20254 天前
软硬一体智慧场馆系统推荐——助力场馆数字化高效升级
java·大数据·人工智能·物联网·1024程序员节
开开心心就好16 天前
吾爱大佬原创的文件时间修改工具
安全·智能手机·pdf·电脑·智能音箱·智能手表·1024程序员节
开开心心就好21 天前
近200个工具的电脑故障修复合集
安全·智能手机·pdf·电脑·consul·memcache·1024程序员节
数据皮皮侠AI23 天前
中国城市可再生能源数据集(2005-2021)|顶刊 Sci Data 11 种能源面板
大数据·人工智能·笔记·能源·1024程序员节
计算机毕业论文辅导1 个月前
物联网实战:基于MQTT协议的智能家居数据传输系统设计与实现
1024程序员节
开开心心就好1 个月前
支持批量处理的视频分割工具推荐
安全·智能手机·rust·pdf·电脑·1024程序员节·lavarel
liuyao_xianhui1 个月前
Linux开发工具结尾 _make
linux·运维·服务器·数据结构·哈希算法·宽度优先·1024程序员节
学传打活1 个月前
【边打字.边学昆仑正义文化】_21_爱的结晶(1)
微信公众平台·1024程序员节·汉字·昆仑正义文化
数据皮皮侠AI1 个月前
顶刊同款!中国地级市风灾风险与损失数据集(2000-2022)|灾害 / 环境 / 经济研究必备
大数据·人工智能·笔记·能源·1024程序员节
Fab1an1 个月前
Busqueda——Hack The Box 靶机
linux·服务器·学习·1024程序员节