web音乐商城简陋版项目总结(sevlet+jsp+mysql)

2023-12-27 06:10

本文主要是介绍web音乐商城简陋版项目总结(sevlet+jsp+mysql),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这次的web项目是做一个音乐商城,目的是巩固下最近java ee学习的内容。
 有点头皮发麻,做一个响应式网站,完全不知道从何做起,开始的时候做servlet响应,就无脑一个请求对应一个servlet,并且这个sevlet内容,从获取请求到交互数据全在一个类中实现。
在这里插入图片描述

    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {Connection conn = null;Statement stmt = null;ResultSet rs = null;boolean loginsucess = false;String name = req.getParameter("uname");String password = req.getParameter("upass");System.out.println("用户名" + name + "密码" + password);System.out.println("获取成功");boolean exist = SqlUtil.SqlQUtilExist(name);System.out.println(exist);try {Class.forName("com.mysql.jdbc.Driver");//注册驱动} catch (ClassNotFoundException e) {e.printStackTrace();}try {conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/users", "root", "ChenBaifu137708.");} catch (SQLException e) {e.printStackTrace();}//获取连接try {assert conn != null;stmt = conn.createStatement();//获取数据库操作对象} catch (SQLException e) {e.printStackTrace();}String sql = "select password from accountinformation where id_name = '" + name + "' and password = '" + password + "'";try {assert stmt != null;stmt.execute(sql);} catch (SQLException e) {e.printStackTrace();}try {rs = stmt.executeQuery(sql);if (rs.next()) {loginsucess = true;}} catch (SQLException e) {e.printStackTrace();}System.out.println(loginsucess);if (loginsucess) {Cookie cok_name=new Cookie("id_name",name);Cookie cok_pass=new Cookie("password",password);cok_name.setMaxAge(60*60*24*7);cok_pass.setMaxAge(60*60*25*7);Customer customer = SqlUtil.SqlQUtil(name);HttpSession session = req.getSession();session.setAttribute("customer", customer);cok_name.setPath(req.getContextPath());cok_pass.setPath(req.getContextPath());resp.addCookie(cok_name);resp.addCookie(cok_pass);req.setAttribute("username", name);req.getRequestDispatcher("/login_Sucess.jsp").forward(req, resp);}if (!loginsucess) {req.setAttribute("username", name);req.getRequestDispatcher("/Login_Error.jsp").forward(req, resp);}try {stmt.close();conn.close();} catch (SQLException e) {e.printStackTrace();}}

反正我自己感觉挺离谱的,后面的时候,才知道,咦?原来可以封装工具类,原来可以把一个请求到响应的过程分好几层,既方便又清晰?emm,
随着项目的推进,慢慢找到前面写项目的离谱之处。
在这里插入图片描述
我也开始试着分层,也开始试着封装一些工具,虽然,开始的时候把dao层和工具类写到一块了,(不管是数据库增删改查还是注册驱动我都认为是工具类,被自己蠢哭了)
在这里插入图片描述
我写后台查询的时候才知道,诶原来过滤器是这么用的,写保存登陆状态的时候,诶cookie原来可以保存。

写支付宝沙箱支付的时候,知道了同步回调是重定向,别问,问就是
正是项目的训练才可以把各个板块的只是糅合到一块。
在这里插入图片描述
我一直还离谱的认为,是服务器内部的转发,直接就填的本地地址,我就说怎么同步回调有点问题。。。。。
本次分享到这里了,谢谢阅读

这篇关于web音乐商城简陋版项目总结(sevlet+jsp+mysql)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/542106

相关文章

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

SQL Server 查询数据库及数据文件大小的方法

《SQLServer查询数据库及数据文件大小的方法》文章介绍了查询数据库大小的SQL方法及存储过程实现,涵盖当前数据库、所有数据库的总大小及文件明细,本文结合实例代码给大家介绍的非常详细,感兴趣的... 目录1. 直接使用SQL1.1 查询当前数据库大小1.2 查询所有数据库的大小1.3 查询每个数据库的详

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

MySQL中REPLACE函数与语句举例详解

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函... 目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

MySQL 临时表与复制表操作全流程案例

《MySQL临时表与复制表操作全流程案例》本文介绍MySQL临时表与复制表的区别与使用,涵盖生命周期、存储机制、操作限制、创建方法及常见问题,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小... 目录一、mysql 临时表(一)核心特性拓展(二)操作全流程案例1. 复杂查询中的临时表应用2. 临时

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员