项目基本思路:
1、前后端分离,使用AJAX中的GET POST方法请求Servlet
2、Servlet调用Service方法,再进一步调用Dao操作数据库
3、将Servlet中获取的值以Json格式返回前端,进行解析
将表单中提交的数据转换成username=aaa&&password=bbb格式只需一行代码
$(this).serialize() this指代的是需要提交的表单
使用classLoader加载文件时不需要加/
InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
用户进行登录操作后,可以将User对象存入Session中,在需要判断用户是否登录时可以获取Session判断是否为null
如果页面有乱码现象可用response.setContentType("text/html;charset=utf-8")解决
邮箱激活码的实现:
import javax.mail.*;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import java.util.Properties;
/**
* 发邮件工具类
*/
public final class MailUtils {
private static final String USER = " "; // 发件人称号,同邮箱地址
private static final String PASSWORD = " "; // 如果是qq邮箱可以使户端授权码,或者登录密码
/**
*
* @param to 收件人邮箱
* @param text 邮件正文
* @param title 标题
*/
/* 发送验证信息的邮件 */
public static boolean sendMail(String to, String text, String title){
try {
final Properties props = new Properties();
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.host", "smtp.qq.com");
// 发件人的账号
props.put("mail.user", USER);
//发件人的密码
props.put("mail.password", PASSWORD);
// 构建授权信息,用于进行SMTP进行身份验证
Authenticator authenticator = new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
// 用户名、密码
String userName = props.getProperty("mail.user");
String password = props.getProperty("mail.password");
return new PasswordAuthentication(userName, password);
}
};
// 使用环境属性和授权信息,创建邮件会话
Session mailSession = Session.getInstance(props, authenticator);
// 创建邮件消息
MimeMessage message = new MimeMessage(mailSession);
// 设置发件人
String username = props.getProperty("mail.user");
InternetAddress form = new InternetAddress(username);
message.setFrom(form);
// 设置收件人
InternetAddress toAddress = new InternetAddress(to);
message.setRecipient(Message.RecipientType.TO, toAddress);
// 设置邮件标题
message.setSubject(title);
// 设置邮件的内容体
message.setContent(text, "text/html;charset=UTF-8");
// 发送邮件
Transport.send(message);
return true;
}catch (Exception e){
e.printStackTrace();
}
return false;
}
网友评论