outlook邮箱密码修改就可以了吗.改完密码别人会不会找回

QQ邮箱密码被人改了,我要怎样才可以改回?高手进!
本回答由提问者推荐
var sogou_ad_id=731547;
var sogou_ad_height=160;
var sogou_ad_width=690;邮箱被盗了。。。改密码就可以了吗??害怕啊! - 福步新人 -
福步外贸论坛(FOB Business Forum) |中国第一外贸论坛
UID 1608828
阅读权限 25
邮箱被盗了。。。改密码就可以了吗??害怕啊!
作为一个外贸新手,最近老是受到带有链接的询盘回复。然后也没多想就直接输入了邮箱地址和密码(现在想起来真是脑残!)。还输入了好几个我的工作邮箱, gmail的hotmail。后来上了福步才知道,那是骗子的钓鱼链接。看来很多前辈上当的经历都是十几万十几万的, 吓得我够呛!
于是马上就登陆gmail去更改密码,也确认了没有cc给别的邮箱。 但是还是不放心啊!
想请教一下各位高手是不是邮箱我更改了密码就安全了呢?
然后我也发了邮件给我的客户(就一个熟客),说我们公司最近很多邮箱都给骗子黑了,叫他小心,不要随便汇钱给人, 谁知道客户也不回复, 让我更加担心了怕失去了这么一个唯一的客户!
谁有什么好主意一定要救救我啊,晚上都睡不着觉了~~55555可恨的骗子!!
UID 1609834
阅读权限 25
我们也收到了很多钓鱼的询盘,我也是新手,不过我用的私人邮箱进去的,还是私人QQ邮箱,估计那些尼日利亚的人也不会盗的。。。以后做事要小心嘛,不要拿公司的号开玩笑,输不起的
UID 1608828
阅读权限 25
问题是事情已经发生了, 不知道改密码之后还会不会有问题呢。。。。
UID 420122
阅读权限 60
注意上网卫生~~~~~~~~
UID 1603503
阅读权限 40
我没遇到过昵,,幸运幸运。。。不过还是得小心为妙!
UID 1608828
阅读权限 25
新手啊,真的是太大意了,现在肠子都悔清了! 然后老客户还是不回我邮件,现在更后悔告诉客户邮箱被黑了。。。
UID 1582618
阅读权限 40
来自 福建廈門
密码经常改改罗。。。 平时多注意啊!
UID 1608828
阅读权限 25
谢谢呢~密码是已经改了。骗子应该没其它法子盗用我邮箱了吧?
UID 1608828
阅读权限 25
才刚用阿里巴巴不到2个月,怎么就这么倒霉!
UID 1577120
阅读权限 25
同情,不要什么网站都填密码信息
UID 1609732
阅读权限 25
哦,还这样啊,好恐怖
UID 1609994
阅读权限 25
哈哈,不要担心。。。。没什么过不去的~~~~~~~
UID 1608828
阅读权限 25
在我发现之后就马上改了,但是没改之前真的不知道骗子有没有做什么坏事。。
当前时区 GMT+8, 现在时间是
Powered by D1scuz! &&
FOBShanghai.comJava实现邮箱找回密码实例代码
作者:智慧云端日记
字体:[ ] 类型:转载 时间:
本篇文章主要介绍了Java实现邮箱找回密码实例代码,可以通过邮箱找回丢失密码,具有一定的参考价值,有需要的可以了解一下。
通过邮件找回密码功能的实现
1、最近开发一个系统,有个需求就是,忘记密码后通过邮箱找回。现在的系统在注册的时候都会强制输入邮箱,其一目的就是 通过邮件绑定找回,可以进行密码找回。通过java发送邮件的功能我就不说了,重点讲找回密码。
2、参考别人的思路:发送邮件→请求邮件里的URL→验证url→{验证成功修改密码,不成功跳转到失败页面}
重点就是如何生成这个url和如何解析这个url.
需要注意的是一个url只能修改一次密码,当同一帐号发送多封邮件,只有最后一封邮件的url 邮箱
&3、加密能防止伪造攻击,一次url只能验证一次,并且绑定了用户。生成url:&& 可以用UUID生成随机密钥。
数字签名 = MD5(用户名+'′+过期时间+‘′+过期时间+‘'+密钥key)
数据库字段(用户名(主键),密钥key,过期时间)
url参数(用户名,数字签名) ,密钥key的生成:在每一个用户找回密码时候为这个用户生成一个密钥key ,
生成过期时间,生成数字签名,生成url,发送邮件.&& AddU(用户名,密钥key,过期时间)
使用到的数据库如下 :
找回邮箱密码代码如下:
package com.soq.card.web.
import java.sql.T
import java.util.L
import java.util.UUID;
import org.hibernate.C
import org.hibernate.S
import org.hibernate.SessionF
import org.hibernate.criterion.R
import org.springframework.orm.hibernate3.HibernateT
import com.soq.card.biz.UserH
import com.soq.card.entity.U
import com.soq.card.tools.DB
import com.soq.card.tools.M
import com.soq.card.tools.Md5;
import com.soq.card.web.base.BaseA
* @author javen
public class PassEmailAction extends BaseAction {
private UserHander userH
private String userN
public String sendmail() {
HibernateTemplate ht = this.getUserHander().getUsersDAO().getHibernateTemplate();
SessionFactory factory = ht.getSessionFactory();
Session session = factory.openSession();
Criteria criteria = session.createCriteria(Users.class);
criteria.add(Restrictions.eq("loginName", email));
List&Users& list = criteria.list();
if (list.size() & 0) {
users=list.get(0);
Mail mail = new Mail();
String secretKey = UUID.randomUUID().toString(); // 密钥
Timestamp outDate = new Timestamp(System.currentTimeMillis() + 30 * 60 * 1000);// 30分钟后过期
long date = outDate.getTime() / 1000 * 1000;// 忽略毫秒数 mySql 取出时间是忽略毫秒数的
DBhepler bhepler=new DBhepler();
String sql="update users set outDate=?,validataCode=? where loginName=?;";
String str[] ={outDate+"",secretKey,users.getLoginName()};
bhepler.AddU(sql, str);
//this.getUserHander().getUsersDAO().getHibernateTemplate().update(users); // 保存到数据库
System.out.println("
UserName&&&& "+users.getUserName());
String key =users.getUserName() + "$" + date + "$" + secretK
System.out.println(" key&&&"+key);
String digitalSignature = Md5.md5(key);// 数字签名
String path = this.getRequest().getContextPath();
String basePath = this.getRequest().getScheme() + "://"
+ this.getRequest().getServerName() + ":"
+ this.getRequest().getServerPort() + path + "/";
String resetPassHref = basePath + "checkLink?sid="
+ digitalSignature +"&userName="+users.getUserName();
String emailContent = "请勿回复本邮件.点击下面的链接,重设密码&br/&&a href="
+ resetPassHref + " target='_BLANK'&" + resetPassHref
+ "&/a& 或者
&a href=" + resetPassHref
+ " target='_BLANK'&点击我重新设置密码&/a&"
+ "&br/&tips:本邮件超过30分钟,链接将会失效,需要重新申请'找回密码'" + key
+ "\t" + digitalS
mail.setTo(email);
mail.setFrom("XX");// 你的邮箱
mail.setHost("smtp.163.com");
mail.setUsername("");// 用户
mail.setPassword("CXXX");// 密码
mail.setSubject("[二维码名片]找回您的账户密码");
mail.setContent(emailContent);
if (mail.sendMail()) {
System.out.println(" 发送成功");
this.getRequest().setAttribute("mesg", "重置密码邮件已经发送,请登陆邮箱进行重置!");
return "sendMail";
this.getRequest().setAttribute("mesg", "用户名不存在,你不会忘记邮箱了吧?");
return "noUser";
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
public String checkResetLink() {
System.out.println("sid&&&" + sid);
if (sid.equals("") || userName.equals("")) {
this.getRequest().setAttribute("mesg", "链接不完整,请重新生成");
System.out.println("&&&&& null");
return "error";
HibernateTemplate ht = this.getUserHander().getUsersDAO().getHibernateTemplate();
SessionFactory factory = ht.getSessionFactory();
Session session = factory.openSession();
Criteria criteria = session.createCriteria(Users.class);
criteria.add(Restrictions.eq("userName", userName));
List&Users& list = criteria.list();
if (list.size()&0) {
users=list.get(0);
Timestamp outDate = (Timestamp) users.getOutDate();
System.out.println("outDate&&&"+outDate);
if(outDate.getTime() &= System.currentTimeMillis()){ //表示已经过期
this.getRequest().setAttribute("mesg", "链接已经过期,请重新申请找回密码.");
System.out.println("时间 超时");
return "error";
String key = users.getUserName()+"$"+outDate.getTime()/+"$"+users.getValidataCode();//数字签名
System.out.println("key link》》"+key);
String digitalSignature = Md5.md5(key);// 数字签名
System.out.println("digitalSignature&&&&"+digitalSignature);
if(!digitalSignature.equals(sid)) {
this.getRequest().setAttribute("mesg", "链接不正确,是否已经过期了?重新申请吧.");
System.out.println("标示不正确");
return "error";
//链接验证通过 转到修改密码页面
this.getRequest().setAttribute("user", users);
return "success";
this.getRequest().setAttribute("mesg", "链接错误,无法找到匹配用户,请重新申请找回密码.");
System.out.println("用户不存在");
return "error";
public Users getUsers() {
public void setUsers(Users users) {
this.users =
public UserHander getUserHander() {
return userH
public void setUserHander(UserHander userHander) {
this.userHander = userH
public String getEmail() {
public void setEmail(String email) {
this.email =
public String getSid() {
public void setSid(String sid) {
this.sid =
public String getUserName() {
return userN
public void setUserName(String userName) {
this.userName = userN
补充1:Timestamp类型对象在保存到数据的时候 毫秒精度会丢失。比如: 10:30:10.234& 存到mysql数据库的时候 变成
10:30:10.0。时间变得不相同了,sid 匹配的时候不会相等。 所以我做了忽略精度的操作。
补充2:解决linux下面title中文乱码
sun.misc.BASE64Encoder enc = new sun.misc.BASE64Encoder();
mailMessage.setSubject(MimeUtility.encodeText(mailInfo.getSubject(), "UTF-8", "B"));
//解决linux邮件title乱码
补充3:怎么不直接把sid插入到users表呢。验证的时候直接比较sid就ok了。
源码下载地址:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具}

我要回帖

更多关于 如何更改邮箱密码 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信