`
J0119
  • 浏览: 1826 次
  • 性别: Icon_minigender_2
  • 来自: 上海
最近访客 更多访客>>
社区版块
存档分类
最新评论

java 发送邮件

 
阅读更多
package test;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import org.apache.commons.mail.EmailAttachment;

import org.apache.commons.mail.MultiPartEmail;


import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.Colour;
import jxl.format.UnderlineStyle;
import jxl.format.VerticalAlignment;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;

public class FinalTest {

public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub


  String filePath = "src//ArticleRedirects.xls";
        Workbook book;
  try {
book = Workbook.getWorkbook(new File(filePath));

        //get a Sheet object.   

for (int sheeti= 0;sheeti<book.getNumberOfSheets();sheeti++){

        Sheet sheet = book.getSheet(sheeti); 

       
       
        WritableFont font1 = new WritableFont(WritableFont.ARIAL,14,WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE,Colour.RED);

WritableCellFormat cellFormat1 = new WritableCellFormat(font1);
//set background color;
cellFormat1.setBackground(Colour.LIGHT_TURQUOISE);
//set the border;
cellFormat1.setBorder(Border.ALL, BorderLineStyle.THIN);
//set wrap automatically;
cellFormat1.setWrap(true);
//set the text align center;
cellFormat1.setAlignment(Alignment.CENTRE);
//set the text align center vertically;
cellFormat1.setVerticalAlignment(VerticalAlignment.CENTRE);
       
       
        System.out.println(sheet.getName());
        List<String> redirectLink301 = new ArrayList<String>();
        List<String> baseLink301 = new ArrayList<String>();
        List<String> notFoundLinks = new ArrayList<String>();
        List<String> movedLink = new ArrayList<String>();
        List<String> otherStatusLink = new ArrayList<String>();
       
            
    for(int k =0;k<sheet.getRows();k++){
  

Cell cell = sheet.getCell(0, k);
   
    String baseLink = cell.getContents(); 
  if(baseLink.trim()!=""){ 
    URL url = new URL(baseLink);
 
     HttpURLConnection connection = (HttpURLConnection)url.openConnection();
       
         connection.setRequestMethod("GET");
         connection.connect();
       
        connection.setInstanceFollowRedirects( false );
        int code = connection.getResponseCode();

        if(code==301){
       
        URL url2 = new URL(baseLink);
        HttpURLConnection connection2 = (HttpURLConnection)url2.openConnection();
          
            connection2.setRequestMethod("GET");
            connection2.connect();
           InputStream is = connection2.getInputStream();
            
        baseLink301.add(baseLink);
        redirectLink301.add(connection2.getURL()+"");
            System.out.println(code + ":  redirect Link: "+baseLink);
        is.close();
      
       
        }else if(code==302){
        movedLink.add(baseLink);
        System.out.println(code+ ":  Moved links: "+baseLink);
         
        }else if(code==404){
        notFoundLinks.add(baseLink);
        System.out.println(code+ ":  NotFound Link: "+baseLink);
        }else{
       
        otherStatusLink.add(baseLink);
        System.out.println(code+ ":  sucess or other Status Links: "+baseLink);
        }

   }  

   
   
   
    //create excel 

   
      WritableWorkbook wwb = null;
  wwb = Workbook.createWorkbook(new File("src//testResults//resultsOf"+sheet.getName()+".xls"));
 
 
  WritableSheet movedws = wwb.createSheet("302 Moved links", 0);
  Label labelA0 = new Label(0, 0, "HERE ARE THE MOVED LINKS",cellFormat1);//set the format of the first line,first column
  movedws.addCell(labelA0);
  movedws.getSettings().setDefaultColumnWidth(60);
 
 
      for (int k =0;k<movedLink.size();k++){
    Label labelA = new Label(0, k+2, movedLink.get(k));
     try {
    movedws.addCell(labelA);
} catch (RowsExceededException e) {

e.printStackTrace();
} catch (WriteException e) {

e.printStackTrace();
}
     
      } 
     
     
      WritableSheet notFoundws = wwb.createSheet("404 not Found links", 0);
      Label labelL0 = new Label(0, 0, "HERE ARE THE NOTFOUND LINKS",cellFormat1);//set the format of the first line,first column
  notFoundws.addCell(labelL0);
  notFoundws.getSettings().setDefaultColumnWidth(60);
 
      for (int l =0;l<notFoundLinks.size();l++){
    Label labelL = new Label(0, l+2, notFoundLinks.get(l));
     try {
      notFoundws.addCell(labelL);
} catch (RowsExceededException e) {

e.printStackTrace();
} catch (WriteException e) {

e.printStackTrace();
}
     
      } 
     
     
      WritableSheet otherStatusws = wwb.createSheet("otherStatusLinks", 0);
  Label labeln0 = new Label(0, 0, "HERE ARE OTHER STATUS LINKS LIKE 200,5XX",cellFormat1);//set the format of the first line,first column
  otherStatusws.getSettings().setDefaultColumnWidth(60);
  otherStatusws.addCell(labeln0);
     
      for (int n =0;n<otherStatusLink.size();n++){
      Label labeln = new Label(0, n+2, otherStatusLink.get(n));
      try {
      otherStatusws.addCell(labeln);
      } catch (RowsExceededException e) {

e.printStackTrace();
      } catch (WriteException e) {

e.printStackTrace();
}
     
      } 
     
     
      WritableSheet redirect301ws = wwb.createSheet("redirect301Links", 1);
      Label labelB10 = new Label(0, 0, "BASE URL: BEFORE REDIRECT",cellFormat1);//set the format of the first line,first column
      redirect301ws.getSettings().setDefaultColumnWidth(60);
  redirect301ws.addCell(labelB10);
     
      for (int p =0;p<baseLink301.size();p++){
      Label labelB1 = new Label(0, p+2, baseLink301.get(p));
      try {
      redirect301ws.addCell(labelB1);
} catch (RowsExceededException e) {

e.printStackTrace();
} catch (WriteException e) {

e.printStackTrace();
}
     
      } 
  

     
      Label labelB0 = new Label(1, 0, "REDIRECED : AFTER REDIRECT",cellFormat1); //set the format of the first line,second column
      redirect301ws.addCell(labelB0);
      for (int m =0;m<redirectLink301.size();m++){
         
          Label labelB = new Label(1, m+2, redirectLink301.get(m)); 
      try {
      redirect301ws.addCell(labelB);
     
      } catch (RowsExceededException e) {

      e.printStackTrace();
      } catch (WriteException e) {

      e.printStackTrace();
      }
     
      }
     
     
      WritableSheet summary = wwb.createSheet("summary", 0);
     
      summary.getSettings().setDefaultColumnWidth(60);
      Label summaryLab = new Label(0, 0, "HERE ARE SUMMARIES OF  " +sheet.getName(),cellFormat1);//set the format of the first line,first column
      summary.addCell(summaryLab);
     
      Label label301redirects = new Label(0, 2, "301redirect links:" + baseLink301.size());
      Label labelNotFoundLinks = new Label(0, 3, "404 not Found links:" + notFoundLinks.size());
      Label labelmovedLinks = new Label(0, 4, "302 Moved links:" + notFoundLinks.size());
      Label otherStatusLinks = new Label(0, 5, "otherStatus links:" + otherStatusLink.size());
     
     
     
     
      summary.addCell(label301redirects);
      summary.addCell(labelNotFoundLinks);
      summary.addCell(labelmovedLinks);
         summary.addCell(otherStatusLinks);
     
      wwb.write();   
     
      wwb.close(); 
                
                
               
}
System.out.println("================DONE====================");

send();



} catch (BiffException e) {

e.printStackTrace();
} catch (IOException e) {

e.printStackTrace();
}        
        

}


public static void send() throws Exception{


MultiPartEmail email = new MultiPartEmail(); 
 
      
        email.setTLS(true); 
        email.setHostName("smtp.163.com"); 
        email.setAuthentication("zhoulihonggood", "16307932923148"); 
 
        EmailAttachment attachment = new EmailAttachment();
       
        CompressBook cbook = new CompressBook();
        cbook.zip("E:\\workspace\\verifyMMLinks\\src\\testResults");
       
        attachment.setPath("c:\\test.zip"); 
        attachment.setDisposition(EmailAttachment.ATTACHMENT);
        attachment.setDescription("result"); 
        attachment.setName("test.zip"); 
 
        email.addTo("szhou@defymedia.com"); 
        email.addCc("lzhang@defymedia.com");
        email.addCc("szhou@defymedia.com");
        email.addTo("cwong@defymedia.com");
        email.addCc("ywang@defymedia.com");
        email.addCc("MAlvarino@defymedia.com");
       
        email.setFrom("zhoulihonggood@163.com");
       
        email.setSubject("TestResults"); 
        email.setMsg("hi Calvin, I have attached the tested results"); 
 
        email.attach(attachment); 
        email.send(); 
}









    } 













  • 大小: 238.1 KB
分享到:
评论

相关推荐

    java发邮件 java发email

    Java发送电子邮件是一个常见的任务,尤其在自动化通知、报表发送或者用户验证等场景中。下面将详细解释如何使用Java来发送邮件,并提供相关的知识点。 首先,Java通过JavaMail API提供了发送邮件的功能。JavaMail ...

    java发送邮件工具

    java发送邮件工具类,用于java程序实现邮件的发送功能

    JAVA发送邮件实现,消息格式化

    本文将详细讲解如何使用Java发送邮件,并着重介绍消息格式化的概念及其重要性。 首先,发送邮件的核心类是JavaMail API提供的`javax.mail`包中的`Session`, `Message`, `Transport`等类。为了发送邮件,我们需要...

    javamail"java发送邮件所需要的包

    描述中提到的“java发送邮件所需要的包”即是指JavaMail API,它包含了一系列的类和接口,例如`javax.mail.Session`,它是邮件会话对象,用于配置邮件服务器的连接参数;`javax.mail.Transport`,用于发送邮件;`...

    java发送邮件功能

    Java发送邮件功能是Java开发中常见的一项任务,它允许开发者通过编程的方式实现电子邮件的发送,包括正文内容、附件以及抄送等高级功能。在Java中,我们主要利用JavaMail API来实现这一目标。 JavaMail API是一个...

    java发送邮件jar包2个

    java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个java发送邮件jar包2个...

    java发送邮件

    Java发送邮件是Java编程中的一项常见任务,尤其在企业级应用和自动化通知系统中非常普遍。本项目基于Maven构建,但如果你不使用Maven,你需要手动添加以下三个关键的JAR包:`mail.jar`,`commons-email-X.X.jar`,...

    java发送邮件实例

    Java发送邮件是一个常见的任务,尤其在自动化通知、报表发送或者用户验证等场景中。下面将详细解释这个过程,包括SMTP(Simple Mail Transfer Protocol)的工作原理、JavaMail API的使用以及可能遇到的问题及其解决...

    java发送邮件的实例

    总的来说,Java发送邮件涉及到了网络通信、邮件协议(如SMTP)、JavaMail API的使用,以及可能的认证机制。理解这些知识点对于实现一个稳定的邮件发送功能至关重要。在实际操作时,确保正确配置邮件服务信息,并对...

    JAVA发送邮件示例代码

    本文将详细讲解如何使用Java发送邮件,包括所需的库、基本概念以及实际示例代码。 首先,JavaMail API是Java平台用于处理邮件服务的核心库。要发送邮件,你需要在项目中引入JavaMail的依赖。如果你使用的是Maven,...

    java实现邮件发送(三种发送方式都有)

    Java发送邮件是软件开发中常见的需求,特别是在自动化通知、用户验证和客户服务等方面。在这个主题下,我们将探讨三种Java实现邮件发送的方式,以及如何通过提供的代码和参考资料进行实践。 首先,让我们了解一下...

    java发送邮件所需jar包.zip

    Java发送邮件是一个常见的任务,尤其在自动化通知、报表发送或者用户验证等场景中。要实现这个功能,开发者通常需要引入一些特定的库,也就是我们所说的jar包。在"java发送邮件所需jar包.zip"这个压缩文件中,很可能...

    java发送邮件Demo

    本示例“java发送邮件Demo”旨在教你如何利用JavaMail API实现这个功能。JavaMail API是一个开源库,允许开发者通过SMTP(简单邮件传输协议)发送、接收和管理邮件。 首先,确保在项目中引入JavaMail API的相关依赖...

    java 发送邮件sdk

    JavaMail SDK是Java发送邮件的核心工具,通过配置Session,创建并设置Message,以及使用Transport发送邮件,开发者可以轻松地在Java应用中实现邮件功能。同时,JavaMail还提供了丰富的功能,如HTML邮件、附件、抄送...

    java发送邮件完整程序

    Java发送邮件是一个常见的任务,尤其在自动化通知、订阅服务或者数据传输中。在这个"java发送邮件完整程序"中,我们将会探讨如何使用Java语言来构建一个邮件发送功能,包括所需的库、步骤以及关键代码片段。 首先,...

    java发送邮件源码

    本示例主要关注如何使用Java发送邮件,并结合`Mail.jar`库来实现这一功能。`Mail.jar`通常包含了JavaMail API,这是一个用于处理邮件的开源库。 首先,我们需要在项目中引入JavaMail API的相关依赖。如果是在Maven...

    JAVA发送邮件实现

    在Java编程语言中,发送邮件是一项常见的任务,尤其在开发Web应用、自动化通知或系统集成时。...Java发送邮件的功能十分强大,可以根据需求进行各种定制。通过学习和实践,你可以轻松地在Java应用中实现邮件服务功能。

    java发送邮件jar

    Java发送邮件功能主要依赖于两个库,即javax.mail.jar和activation.jar。这两个JAR文件包含了JavaMail API,它是Java平台中用于发送和接收电子邮件的标准API。让我们深入了解一下这两个库及其在Java邮件处理中的作用...

    使用java发送邮件的方法

    使用java发送邮件的方法,直接可以拿来用,最近找了个例子,稍微整理了一下

Global site tag (gtag.js) - Google Analytics