javamail 关于Access to default session denied

找了一下,百度第一条说了等于没说。现在给出分析以及解决方案:

Authenticator类对象每次都是创建新的对象。然后再看

 

先的问题就变成了怎么改,就这么改:

Session session = Session.getDefaultInstance(props, 
                        CtsAuthenticator.getCtsAuthenticator(data.get(USER_NAME), data.get(PASSWORD))
                         );
	static class CtsAuthenticator extends Authenticator{
		private static Map<String,CtsAuthenticator> ctsAuthenticatorMap=new HashMap<>(10);
		public final static CtsAuthenticator getCtsAuthenticator(String userName, String password){
			String key = "userName:"+userName+" password:"+password;
			CtsAuthenticator ctsAuthenticator = ctsAuthenticatorMap.get(key);
			if(ctsAuthenticator!=null){
				return ctsAuthenticator;
			}
			return newInstance(userName, password, key);
		}

		private synchronized static CtsAuthenticator newInstance(String userName, String password, String key) {
			CtsAuthenticator newInstance = new CtsAuthenticator(userName,password);
			ctsAuthenticatorMap.put(key,newInstance);
			return newInstance;
		}

		private String userName;
		private String password;

		private CtsAuthenticator(String userName,String password){
			this.userName=userName;
			this.password=password;
		}

		@Override
		public PasswordAuthentication getPasswordAuthentication() {
			return new PasswordAuthentication(userName, password);
		}
	}

就是把 Authenticator 缓存起来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值