网络安全作业三


<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>用户登录</title><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"><style>body {font-family: 'Arial', sans-serif;background-color: #f0f2f5;display: flex;justify-content: center;align-items: center;min-height: 100vh;margin: 0;padding: 20px;}.login-container {background-color: white;padding: 2rem;border-radius: 8px;box-shadow: 0 2px 15px rgba(0, 0, 0, 0.1);width: 100%;max-width: 350px;transition: transform 0.2s ease;}.login-container:hover {transform: translateY(-3px);}.login-title {text-align: center;color: #1a73e8;margin-bottom: 1.5rem;padding-bottom: 0.8rem;border-bottom: 2px solid #1a73e8;}.form-group {margin-bottom: 1.2rem;position: relative;}label {display: block;margin-bottom: 0.5rem;color: #5f6368;}.input-wrapper {position: relative;}input {width: 100%;padding: 0.8rem 0.8rem 0.8rem 2.5rem;border: 1px solid #dadce0;border-radius: 4px;box-sizing: border-box;font-size: 1rem;transition: all 0.2s;}.input-icon {position: absolute;left: 0.8rem;top: 50%;transform: translateY(-50%);color: #86909C;}input:focus {outline: none;border-color: #1a73e8;box-shadow: 0 0 0 2px rgba(26, 115, 232, 0.2);}.login-btn {width: 100%;padding: 0.8rem;background-color: #1a73e8;color: white;border: none;border-radius: 4px;font-size: 1rem;font-weight: 500;cursor: pointer;transition: background-color 0.2s;display: flex;justify-content: center;align-items: center;gap: 8px;}.login-btn:hover {background-color: #1557b0;}.login-btn.loading {background-color: #69b1ff;cursor: wait;}.spinner {display: none;width: 16px;height: 16px;border: 2px solid rgba(255, 255, 255, 0.3);border-radius: 50%;border-top-color: white;animation: spin 1s linear infinite;}@keyframes spin {to { transform: rotate(360deg); }}.login-btn.loading .spinner {display: inline-block;}.error-message {color: #d93025;text-align: center;margin: 1rem 0;padding: 0.6rem;background-color: #fff8f8;border-radius: 4px;display: none;border: 1px solid #ffebee;}.form-options {display: flex;justify-content: space-between;align-items: center;margin: 1rem 0;font-size: 0.9rem;}.remember-me {display: flex;align-items: center;gap: 5px;cursor: pointer;}.remember-me input {width: auto;padding: 0;}.forgot-link {color: #1a73e8;text-decoration: none;}.forgot-link:hover {text-decoration: underline;}</style>
</head>
<body><div class="login-container"><h2 class="login-title">账户登录</h2><form id="loginForm"><div class="form-group"><label for="username">用户名</label><div class="input-wrapper"><i class="fas fa-user input-icon"></i><input type="text" id="username" name="username" required></div></div><div class="form-group"><label for="password">密码</label><div class="input-wrapper"><i class="fas fa-lock input-icon"></i><input type="password" id="password" name="password" required></div></div><div class="form-options"><label class="remember-me"><input type="checkbox" id="rememberMe"> 记住我</label><a href="#" class="forgot-link">忘记密码?</a></div><button type="submit" class="login-btn"><span>登录</span><span class="spinner"></span></button><div class="error-message" id="errorMsg">用户名或密码错误</div></form></div><script>// 获取表单元素const loginForm = document.getElementById('loginForm');const usernameInput = document.getElementById('username');const passwordInput = document.getElementById('password');const rememberMe = document.getElementById('rememberMe');const errorMsg = document.getElementById('errorMsg');const loginBtn = document.querySelector('.login-btn');// 页面加载时检查记住的用户名document.addEventListener('DOMContentLoaded', () => {const savedUser = localStorage.getItem('savedUsername');if (savedUser) {usernameInput.value = savedUser;rememberMe.checked = true;}});// 表单提交事件loginForm.addEventListener('submit', async function(e) {e.preventDefault();const username = usernameInput.value.trim();const password = passwordInput.value.trim();// 简单验证if (!username) {showError('请输入用户名');return;}if (!password) {showError('请输入密码');return;}// 显示加载状态loginBtn.classList.add('loading');loginBtn.disabled = true;hideError();try {// 模拟网络请求延迟await new Promise(resolve => setTimeout(resolve, 800));// 验证逻辑if (username === 'admin' && password === '123456') {// 记住用户名if (rememberMe.checked) {localStorage.setItem('savedUsername', username);} else {localStorage.removeItem('savedUsername');}alert('登录成功!');// 实际应用中使用: window.location.href = '首页地址';} else {showError('用户名或密码错误');passwordInput.value = '';}} finally {// 恢复按钮状态loginBtn.classList.remove('loading');loginBtn.disabled = false;}});// 错误提示控制function showError(message) {errorMsg.textContent = message;errorMsg.style.display = 'block';// 3秒后自动隐藏setTimeout(hideError, 3000);}function hideError() {errorMsg.style.display = 'none';}// 输入框获得焦点时隐藏错误信息[usernameInput, passwordInput].forEach(input => {input.addEventListener('focus', hideError);});</script>
</body>
</html>

