Java Web 网络商城案例演示一、(环境搭建)

) ;

– 5 创建订单项表

CREATE TABLE orderitem (

itemid varchar(32) NOT NULL,

quantity int(11) DEFAULT NULL, #购买数量

total double DEFAULT NULL, #小计

pid varchar(32) DEFAULT NULL, #购买商品的id

oid varchar(32) DEFAULT NULL, #订单项所在订单id

PRIMARY KEY (itemid),

KEY order_item_fk_0001 (pid),

KEY order_item_fk_0002 (oid),

CONSTRAINT order_item_fk_0001 FOREIGN KEY (pid) REFERENCES product (pid),

CONSTRAINT order_item_fk_0002 FOREIGN KEY (oid) REFERENCES orders (oid)

) ;

二、环境搭建


在这里插入图片描述

创建目录结构

在这里插入图片描述

导入架包

在这里插入图片描述

3、工具类的构建

在这里插入图片描述

package cn.itzheng.store.utils;

import javax.servlet.http.Cookie;

public class CookUtils {

/**

  • 通过名称在cookie数组获取指定的cookie

  • @param name cookie名称

  • @param cookies cookie数组

  • @return

*/

public static Cookie getCookieByName(String name, Cookie[] cookies) {

if(cookies!=null){

for (Cookie c : cookies) {

//通过名称获取

if(name.equals(c.getName())){

//返回

return c;

}

}

}

return null;

}

}

package cn.itzheng.store.utils;

import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

import javax.sql.DataSource;

import com.mchange.v2.c3p0.ComboPooledDataSource;

public class JDBCUtils {

private static ComboPooledDataSource ds = new ComboPooledDataSource();

private static ThreadLocal tl=new ThreadLocal<>();

/**

  • 从线程中获取连接

  • @return

  • @throws SQLException

*/

public static Connection getConnection() throws SQLException {

//从线程中获取conneciton

Connection conn = tl.get();

if(conn==null){

conn=ds.getConnection();

//和当前线程绑定

tl.set(conn);

}

return conn;

}

// 获取数据源

public static DataSource getDataSource() {

return ds;

}

// 释放资源

public static void closeResource( Statement st, ResultSet rs) {

closeResultSet(rs);

closeStatement(st);

}

// 释放资源

public static void closeResource(Connection conn, Statement st, ResultSet rs) {

closeResource(st, rs);

closeConn(conn);

}

// 释放 connection

public static void closeConn(Connection conn) {

if (conn != null) {

try {

conn.close();

//和线程解绑

tl.remove();

} catch (SQLException e) {

e.printStackTrace();

}

conn = null;

}

}

// 释放 statement ctrl + shift + f 格式化代码

public static void closeStatement(Statement st) {

if (st != null) {

try {

st.close();

} catch (SQLException e) {

e.printStackTrace();

}

st = null;

}

}

// 释放结果集

public static void closeResultSet(ResultSet rs) {

if (rs != null) {

try {

rs.close();

} catch (SQLException e) {

e.printStackTrace();

}

rs = null;

}

}

//开启事务

public static void startTransaction() throws SQLException{

getConnection().setAutoCommit(false);

}

/**

  • 事务提交且释放连接

*/

public static void commitAndClose(){

Connection conn = null;

try {

conn=getConnection();

//事务提交

conn.commit();

//关闭资源

conn.close();

//解除版定

tl.remove();

} catch (SQLException e) {

e.printStackTrace();

}

}

/**

  • 事务回滚且释放资源

*/

public static void rollbackAndClose(){

Connection conn = null;

try {

conn=getConnection();

//事务回滚

conn.rollback();

//关闭资源

conn.close();

//解除版定

tl.remove();

} catch (SQLException e) {

e.printStackTrace();

}

}

public static void main(String[] args) throws SQLException {

System.out.println(getConnection().toString());

}

}

package cn.itzheng.store.utils;

import java.util.Properties;

import javax.mail.Authenticator;

import javax.mail.Message;

import javax.mail.MessagingException;

import javax.mail.PasswordAuthentication;

import javax.mail.Session;

