jdk1.4 Spring 邮件群发,行列机制

2024-01-21 16:38

本文主要是介绍jdk1.4 Spring 邮件群发,行列机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

jdk1.4 Spring 邮件群发,队列 机制
Spring 邮件群发,队列 机制

<1>

package com.cofortune.zhengjia.common.utils;

import java.io.InputStream;


import javax.mail.internet.MimeMessage;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.mail.MailException;
import org.springframework.mail.MailSender;
import org.springframework.mail.SimpleMailMessage;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessagePreparator;

public class MailSenderPooled implements MailSender, JavaMailSender, Runnable {

protected final Log log = LogFactory.getLog(getClass());

// -------------------------------------------------------------------------

/**
  * 实际发送 邮件邮件发送器,可以是MailSender,或JavaMailSender
  */
private MailSender mailSender;

// -------------------------------------------------------------------------

/**
  * 邮件排队点号、发送线程,
  */
private Thread thread;

/**
  * 邮件排队队列
  */
private Queue queue = new Queue();

/**
  * 锁,仅此而已
  *
  * @see #run()
  * @see #add(Object)
  */
private Object mutex = new Object();

// -------------------------------------------------------------------------

/**
  * 构造本类对象,同时启动侦听 邮件的到达。
  *
  * 如果要阻止侦听和发送,应该调用close方法,在Spring的Context中"最好"配置destroy-method="close",不过这不是必须的。
  *
  */
public MailSenderPooled() {
  thread = new Thread(this);
  thread.setDaemon(true);
  thread.start();
}

// -------------------------------------------------------------------------

/**
  * 邮件发送循环,它被作为thread runnable的run实现。
  *
  * @see #add(Object)
  *
  */
public void run() {
  while (!isClose()) {
   if (!isEmpty()) {
    Object object = poll();
    try {
     // 执行实际发送
     doSend(object);
    } catch (Exception ex) {
     log.error(ex);
     ex.printStackTrace();
    }
   }
   // 等~直到add方法的通知!
   synchronized (mutex) {
    try {
     mutex.wait();
    } catch (InterruptedException e) {
    }
   }
  }
}

// -------------------------------------------------------------------------

public MailSender getMailSender() {
  return mailSender;
}

/**
  * 设置实际的 邮件发送器
  *
  * @param mailSender
  */
public void setMailSender(MailSender mailSender) {
  this.mailSender = mailSender;
}

// -------------------------------------------------------------------------

/**
  * 关闭PooledMailSender!
  *
  * 关闭的PooledMailSender不可再接收和发送 邮件
  */
public void close() {
  queue.clear();
  queue = null;
}

/**
  * 已经关闭?
  *
  * 关闭的PooledMailSender不可再接收和发送 邮件
  *
  * @return
  */
public boolean isClose() {
  return queue == null;
}

// -------------------------------------------------------------------------
// 邮件排队机操作方法代理

protected boolean isEmpty() {
  return queue != null && queue.isEmpty();
}

/**
  * 邮件加入排队机
  *
  * @param obj
  * @see #run()
  */
protected void add(Object obj) {
 
  queue.add(obj); 
  synchronized (mutex) {
   mutex.notify();
  }
}

protected Object poll() {
 
  return queue.poll();
}


// -------------------------------------------------------------------------
// MailSender接口实现-将 邮件放入排队机

public void send(SimpleMailMessage simpleMessage) throws MailException {
  add(simpleMessage);
}

public void send(SimpleMailMessage[] simpleMessages) throws MailException {

  SimpleMailMessage[] messages = simpleMessages;
  for (int i = 0; i < messages.length; i++) {
   SimpleMailMessage message = messages[i];
   add(message);
  }
}

// -------------------------------------------------------------------------
// // // JavaMailSender接口实现-将 邮件放入排队机

public void send(MimeMessage mimeMessage) throws MailException {
  add(mimeMessage);
}

public void send(MimeMessage[] mimeMessages) throws MailException {

  MimeMessage[] messages = mimeMessages;
  for (int i = 0; i < messages.length; i++) {
   MimeMessage message = messages[i];
   add(message);
  }

}

public void send(MimeMessagePreparator mimeMessagePreparator)
   throws MailException {
  add(mimeMessagePreparator);
}

public void send(MimeMessagePreparator[] mimeMessagePreparators)
   throws MailException {

  MimeMessagePreparator[] preparators = mimeMessagePreparators;
  for (int i = 0; i < preparators.length; i++) {
   MimeMessagePreparator preparator = preparators[i];
   add(preparator);
  }
}

public MimeMessage createMimeMessage() {
  return ((JavaMailSender) mailSender).createMimeMessage();
}

public MimeMessage createMimeMessage(InputStream contentStream)
   throws MailException {
  return ((JavaMailSender) mailSender).createMimeMessage(contentStream);
}

// -------------------------------------------------------------------------
// 实际发送代理方法

public void doSend(Object object) {
  if (object instanceof SimpleMailMessage) {
   doSend((SimpleMailMessage) object);
  } else if (object instanceof MimeMessage) {
   doSend((MimeMessage) object);
  } else if (object instanceof MimeMessagePreparator) {
   doSend((MimeMessagePreparator) object);
  }
}

public void doSend(SimpleMailMessage simpleMessage) throws MailException {
  mailSender.send(simpleMessage);
}

public void doSend(MimeMessage mimeMessage) throws MailException {
  ((JavaMailSender) mailSender).send(mimeMessage);
}

public void doSend(MimeMessagePreparator mimeMessagePreparator)
   throws MailException {
  ((JavaMailSender) mailSender).send(mimeMessagePreparator);
}

}


<2>

package com.cofortune.zhengjia.common.utils;

import java.util.LinkedList;
import java.util.List;

public class Queue {


private static Queue queue = new Queue();

private List list;

public static final int SIZE = 10;

public Queue() {
  list = new LinkedList();
}

public static Queue getInstance() {
  return queue;

}

public boolean isFull() {
  return list.size() == SIZE;
}

public void add(Object obj) {
  list.add(obj);
}

public Object poll() {
  return (Object) list.remove(0);
}

public boolean isEmpty() {
  return list.isEmpty();
}

public void clear(){
  list.clear();
}

}




本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/xymyeah/archive/2007/08/29/1763382.aspx

本文固定链接:http://www.verydemo.com/demo_c143_i15890.html

这篇关于jdk1.4 Spring 邮件群发,行列机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/630150

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定