基础文档标签

  1. <!DOCTYPE html>
    声明文档类型为HTML5,告知浏览器使用HTML5标准解析页面,确保正确渲染新特性。

  2. <html lang="zh-CN">
    HTML文档的根元素,lang="zh-CN"指定页面主要语言为简体中文,有助于对搜索引擎优化和辅助技术(如屏幕阅读器)有重要意义。

  3. <head>
    包含页面的元数据,这些信息不直接显示在页面上,但对浏览器和搜索引擎至关重要。

  4. <meta charset="UTF-8">
    指定页面字符编码为UTF-8,支持包括中文在内的全球大多数语言字符,避免乱码问题。

  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
    用于响应式设计,width=device-width使页面宽度与设备屏幕宽度一致,initial-scale=1.0设置初始缩放比例为1,确保移动设备上显示正常。

  6. <title>用户登录</title>
    定义页面标题,显示在浏览器标签页上,也用于书签和搜索引擎结果展示。

  7. <link rel="stylesheet" href="...">
    引入外部资源,这里用于加载Font Awesome图标库,提供表单中使用的用户图标(fa-user)和锁图标(fa-lock)。

  8. <style>
    内嵌CSS样式块,用于定义页面元素的布局、颜色、字体等视觉样式,使页面更美观。

  9. <body>
    包含页面所有可见内容,如登录表单、按钮、文本等,是用户直接交互的区域。

页面内容标签

  1. <div class="login-container">
    通用容器元素,class="login-container"用于通过CSS设置登录框的整体样式(如背景、边框、阴影等),将相关元素分组便于布局管理。

  2. <h2 class="login-title">账户登录</h2>
    二级标题标签,用于显示页面主标题,class="login-title"用于设置标题的样式(如颜色、边框等)。

  3. <form id="loginForm">
    表单容器,用于收集用户输入信息。id="loginForm"便于JavaScript通过ID获取表单元素,进而处理提交事件。

  4. <div class="form-group">
    表单分组容器,class="form-group"用于对表单中的输入项(如用户名、密码)进行分组,设置统一的间距和布局。

  5. <label for="username">用户名</label>
    表单标签,for="username"id="username"的输入框关联,点击标签时会自动聚焦到对应的输入框,提升可用性。

  6. <div class="input-wrapper">
    输入框容器,用于包裹输入框和图标,通过CSS定位实现图标在输入框内的效果。

  7. <i class="fas fa-user input-icon"></i>
    Font Awesome图标元素,fas fa-user表示用户图标,input-icon用于设置图标在输入框内的位置样式,增强视觉引导。

  8. <input> 输入框系列:

    • type="text":文本输入框,用于输入用户名,内容可见。
    • type="password":密码输入框,输入内容会被隐藏(显示为圆点或星号)。
    • type="checkbox":复选框,用于"记住我"功能,id="rememberMe"与对应标签关联。
    • id属性:唯一标识输入框,用于关联标签和JavaScript操作。
    • required属性:指定输入框为必填项,表单提交时若未填写会触发浏览器默认验证提示。
  9. <a href="#" class="forgot-link">忘记密码?</a>
    超链接元素,href="#"为临时链接占位符,class="forgot-link"设置链接样式,用于跳转至密码找回页面。

  10. <button type="submit" class="login-btn">
    提交按钮,type="submit"表示点击时会触发表单的提交事件,class="login-btn"设置按钮样式,内部包含"登录"文本和加载状态的spinner元素。

  11. <span class="spinner"></span>
    加载状态指示器,通过CSS动画实现旋转效果,登录过程中显示,提示用户操作正在处理。

  12. <div class="error-message" id="errorMsg">
    错误信息容器,id="errorMsg"用于JavaScript控制显示/隐藏,class="error-message"设置错误提示的样式(如红色文字、浅色背景)。

