## 1. Web应用开发概述 ### 1.1 Web开发的基本概念 (了解) #### 1.1.1 什么是Web应用? > Web App 是基于 Web 技术开发的应用程序,用户可以通过浏览器访问和使用,而无需下载和安装。Web App 可以在不同的设备和平台上运行,无需针对不同的操作系统进行开发和维护,具有较好的跨平台兼容性。Web App 通常使用 HTML、CSS、JavaScript 等 Web 技术进行开发,可以访问互联网上的各种资源和服务。 #### 1.1.2 Web App 的优点 - **跨平台兼容性好:** Web App 可以在不同的设备和平台上运行,无需针对不同的操作系统进行开发和维护,具有较好的跨平台兼容性。 - **开发成本低:** Web App 的开发成本相对较低,因为无需针对不同的操作系统进行开发和维护,可以使用 Web 技术进行开发。 - **维护成本低:** Web App 的维护成本相对较低,因为可以在服务器端进行维护和更新,无需对每个设备进行更新。 - **更新和发布灵活:** Web App 的更新和发布较为灵活,可以通过 Web 服务器进行发布和更新,无需通过应用商店进行审核和等待。 - **无需下载和安装:** Web App 可以通过浏览器直接访问和使用,无需下载和安装,使用较为方便。 - **易于扩展和集成:** Web App 可以轻松地集成和扩展各种 Web 服务和 API,例如社交网络、在线支付、地图服务等。 #### 1.1.3 Web App 的缺点 - **性能和用户体验相对较差:** Web App 受限于浏览器的性能和功能,因此性能和用户体验相对较差,特别是在移动设备上。 - **依赖网络连接:** Web App 需要依赖网络连接进行访问和使用,如果网络连接不稳定或者断开,用户无法继续使用应用程序。 - **难以实现离线体验:** Web App 难以实现离线体验,因为需要依赖网络连接进行访问和使用。 - **安全性和隐私保护问题:** Web App 可能存在安全性和隐私保护问题,因为需要使用网络进行数据传输和处理。 - **受限于浏览器:** Web App 受限于浏览器的功能和规范,因此开发者需要考虑浏览器的兼容性和规范。 #### 1.1.4 web应用工作流 ![](./resources/web-flow.png) ### 1.2 Web开发技术发展历史及趋势 #### 1.2.1 Web技术发展历程 - **参考资料:** - [五分钟了解互联网Web技术发展史](https://cloud.tencent.com/developer/article/1808394) - [Web开发技术发展历史](https://www.cnblogs.com/datapool/p/6218105.html) #### 1.2.2 当前Web开发的主要技术栈 - **前端技术栈:** - **HTML5:** 提供了更丰富和语义化的标记,增强了多媒体支持。 - **CSS3:** 支持更复杂的样式和动画效果,提高网页美观度。 - **JavaScript:** 用于增加交互性和动态功能。 - **TypeScript:** JavaScript的超集,提供了静态类型检查和面向对象编程特性,有助于构建大型应用程序。 - **前端构建工具:** 如Webpack、Gulp等,用于自动化前端开发流程,包括编译、压缩、测试等。 - **前端框架/库:** React、Vue 和 Angular 是最流行的框架,它们提供了一套完整的解决方案来构建用户界面。 - **后端技术栈:** - **Java:** 广泛应用于企业级应用开发,Spring Boot 和 Spring Cloud 是流行的微服务架构框架。 - **Python:** 常用于数据处理和科学计算领域,Django 和 Flask 是常用的Web框架。 - **Node.js:** 用于构建高性能的实时应用,Express 是一个流行的服务器框架。 - **.Net:** Microsoft的.NET Framework 和 .NET Core 提供了一个强大的平台来构建高性能Web应用和服务。 - **RESTful API设计:** 提供了一种标准的方式来设计和实现API。 - **数据库技术:** - **关系型数据库:** 如MySQL、PostgreSQL等,适用于复杂查询和事务处理。 - **NoSQL数据库:** 如MongoDB、Redis等,适用于大数据量和高并发场景。 - **云数据库服务:** 如Amazon RDS、Google Cloud SQL等,提供托管式的数据库服务。 - **工具及服务软件:** - **服务器:** 例如 Apache、Nginx、Tomcat 等。 - **代码编辑器:** 例如 IntelliJ IDEA、Eclipse、VS Code 等。 - **调试工具:** 例如 Chrome DevTools、Firebug 等。 - **版本控制工具:** 例如 Git、SVN 等。 #### 1.2.3 未来的Web开发技术趋势预测 - **持续集成与部署(CI/CD):** 更加自动化的工作流程将会成为常态,以提高开发效率和软件质量。 - **微服务架构:** 微服务将继续流行,因为它提高了系统的可扩展性和可维护性。 - **容器化技术:** Docker 和 Kubernetes 等技术将更加普及,用于部署和管理应用。 - **无服务器架构(Serverless):** 减少运维负担,专注于业务逻辑的编写。 - **人工智能和机器学习:** AI 和 ML 将被更广泛地应用于Web应用中,以增强用户体验和自动化后台任务。 - **隐私和安全:** 隐私保护技术和加密方法将成为开发过程中的重点。 ### 1.3 什么是Java Web开发?(了解) > Java Web开发是指使用Java语言来构建和维护可以在Web浏览器上运行的应用程序的过程。这些应用程序通常由服务器端组件和客户端组件组成,服务器端负责处理业务逻辑并提供数据给客户端,而客户端则负责显示数据并允许用户与之交互。 - **Java Web开发的主要组成部分** - **服务器端技术:** 包括Servlets、JSP (Java Server Pages)、JavaBeans、EJB (Enterprise JavaBeans)、Spring框架等。 - **客户端技术:** 主要是HTML、CSS和JavaScript,用于构建用户界面; 前端框架如Angular、React、Vue.js等。 - **中间件:** 如Servlet容器(例如Tomcat)、应用服务器(例如WildFly、GlassFish)等。 - **数据库技术:** 用于存储和检索数据,包括关系型数据库(如MySQL、PostgreSQL)和NoSQL数据库(如MongoDB、Redis)等。 - **Java Web应用的特点和优势** - **可移植性:** Java Web应用可以轻松地在不同的操作系统上运行,无需修改源代码。 - **平台无关性:** Java Web应用可以通过Java虚拟机(JVM)在任何支持Java的平台上运行。 - **安全性:** Java提供了强大的安全模型,包括沙箱机制、权限管理和加密支持。 - **强大的生态系统:** Java拥有庞大的开发者社区和丰富的开源库,这使得开发高质量的Web应用更加容易。 ### 1.4 开发环境搭建 (掌握) #### 1.4.1 IntelliJ IDEA - **IntelliJ IDEA的安装与配置** - 下载IntelliJ IDEA Community Edition或Ultimate Edition。 - 安装并设置JDK路径。 - 配置IDEA设置,如字体、颜色主题等。 - **创建Java Web项目** - 使用New Project向导选择Java Web模板。 - 设置项目名称、位置和模块结构。 - 添加必要的依赖,如Servlet API、Spring框架等。 - **配置项目依赖** - 使用Gradle或Maven作为构建工具。 - 添加外部库和框架依赖。 #### 1.4.2 Git/Gitee/Github的使用(重点掌握) > 参考 [git(ppt)](./resources/javaweb%20-week-01-git.pptx) > > 更多参考[菜鸟教程](https://www.runoob.com/git/git-tutorial.html) - **版本控制的概念** - 版本控制系统是一种记录文件和目录更改的软件,以便可以恢复旧版本。 - **Git的基本命令** - `git init`: 初始化一个新的本地仓库。 - `git clone`: 克隆一个远程仓库。 - `git add`: 将文件添加到暂存区。 - `git commit`: 提交更改到仓库。 - `git push`: 将本地更改推送到远程仓库。 - **Gitee/Github账号注册与仓库创建** - 注册账号并创建一个新的仓库。 - 设置仓库的描述、许可证和README文件。 - **项目初始化与提交** - 将本地文件添加到仓库并提交。 - 推送至远程仓库。 #### 1.4.3 Markdown的使用(掌握) > 参考 >> [Markdown语法](https://www.markdownguide.org/basic-syntax/) >> [Markdown 基本语法(中文)](https://markdown.com.cn/basic-syntax/) - **Markdown语法简介** - Markdown是一种轻量级的标记语言,用于编写易于阅读的纯文本格式文档。 - 基本语法包括标题、列表、链接、图像等。 - **使用Markdown编辑器** - 推荐使用IntelliJ IDEA、VS Code、Typora等编辑器。 - 集成实时预览功能,方便查看Markdown文档的效果。 - **文档编写与格式化** - 撰写清晰、简洁的文档,使用合适的标题层次结构。 - 插入代码片段、表格和其他元素以增强文档的可读性。 ### 1.4 项目开发流程简单介绍(了解) - **需求分析与设计** - **用户需求调研** - 与客户沟通明确项目目标。 - 收集用户故事和用例。 - **功能需求分析** - 分析用户故事,确定功能需求。 - 列出关键特性和功能。 - **架构设计与技术选型** - 设计系统的整体架构。 - 选择合适的技术栈和技术方案。 - **编码与调试** - **代码编写规范** - 遵循一致的命名规则和代码风格。 - 使用适当的注释。 - **单元测试与集成测试** - 编写单元测试以验证函数的正确性。 - 执行集成测试以确保不同组件之间协同工作。 - **调试技巧** - 使用断点和日志输出进行调试。 - 利用IDE的调试工具。 - **测试与发布** - **自动化测试工具** - 使用JUnit、TestNG等框架进行单元测试。 - 使用Selenium进行UI自动化测试。 - **部署流程** - 使用持续集成/持续部署(CI/CD)工具,如Jenkins、GitLab CI/CD。 - 配置自动构建、测试和部署管道。 - **监控与性能优化** - 使用工具如Prometheus、Grafana监控系统性能。 - 根据监控数据调整系统配置。 - **维护与升级** - **软件维护周期** - 定期检查和修复已知问题。 - 实施新功能和改进。 - **版本管理与发布策略** - 使用语义版本控制。 - 制定明确的发布计划和时间表。 - **用户反馈与迭代改进** - 收集用户反馈,评估用户体验。 - 根据反馈进行迭代改进。