import javax.mail.Transport;

import javax.mail.internet.AddressException;

import javax.mail.internet.InternetAddress;

import javax.mail.internet.MimeMessage;

import javax.mail.internet.MimeMessage.RecipientType;

public class MailUtils {

public static void sendMail(String email, String emailMsg)

throws AddressException, MessagingException {

// 1.创建一个程序与邮件服务器会话对象 Session

Properties props = new Properties();

//设置发送的协议

//props.setProperty(“mail.transport.protocol”, “SMTP”);

//设置发送邮件的服务器

//props.setProperty(“mail.host”, “smtp.126.com”);

//props.setProperty(“mail.smtp.auth”, “true”);// 指定验证为true

// 创建验证器

Authenticator auth = new Authenticator() {

public PasswordAuthentication getPasswordAuthentication() {

//设置发送人的帐号和密码

return new PasswordAuthentication(“admin”, “admin@store.com”);

}

};

Session session = Session.getInstance(props, auth);

// 2.创建一个Message,它相当于是邮件内容

Message message = new MimeMessage(session);

//设置发送者

message.setFrom(new InternetAddress(“admin@store.com”));

//设置发送方式与接收者

message.setRecipient(RecipientType.TO, new InternetAddress(email));

//设置邮件主题

message.setSubject(“用户激活”);

// message.setText(“这是一封激活邮件,请点击”);

String url=“http://localhost:8080/MyTomcat/UserServlet?method=active&code=”+emailMsg;

String content=“

来自购物天堂的激活邮件!激活请点击以下链接!

”+url+“

”;

//设置邮件内容

message.setContent(content, “text/html;charset=utf-8”);

// 3.创建 Transport用于将邮件发送

Transport.send(message);

}

public static void main(String[] args) throws AddressException, MessagingException {

MailUtils.sendMail(“aaa@store.com”, “abcdefg”);

}

}

package cn.itzheng.store.utils;

import java.math.BigInteger;

import java.security.MessageDigest;

import java.security.NoSuchAlgorithmException;

public class MD5Utils {

/**

  • 使用md5的算法进行加密

*/

public static String md5(String plainText) {

byte[] secretBytes = null;

try {

secretBytes = MessageDigest.getInstance(“md5”).digest(

plainText.getBytes());

} catch (NoSuchAlgorithmException e) {

throw new RuntimeException(“没有md5这个算法!”);

}

String md5code = new BigInteger(1, secretBytes).toString(16);// 16进制数字

// 如果生成数字未满32位,需要前面补0

for (int i = 0; i < 32 - md5code.length(); i++) {

md5code = “0” + md5code;

}

return md5code;

}

}

package cn.itzheng.store.utils;

import java.util.Map;

import org.apache.commons.beanutils.BeanUtils;

import org.apache.commons.beanutils.ConvertUtils;

import org.apache.commons.beanutils.converters.DateConverter;

public class MyBeanUtils {

public static void populate(Object obj, Map<String, String[]> map) {

try {

// 由于BeanUtils将字符串"1992-3-3"向user对象的setBithday();方法传递参数有问题,手动向BeanUtils注册一个时间类型转换器

// 1_创建时间类型的转换器

DateConverter dt = new DateConverter();

// 2_设置转换的格式

dt.setPattern(“yyyy-MM-dd”);

// 3_注册转换器

ConvertUtils.register(dt, java.util.Date.class);

BeanUtils.populate(obj, map);

} catch (Exception e) {

throw new RuntimeException(e);

}

}

public static T populate(Class clazz, Map<String, String[]> map) {

try {

T obj=clazz.newInstance();

// 由于BeanUtils将字符串"1992-3-3"向user对象的setBithday();方法传递参数有问题,手动向BeanUtils注册一个时间类型转换器

// 1_创建时间类型的转换器

DateConverter dt = new DateConverter();

// 2_设置转换的格式

dt.setPattern(“yyyy-MM-dd”);

// 3_注册转换器

ConvertUtils.register(dt, java.util.Date.class);

BeanUtils.populate(obj, map);

return obj;

} catch (Exception e) {

throw new RuntimeException(e);

}

}

}