JavaScript相关元素

  1. <script>
    包含JavaScript代码,用于实现页面交互逻辑,如表单验证、登录状态处理、错误提示控制等。

  2. 核心JavaScript逻辑涉及的元素操作:

    • 通过document.getElementById()获取表单、输入框、按钮等元素。
    • 使用addEventListener('submit', ...)监听表单提交事件。
    • e.preventDefault()阻止表单默认提交行为(避免页面刷新)。
    • 通过localStorage实现"记住我"功能,保存/读取用户名。
    • 控制errorMsg元素的显示/隐藏,展示不同的错误提示。
    • 切换按钮的loading类,显示/隐藏加载状态。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/915941.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/915941.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入理解 ThreadLocal:从原理到最佳实践

&#x1f4dd; 前言&#xff1a;为什么你需要了解 ThreadLocal&#xff1f;在多线程并发编程中&#xff0c;线程安全始终是一个绕不开的话题。我们常常需要为每个线程维护一份独立的上下文数据&#xff0c;例如用户信息、事务 ID、日志追踪 ID 等。这些数据不能被多个线程共享&…

AD一张原理图分成多张原理图

先选中你要作为主级原理图的那张原理图&#xff0c;我这里是Sheet1,点击设计&#xff08;D&#xff09;&#xff0c;再点击create sheet symbol from sheet&#xff08;这个不能选错&#xff09;快捷键&#xff1a;DY弹窗中选择要加入的次级原理图左击鼠标放置重复上面的动作&a…

AI大模型资源

网址 https://sass.kupepoem.cn/ 登录-选择模型 打开上述网址后如下操作&#xff1a; 进入后&#xff0c;所有模型均可使用&#xff1a; o4-mini&#xff08;支持Deep Research深入研究&#xff09; 选择o4-mini模型 选择深度研究 要研究什么&#xff0c;对话直接输入即可。…

论文阅读--《Besting the Black-Box: Barrier Zones for Adversarial Example Defense》

好的&#xff0c;这是《Besting the Black-Box: Barrier Zones for Adversarial Example Defense》论文的中文翻译&#xff1a;[文件名称]: Besting_the_Black-Box_Barrier_Zones_for_Adversarial_Example_Defense.pdf [文件内容开始]第 1 页 收稿日期&#xff1a;2021年10月1…

如何保证GPFS文件系统的强一致性

一、底层机制&#xff1a;分布式锁与元数据管理GPFS 通过分布式锁和集中式元数据管理的结合&#xff0c;确保数据和元数据的一致性&#xff1a;集中式元数据服务器&#xff08;MDS&#xff09;GPFS 采用主从架构的元数据管理&#xff0c;由指定节点&#xff08;或集群&#xff…

使用Docker+Nginx部署电商平台项目(服务端+管理端+商城)

1.项目背景&#xff1a; 本项目作为小商场系统&#xff0c;涵盖内容如下&#xff1a; litemall Spring Boot后端 Vue管理员前端 微信小程序用户前端 Vue用户移动端 1.1项目架构&#xff1a; 1.2项目技术栈&#xff1a; 本项目可以使用window运行jar包本地部署&#xff0c…

Java网络编程入门:从基础原理到实践(二)

目录 1. 网络编程基础&#xff1a;搞懂设备通信的底层逻辑 1.1 为啥需要网络编程&#xff1f;—— 让设备 “互通有无” 1.2 什么是网络编程&#xff1f;—— 给数据 “定规矩、找路线” 1.3 网络编程的基本概念&#xff1a;理清通信里的角色和流程 1.3.1 发送端和接收端 …

XSS内容分享

反射型XSS &#xff1a;反射型XSS 是非持久性、参数型的跨站脚本。反射型XSS 的JS 代码在Web 应用的参数&#xff08;变量&#xff09;中&#xff0c;如搜索框的反射型XSS。在搜索框中&#xff0c;提交PoC[scriptalert(/xss/)/script]&#xff0c;点击搜索&#xff0c;即可触发…

电线杆距离居民区的安全距离【重要!!!】

10kV架空电线安全距离购房指南 中国大陆地区10kV架空电线距居民住宅需要满足1.5米水平安全距离&#xff08;裸导线&#xff09;和6.5米垂直安全距离的国家强制标准。根据现行法规&#xff0c;10kV系统的电磁辐射水平极低&#xff0c;对居民健康影响可忽略不计&#xff0c;但购房…

河南萌新联赛2025第(二)场:河南农业大学

