专注WEB开发 分享经验,沉淀知识

禁止浏览器input表单自动填充

 作者:chenxing  时间:2017-05-10 15:41  评论:

前面提到过主要是password会出现这类填充现象,我们再加载页面的时候,把这个设置成其他类型的值-text,然后input聚焦的时候把它转化为password。这样加载页面的时候没有了password类型的input,那么就不会有自动填充现象,只要再输入的时候再把这个表单转化为password就行,这样问题就能得到解决了。

最近开发遇到了一个令人头疼的事儿--浏览器input表单的自动填充行为。在type类型是password附近的input都会被自动填充上信息。这个是不程序行为,而是浏览器自动填充。

禁止浏览器input表单自动填充

对于这个功能我深恶痛绝。

首先从程序角度看,回来结果变的不可控,明明是一段规范的代码产生的结果出乎意料,我们最讨厌这些出乎意料的结果。更甚,有些国产浏览器达到发指的地步,它居然能覆盖你设置的默认表单的值。为空的时候你自动填充,那无话可说,但是我都主动设值了还修改我的值,那这个就不能容忍了。

其次,从安全角度看。这个功能简直是牺牲安全性来换取用户体验的。使用这个你的确保你的设备是安全的,私有的,言外之意,你的电脑是是有的只能你一个人用,如果是多人使用电脑的话其他人很容易直接通用这种自动填充功能登录你的账号。

那么我们该如何禁止浏览器的这种野蛮行为(禁止浏览器input表单自动填充)?

前面提到过主要是password会出现这类填充现象,我们再加载页面的时候,把这个设置成其他类型的值-text,然后input聚焦的时候把它转化为password。这样加载页面的时候没有了password类型的input,那么就不会有自动填充现象,只要再输入的时候再把这个表单转化为password就行,这样问题就能得到解决了。

<input type="text" name="password" onfocus="this.type='password'" />

经测试,这个适用标准的浏览器(chrome,firfox,ie等),对于常见的国产浏览器(360,UC,QQ,百度,遨游等)也适用。至于一些小众的浏览器,没使用过也没测试,不能绝对保证有效。

除特别注明外,本站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/37.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

聊聊国产化

 2024-08-24 15:56  97

内网穿透工具frp配置详情

 2024-07-18 22:30  192

mac在终端复制出现乱码00~ *** 01~

 2024-07-16 20:38  43

php html生成图片

 2024-07-08 20:25  82

scp命令使用说明

 2024-07-06 12:14  113

如何在当前目录打开终端

 2024-07-04 14:54  84

 最新评论

 tradeOff: 08月30日 10:19
在某些领域国产化是一个迫不得已的事儿
来源: 聊聊国产化
 sue: 07月03日 10:24
可以
来源: 微信小程序如何获取单个input值
 流年: 07月02日 11:31
不错的尝试
来源: 博客系统如何用markdown编辑器发布文章
 诚心: 09月29日 23:01
学到了
来源: 如何一次性推送百万级别的消息
 Nick: 04月14日 12:26
网上的资料还是太老,都只是取一个元素,解决了一大难题
来源: redis set集合取出一组数据并删除
 skywalker: 11月03日 18:21
简洁明了
来源: mysql 获取某个日期的前一天或后一天