特地发表一篇博客来记录自己完成的第一个项目,在这里把我做项目期间的一些问题总结一下,整个项目大概耗时5天,废话不多说,切入正题。
项目内容大致分为以下几个部分
一、导入项目
打开IDEA,在右边点击Maven,导入travel这个maven的项目。
选择travel项目的pom.xml文件,点击ok,完成项目导入。需要等待一小会,项目初始化完成。
二、启动项目
你可以直接双击travel的插件下的“tomcat7:run”
也可以配置maven快捷键启动(推荐)
三、相关技术
3.1 Web层
Servlet:前端控制器
html:视图
Filter: 过滤器
BeanUtils:数据封装
Jackson:json序列化工具
3.2 Service层
javamail:java发送邮件工具
Redis:nosql的数据库
Jedis:java的redis客户端
3.3 Dao层
Mysql:数据库
Druid:数据库连接池
JedisTemplate:jdbc的工具
大概就是这个样子
原码的文件都放在对应的包下,无需改动
接下来需要打开你的数据库
四、创建数据库
-- 创建数据库
CREATE DATABASE travel;
-- 使用数据库
USE travel;
--创建表
复制提供好的sql,文件里面有,输入上面两条命令即可
创建好的travel就如上图所示
五、完成注册功能
5.1完成登记功能
功能分析
在后端和前端完成代码编辑
抓包查看
这个时候刷新数据库的travel_user表,会出现注册的用户信息
注册成功后,会弹出成功界面,接着往下做就好
5.2 初步启动时遇到的问题
1.在这里我提一下我遇到的问题,我完成注册功能的时候运行一开始报错,后来查看了原来是他给的文件中,加载的文件数据中,“druid.properties”的前面是不应有“/”的!这个错误挺劝退的
// 加载配置文件中的数据
InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
Properties pp = new Properties();
2.数据库版本过高问题
你需要在你的druid.properti文件改一下驱动,而且要注意的是!!!这个文件在target目录和resourses目录下都有,一定两个都要改!!!!
将源文件的“com.mysql.jdbc.Driver”加上“cj”
driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql:///travel
username=root
password=123
initialSize=5
maxActive=10
maxWait=3000
在这里我还要插一句,你连接数据库的时候一定要看看这个文件中的username和password是不是你本地数据库的,我的当时就没检查这个,结果一直连接不上,晕,一定要仔仔细细。而且一定要两个包里的文件都改。
3.java.sql.SQLIntegrityConstraintViolationException
我左思右想不知道这个错误错在哪了,后来查了说的是因为有一个唯一的键值重复了,可能是你插入了两条主键一样的数据,数据库里的主键是不能重复的
可能是我在注册的时候有的属性为“UQ”,但我测试的时候输入了一样的数据,晕
去数据库进行修改
将username的UQ(唯一属性)去掉勾勾,这是添加了重复username的就不再报错,或者你删掉之前存过得数据也行
六、邮件激活
分析
新用户需要完成邮件激活问题,打开MAILUtils.java,要在网易邮箱中和QQ邮箱中开启授权码功能,我以发件人使用qq邮箱为例,照着改:
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 = "XXXXXXXX@qq.com"; // 发件人称号,同邮箱地址
private static final String PASSWORD = "此处是qq邮箱的授权码"; // 如果是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;
}
public static void main(String[] args) throws Exception { // 做测试用
MailUtils.sendMail("此处输入网易邮箱地址","你好,这是一封测试邮件,无需回复。","测试邮件");
System.out.println("发送成功");
}
}
修改好后可以收到测试邮件,功能完成
点击链接,会生成激活码,like
此处就不放具体修改过程啦
打开邮件,点击链接
此时刷新数据库,状态码变成“Y”
七、登陆
点击登陆,成功跳转登陆页面
八、退出
登陆界面会出现“欢迎回来XX”,后面有退出,此项功能完成
九、将优化Servlet
减少Servlet的数量,现在是一个功能一个Servlet,将其优化为一个模块一个Servlet,相当于在数据库中一张表对应一个Servlet,在Servlet中提供不同的方法,完成用户的请求。
十、分类数据展示
分析
注意:这一步使用缓存优化的时候redis记得打开,否则报错,从缓存中查询比直接在数据库要快很多。
十一、分页展示
一步步优化,一开始展示页数,到页数上加突出显示,到分页完成,完成了首页和尾页的切换,还有上一页和下一页的切换。
完成旅游线路名称查询
十三、旅游线路详情展示
分析
十四、旅游线路收藏
分析
完成收藏功能,并显示收藏次数
至此实现了项目的所有的功能
get!!