我看到花儿在绽放 我听到鸟儿在歌唱 我看到人们匆匆忙忙 我看到云朵在天上 我听到小河在流淌 我看到人们漫步在路上 河南萌新联赛2025第&#xff08;二&#xff09;场&#xff1a;河南农业大学 河南萌新联赛2025第&#xff08;二&#xff09;场&#xff1a;河南农业大学_ACM/N…

unixbench系统性能测试

unixbench系统性能测试 环境&#xff1a; UnixBench: 6.0.0(2025-05-21)简介 UnixBench 是一款经典的 Unix/Linux 系统性能测试工具&#xff0c;主要用于评估系统的CPU 运算能力、内存性能、多线程处理能力以及部分系统调用&#xff08;如进程创建、文件操作&#xff09;的效率…

上线了,自己开发的刷题小程序,vue3.0

嘿&#xff0c;最近我搞了个Java刷题的小程序&#xff0c;用Vue写的&#xff0c;界面和功能都还挺完整的。今天就来跟大家聊聊这个小程序是怎么实现的&#xff0c;代码里都藏着哪些小细节。 先看整体结构&#xff0c;我把整个页面分成了几个大块&#xff1a;顶部导航栏、题目内…

嵌入式开发学习———Linux环境下数据结构学习(三)

单向循环链表单向循环链表是一种特殊的单向链表&#xff0c;尾节点的指针指向头节点&#xff0c;形成一个闭环。适用于需要循环访问的场景&#xff0c;如轮询调度。结构特点&#xff1a;每个节点包含数据域和指向下一个节点的指针&#xff0c;尾节点的指针指向头节点而非空值。…

【华为机试】684. 冗余连接

文章目录684. 冗余连接描述示例 1示例 2提示解题思路核心分析问题转化算法选择策略1. 并查集 (Union-Find) - 推荐2. 深度优先搜索 (DFS)3. 拓扑排序算法实现详解方法一&#xff1a;并查集 (Union-Find)方法二&#xff1a;深度优先搜索 (DFS)数学证明并查集算法正确性证明时间复…

Ⅹ—6.计算机二级综合题7---10套

目录 第7套 【填空题】 【修改题】 【设计题】 第8套 【填空题】 【修改题】 【设计题】 第9套 【填空题】 【修改题】 【设计题】 第10套 【填空题】 【修改题】 【设计题】 第7套 【填空题】 题目要求:给定程序中,函数fun的功能是:将形参s所指字符串中所…

【三桥君】大语言模型计算成本高,MoE如何有效降低成本?

​ 你好&#xff0c;我是 ✨三桥君✨ &#x1f4cc;本文介绍&#x1f4cc; >> 一、引言 在AI技术飞速发展的当下&#xff0c;大语言模型&#xff08;LLM&#xff09;的参数规模不断增长&#xff0c;但随之而来的计算成本问题也日益凸显。如何在保持高效推理能力的同时扩…

Python游戏开发利器:Pygame从入门到实战全解析

引言 Pygame是Python中最受欢迎的2D游戏开发库之一&#xff0c;基于SDL&#xff08;Simple DirectMedia Layer&#xff09;构建&#xff0c;支持图形渲染、音效处理、事件响应等核心功能。无论是开发简单的休闲游戏&#xff0c;还是复杂的交互式应用&#xff0c;Pygame都能提供…

行为型模式-协作与交互机制

行为型模式聚焦于对象间的行为交互&#xff0c;通过规范对象协作方式提升系统的灵活性与可扩展性。在分布式系统中&#xff0c;由于多节点异步通信、网络不可靠性及状态一致性挑战&#xff0c;行为型模式需针对分布式特性进行适应性设计。本文从观察者、策略、命令、责任链、状…

spring boot 整合 Spring Cloud、Kafka 和 MyBatis菜鸟教程

环境准备确保项目中已引入 Spring Boot、Spring Cloud、Kafka 和 MyBatis 的依赖。以下是一个典型的 Maven 依赖配置&#xff1a;<dependencies><!-- Spring Boot Starter --><dependency><groupId>org.springframework.boot</groupId><artif…

20 BTLO 蓝队靶场 Sticky Situation 解题记录

难度&#xff1a;5/10考察技能: Windows admin, Autopsy 使用场景&#xff1a;分析USB设备使用情况Autopsy使用注意&#xff1a;用管理员打开&#xff0c;在实际分析时注意先复制一个镜像文件&#xff0c;保存好原文件常用的Windows USB 取证的位置:Windows XP:Registry Key: U…