RMI Crawler->JMX Crawler

This commit is contained in:
geek 2018-01-03 17:19:26 +09:00
parent 12613b1cda
commit 64c6252145
9 changed files with 199 additions and 17 deletions

14
pom.xml
View File

@ -27,8 +27,9 @@
<spring.crypto.version>4.2.3.RELEASE</spring.crypto.version> <spring.crypto.version>4.2.3.RELEASE</spring.crypto.version>
<hibernate.version>5.2.10.Final</hibernate.version> <hibernate.version>5.2.10.Final</hibernate.version>
<javax.mail.version>1.4.7</javax.mail.version> <javax.mail.version>1.4.7</javax.mail.version>
<javax.mail-api.version>1.6.0</javax.mail-api.version>
<jackson.mapper.version>1.9.13</jackson.mapper.version> <jackson.mapper.version>1.9.13</jackson.mapper.version>
<apache.velocity.version>1.7</apache.velocity.version>
<docker.registry.name>docker.loafle.net/overflow</docker.registry.name> <docker.registry.name>docker.loafle.net/overflow</docker.registry.name>
</properties> </properties>
@ -128,6 +129,17 @@
<version>${javax.mail.version}</version> <version>${javax.mail.version}</version>
</dependency> </dependency>
<dependency>
<groupId>javax.mail</groupId>
<artifactId>javax.mail-api</artifactId>
<version>${javax.mail-api.version}</version>
</dependency>
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity</artifactId>
<version>${apache.velocity.version}</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-codec/commons-codec --> <!-- https://mvnrepository.com/artifact/commons-codec/commons-codec -->
<dependency> <dependency>
<groupId>commons-codec</groupId> <groupId>commons-codec</groupId>

View File

@ -0,0 +1,108 @@
package com.loafle.overflow.commons.model;
import java.util.Date;
import java.util.List;
import java.util.Map;
/**
* Created by geek on 18. 1. 3.
*/
public class Mail {
private String mailFrom;
private String mailTo;
private String mailCc;
private String mailBcc;
private String mailSubject;
private String mailContent;
private String contentType;
private List< Object > attachments;
private Map< String, Object > model;
public Mail() {
contentType = "text/plain";
}
public String getContentType() {
return contentType;
}
public void setContentType(String contentType) {
this.contentType = contentType;
}
public String getMailBcc() {
return mailBcc;
}
public void setMailBcc(String mailBcc) {
this.mailBcc = mailBcc;
}
public String getMailCc() {
return mailCc;
}
public void setMailCc(String mailCc) {
this.mailCc = mailCc;
}
public String getMailFrom() {
return mailFrom;
}
public void setMailFrom(String mailFrom) {
this.mailFrom = mailFrom;
}
public String getMailSubject() {
return mailSubject;
}
public void setMailSubject(String mailSubject) {
this.mailSubject = mailSubject;
}
public String getMailTo() {
return mailTo;
}
public void setMailTo(String mailTo) {
this.mailTo = mailTo;
}
public Date getMailSendDate() {
return new Date();
}
public String getMailContent() {
return mailContent;
}
public void setMailContent(String mailContent) {
this.mailContent = mailContent;
}
public List< Object > getAttachments() {
return attachments;
}
public void setAttachments(List < Object > attachments) {
this.attachments = attachments;
}
public Map< String, Object > getModel() {
return model;
}
public void setModel(Map < String, Object > model) {
this.model = model;
}
}

View File

