音乐播放器javaweb项目近日总结,用js,css,HTML,servlet,mybatis来写注册登录忘记密码(还没写好)

本文主要是介绍音乐播放器javaweb项目近日总结,用js,css,HTML,servlet,mybatis来写注册登录忘记密码(还没写好),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这几天学了js,css,HTML,servlet,mybatis,还有axios,目前axios还没有用到,学的比较慢因为那个servlet,axios我看不懂,可能看懂了然后不会用,之后给我们上了一节课,感觉每一个东西单独拆开好像学过,但是放在一起听的很懵,今天我就到处翻博客反复看了点代码,终于知道了一点前后端交互就赶紧写了点。

因为是小白所以写的有些感觉没必要写的比较详细方便自己记忆

1.前端界面代码

html文件:(css,和js就省略了)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>注册页面</title><link rel="stylesheet" href="RjLnFt.css">
</head>
<body>
<div class="container"><h1>注册</h1><form action="/register" method="POST"><div class="form-group"><label for="username">用户名</label><input type="text" id="username" name="username" placeholder="请输入用户名" required></div><div class="form-group"><label for="email">邮箱</label><input type="email" id="email" name="email" placeholder="请输入邮箱" required><ul><li id="EE">邮箱无效!</li></ul></div><div class="form-group"><label for="password">密码</label><input type="password" id="password" name="password" placeholder="请输入密码" required><ul><li id="length-tip">密码必须至少8位。</li><li id="letter-tip">密码必须包含字母。</li><li id="number-tip">密码必须包含数字。</li></ul></div><div class="form-group"><label for="verification-code">验证码</label><div class="input-group"><input type="text" id="verification-code" name="verification-code" placeholder="请输入验证码" required><button type="button">获取验证码</button></div></div><div class="form-group1"><button type="submit" class="submit-button">注册</button></div></form><p class="login-link">已有账号?<a href="SongLogin.html">登录</a></p>
</div>
<script src="fun.js"></script>
</body>
</html>

代码解释:

  • 使用了 <form> 标签,将所有表单元素包裹起来。
  • 设置了 action="/register",指定了表单提交的目标 URL。
  • 设置了 method="POST",指定了提交的 HTTP 方法。
  • 为每个输入字段添加 name 属性,以便在服务器端能够识别表单数据。

 action属性指定了表单数据提交到 /register URL,method属性指定了使用POST方法提交数据。

URL是指在web应用程序中定义的请求路径。

eg:(反射和注解通俗来讲就是 反射来找注解再找类)

我在web.xml中配置了一个Servlet映射,将/register路径映射到RegisterServlet,其中的/register就是URL,看代码:


<!--  配置Servlet--><servlet><servlet-name>RegisterServlet</servlet-name><servlet-class>com.example.servlet.RegisterServlet</servlet-class></servlet><servlet-mapping><servlet-name> RegisterServlet</servlet-name><url-pattern> /register</url-pattern></servlet-mapping>

2.后端代码

RegisterServlet需要处理 POST 请求,从请求中提取表单数据,并与数据库进行交互。

当用户通过 POST 方法向 /register 发送请求时 RegisterServletdoPost 方法将会被调用。


@WebServlet("/register") // 定义Servlet的URL映射
public class RegisterServlet extends HttpServlet {//这个是序列化机制的一部分,一般都写在这,不用很管他private static final long serialVersionUID = 1L;// 处理POST请求protected void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {// 获取表单提交的参数String username = request.getParameter("username");String password = request.getParameter("password");String email = request.getParameter("email");

从表单获取数据后,再加入数据库

3.加入数据库部分

我用的是mybatis

1.先配置环境:

<!--mybatis 依赖--><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.16</version></dependency><!--mysql 驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.46</version></dependency>

2.封装一个user类用来到时候用

直接将数据封装到user里面传过去,后续调用mapper

我下面的代码不全,而且也不是我写song项目的user只是学习mybatis测试用的


public class User {
//alt+鼠标左键可以列编辑private Integer id;private String username;private String password;private String gender;private String addr;public User() {}public Integer getId() {return id;}

3.写mapper部分

 这是一个接口,可以把操作数据库所有的方法都写在这里面,后面方便调用


public interface UserMapper {//查询所有List<User> selectAll();//根据id查询User selectById(int id);//条件查询//1散装参数:如果方法中有多个参数,需要使用@Param("SQL参数占位符名称")//2.对象参数:对象的属性名称要和参数占位符名称一致//3.map集合参数List<User> selectByCondition(@Param("username") String username,@Param("gender") String gender);List<User> selectByCondition(User user);List<User> selectByCondition(Map map);/*** 单条件动态查询* @param user* @return*/List<User> selectByConditionSingle(User user);/*** 添加*/void add(User user);/*** 修改*/int update(User user);/*** 根据id删除*/void deleteByid(int id);}

这是对应xml文件的sql语句:


<!--  添加--><insert id="add" useGeneratedKeys="true" keyProperty="id">insert into tb_user (username,password,gender,addr)values (#{username},#{password},#{gender},#{addr});</insert>

 

4.将数据加入数据库

然后表单加入的数据就可以调用这个法加入了

 //1.获取SqlSessionFactory//1.加载mybatis的核心配置文件,获取SqlSessionFaxtoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//2.获取SqlSession 对象,用它来执行sqlSqlSession sqlSession = sqlSessionFactory.openSession();//在这里面其实是可以写true或者false的没写为f表示要手动提交//3.1获取UserMapper接口的代理对象UserMapper userMapper = sqlSession.getMapper((UserMapper.class));userMapper.add(user2);//提交事务sqlSession.commit();//5.释放资源sqlSession.close();

这篇关于音乐播放器javaweb项目近日总结,用js,css,HTML,servlet,mybatis来写注册登录忘记密码(还没写好)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.