package cn.itzheng.store.utils;

import java.util.UUID;

public class UploadUtils {

/**

  • 获取随机名称

  • @param realName 真实名称

  • @return uuid

*/

public static String getUUIDName(String realName){

//realname 可能是 1.jpg 也可能是 1

//获取后缀名

int index = realName.lastIndexOf(“.”);

if(index==-1){

return UUID.randomUUID().toString().replace(“-”, “”).toUpperCase();

}else{

return UUID.randomUUID().toString().replace(“-”, “”).toUpperCase()+realName.substring(index);

}

}

/**

  • 获取文件真实名称

  • @param name

  • @return

*/

public static String getRealName(String name){

// c:/upload/1.jpg 1.jpg

//获取最后一个"/"

int index = name.lastIndexOf(“\”);

return name.substring(index+1);

}

/**

  • 获取文件目录

  • @param name 文件名称

  • @return 目录

*/

public static String getDir(String name){

int i = name.hashCode();

String hex = Integer.toHexString(i);

int j=hex.length();

for(int k=0;k<8-j;k++){

hex=“0”+hex;

}

return “/”+hex.charAt(0)+“/”+hex.charAt(1);

}

@SuppressWarnings(“unused”)

public static void main(String[] args) {

//String s=“G:\day17-基础加强\resource\1.jpg”;

String s=“1.jgp”;

String realName = getRealName(s);

//System.out.println(realName);

String uuidName = getUUIDName(realName);

//System.out.println(uuidName);

String dir = getDir(realName);

System.out.println(dir);

}

}

package cn.itzheng.store.utils;

import java.util.UUID;

public class UUIDUtils {

/**

  • 随机生成id

  • @return

*/

public static String getId() {

return UUID.randomUUID().toString().replace(“-”, “”).toUpperCase();

}

public static String getUUID64() {

return getId() + getId();

}

/**

  • 生成随机码

  • @return

*/

public static String getCode() {

return getId();

}

public static void main(String[] args) {

System.out.println(getId());

/*

  • String str = UUID.randomUUID().toString(); System.out.println(str);

*/

}

}

c3p0配置文件

com.mysql.jdbc.Driver

jdbc:mysql://localhost:3306/store_40

root

root

30000

30

10

30

100

10

200

10

1

0

com.mysql.jdbc.Driver

jdbc:mysql://localhost:3306/store_40

root

root

5

20

10

40

0

5

导入最后一个工具类解决编码乱码的问题,导入到filter

在这里插入图片描述

package cn.itzheng.store.web.filter;

import java.io.IOException;

import java.io.UnsupportedEncodingException;

import java.util.Map;

import javax.servlet.Filter;

import javax.servlet.FilterChain;

import javax.servlet.FilterConfig;

import javax.servlet.ServletException;

import javax.servlet.ServletRequest;

import javax.servlet.ServletResponse;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletRequestWrapper;

import javax.servlet.http.HttpServletResponse;

/**

  • 统一编码

  • @author Administrator

*/

public class EncodingFilter implements Filter {

@Override

public void init(FilterConfig filterConfig) throws ServletException {

// TODO Auto-generated method stub

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

正值金三银四招聘旺季,很多小伙伴都询问我有没有前端方面的面试题,特地整理出来赠送给大家!

资料领取方式:点击这里前往免费获取

  • 统一编码

  • @author Administrator

*/

public class EncodingFilter implements Filter {

@Override

public void init(FilterConfig filterConfig) throws ServletException {

// TODO Auto-generated method stub

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-9ZzLxx0h-1713497197451)]

[外链图片转存中…(img-s1SwLZDM-1713497197451)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

[外链图片转存中…(img-C4LlIxhN-1713497197451)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

[外链图片转存中…(img-f6o9wg8q-1713497197452)]

最后

正值金三银四招聘旺季,很多小伙伴都询问我有没有前端方面的面试题,特地整理出来赠送给大家!

资料领取方式:点击这里前往免费获取

前端资料图.PNG

  • 12
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值