@ -1,13 +1,15 @@
package com.loafle.overflow.commons.utils; package com.loafle.overflow.commons.utils;
import com.loafle.overflow.commons.model.Mail;
import org.apache.commons.codec.binary.Base64; import org.apache.commons.codec.binary.Base64;
import org.apache.velocity.app.VelocityEngine;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.io.FileSystemResource;
import org.springframework.mail.MailException; import org.springframework.mail.MailException;
import org.springframework.mail.SimpleMailMessage; import org.springframework.mail.SimpleMailMessage;
import org.springframework.mail.javamail.JavaMailSender; import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper; import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.ui.velocity.VelocityEngineUtils;
import javax.crypto.Cipher; import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.IvParameterSpec;
@ -15,6 +17,7 @@ import javax.crypto.spec.SecretKeySpec;
import javax.mail.MessagingException; import javax.mail.MessagingException;
import javax.mail.internet.MimeMessage; import javax.mail.internet.MimeMessage;
import java.io.File; import java.io.File;
import java.util.Map;
/** /**
* Created by geek on 17. 8. 30. * Created by geek on 17. 8. 30.
@ -25,32 +28,35 @@ public class EmailSender {
@Autowired @Autowired
private JavaMailSender mailSender; private JavaMailSender mailSender;
@Autowired
private VelocityEngine velocityEngine;
private String key = "loafle@RandomKey"; private String key = "loafle@RandomKey";
private String initVector = "loafleInitVector"; private String initVector = "loafleInitVector";
public void sendSimpleEmail(String to, String sub, String message) throws MailException { public void sendSimpleEmail(Mail mail) throws MailException {
SimpleMailMessage message1 = new SimpleMailMessage(); SimpleMailMessage message1 = new SimpleMailMessage();
message1.setTo(to); message1.setTo(mail.getMailTo());
message1.setSubject(sub); message1.setSubject(mail.getMailSubject());
message1.setText(message); message1.setText(getContentFromTemplate(mail.getModel()));
message1.setFrom("geek@loafle.com"); message1.setFrom("geek@loafle.com");
mailSender.send(message1); mailSender.send(message1);
} }
public void sendMailWithAttachment(String to, String sub, String text, String path) throws MessagingException { public void sendMailWithAttachment(Mail mail) throws MessagingException {
MimeMessage message = mailSender.createMimeMessage(); MimeMessage message = mailSender.createMimeMessage();
// pass 'true' to the constructor to create a multipart message // pass 'true' to the constructor to create a multipart message
MimeMessageHelper helper = new MimeMessageHelper(message, true); MimeMessageHelper helper = new MimeMessageHelper(message, true);
helper.setTo(to); helper.setTo(mail.getMailTo());
helper.setSubject(sub); helper.setSubject(mail.getMailSubject());
helper.setText(text); helper.setText(mail.getMailContent());
helper.setFrom("geek@loafle.com"); helper.setFrom("geek@loafle.com");
FileSystemResource file = new FileSystemResource(new File(path)); // FileSystemResource file = new FileSystemResource(new File(mail.getAttachments()));
helper.addAttachment("Invoice", file); // helper.addAttachment("Invoice", file);
mailSender.send(message); mailSender.send(message);
} }
@ -93,4 +99,15 @@ public class EmailSender {
return null; return null;
} }
private String getContentFromTemplate(Map<String, Object> model) {
StringBuffer content = new StringBuffer();
try {
content.append(VelocityEngineUtils.mergeTemplateIntoString(velocityEngine,"/templates/email-template.vm", "UTF-8", model));
} catch (Exception e) {
e.printStackTrace();
}
return content.toString();
}
} }

View File

@ -1,5 +1,6 @@
package com.loafle.overflow.module.email.service; package com.loafle.overflow.module.email.service;
import com.loafle.overflow.commons.model.Mail;
import com.loafle.overflow.commons.utils.EmailSender; import com.loafle.overflow.commons.utils.EmailSender;
import com.loafle.overflow.module.domain.dao.DomainDAO; import com.loafle.overflow.module.domain.dao.DomainDAO;
import com.loafle.overflow.module.domain.dao.DomainMemberDAO; import com.loafle.overflow.module.domain.dao.DomainMemberDAO;
@ -20,9 +21,7 @@ import org.springframework.stereotype.Service;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.net.URLDecoder; import java.net.URLDecoder;
import java.net.URLEncoder; import java.net.URLEncoder;
import java.util.Calendar; import java.util.*;
import java.util.Date;
import java.util.List;
/** /**
* Created by geek on 17. 6. 28. * Created by geek on 17. 6. 28.
@ -58,7 +57,18 @@ public class EmailAuthService {
String encode = URLEncoder.encode(en, "UTF-8"); String encode = URLEncoder.encode(en, "UTF-8");
// System.out.println("encode = [" + encode + "]"); // System.out.println("encode = [" + encode + "]");
emailSender.sendSimpleEmail(memberEmail, "Confirm Email", "http://127.0.0.1:19080/account/check_email?key="+ encode +"\r\nConfirm Email"); Mail mail = new Mail();
mail.setMailTo(memberEmail);
mail.setMailSubject("Confirm Email");
mail.setMailContent("http://127.0.0.1:19080/account/check_email?key="+ encode +"\r\nConfirm Email");
Map<String, Object> model = new HashMap<>();
model.put("firstName", auth.getMember().getName());
model.put("lastName", auth.getMember().getCompanyName());
model.put("location", "Seoul");
model.put("signature", "www.loafle.com");
mail.setModel(model);
emailSender.sendSimpleEmail(mail);
this.emailAuthDAO.save(auth); this.emailAuthDAO.save(auth);

View File

@ -70,7 +70,8 @@ public class MemberService {
} }
m.setSigninFailCount(m.getSigninFailCount()+1); m.setSigninFailCount(m.getSigninFailCount()+1);
this.modify(m); this.modify(m);
throw new SignInPwNotMatchException(); // throw new SignInPwNotMatchException();
return null;
} }
m.setSigninFailCount(0); m.setSigninFailCount(0);

View File

@ -1,11 +1,15 @@
package com.loafle.overflow.spring; package com.loafle.overflow.spring;
import org.apache.velocity.app.VelocityEngine;
import org.apache.velocity.exception.VelocityException;
import org.springframework.beans.factory.annotation.Value; import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import org.springframework.mail.javamail.JavaMailSenderImpl; import org.springframework.mail.javamail.JavaMailSenderImpl;
import org.springframework.ui.velocity.VelocityEngineFactory;
import java.io.IOException;
import java.util.Properties; import java.util.Properties;
/** /**
@ -54,6 +58,14 @@ public class MailConfiguration {
return javaMailProperties; return javaMailProperties;
} }
@Bean
public VelocityEngine getVelocityEngine() throws VelocityException, IOException {
Properties properties = new Properties();
properties.load(this.getClass().getResourceAsStream("/velocity.properties"));
return new VelocityEngine(properties);
}
} }
// //

View File

@ -864,6 +864,9 @@ INSERT INTO public."member" (company_name,create_date,email,"name",phone,pw,stat
INSERT INTO public.email_auth (auth_confirm_date,create_date,email_auth_key,member_id) VALUES ( INSERT INTO public.email_auth (auth_confirm_date,create_date,email_auth_key,member_id) VALUES (
NULL,'2017-06-26 15:28:48.895','dbseogns1234',1); NULL,'2017-06-26 15:28:48.895','dbseogns1234',1);
INSERT INTO public.email_auth (auth_confirm_date,create_date,email_auth_key,member_id) VALUES (
NULL,'2017-11-22 12:28:48.895','dbseogns1234',1);
INSERT INTO public."domain" (create_date,"name") VALUES ( INSERT INTO public."domain" (create_date,"name") VALUES (
'2017-06-26 11:25:44.866','overFlow''s domain'); '2017-06-26 11:25:44.866','overFlow''s domain');

View File

@ -0,0 +1,6 @@
resource.loader=jar
jar.resource.loader.class=org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
jar.runtime.log.logsystem.class=org.apache.velocity.runtime.log.SimpleLog4JLogSystem
jar.runtime.log.logsystem.log4j.category=velocity
jar.resource.loader.cache=true
input.encoding=UTF-8

View File

@ -0,0 +1,13 @@
<html>
<head></head>
<body>
<p>Dear ${firstName} ${lastName},</p>
<p>Sending Email <b>Velocity Template Test !!!</b></p>
<p>Thanks</p>
<p>${signature}</p>
<p>${location}</p>
</body>
</html>