網絡安全作業三


<!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
英文地址,請注明出處:http://en.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…