热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ASP.Net实战项目之《图书商城》第一天

Asp.net终于学完了好久没有上传文章了因为这几天在做一项目《图书购物商城》第一次接触真正的项目有那么一点点的体会感觉每一个项目所用的技术点都是一样的不一样的是不同的项目有着不同

Asp.net终于学完了好久没有上传文章了因为这几天在做一项目《图书购物商城》第一次接触真正的项目有那么一点点的体会感觉每一个项目所用的技术点都是一样的不一样的是不同的项目有着不同的业务需求就拿我做的这个来说这个项目是一个图书商城模式基本和淘宝、京东类似在商品列表选择所要购买的商品 –>添加到购物车->下订单->模拟支付宝付款

这个项目我一共用了八天的时间来完成细节做的不是特别的好有大量的bug 我只是把这个项目中的精华部分实现了我计划用八篇文章分别来介绍一下这个项目(请各位大牛勿喷小弟第一次开发项目) 由于篇符有限我不可能将所有的源码上不上传我以介绍原理为主关键的技术点我会上传源码文中如果有不合适的或者错误的地方还请您支持以便我改进万分感谢!!!、

《图书购物商城》第一天

任务:

1. 完成开发环境的搭建

2. 开发完成“注册”界面

3. 用户注册成功以后发送提示邮件

具体实现过程

1. 首先就是要在数据库中搭建数据表

这个项目我所使用的数据库是

Microsoft SQL Server 2008 Express版本

开发环境使用的是 Microsoft Visual Studio 20100

在开发之前我使用“动软代码生成器”为项目数据库的每一张数据表生成了简单三层的DAL层代码和BLL层代码(使用的目的是为了提高开发进度使用的前提必须是熟练的手写三层)

底层搭建好以后就开始编写UI层

2. 开发“注册”页面

我使用的基本上都是非服务端控件应为使用服务端控件会生成一个名字叫做“__ViewState”的隐藏域(在博客前面的文章介绍过)这会使得页面非藏的庞大用户请求页面的时候非常的慢用户体验非常的不好所有我时候非服务端控件

3. 注册界面如下

技术点如下:

jQuary的使用、Ajax无刷新页面、验证码

注意在判断时候为了保险一定要前台后后台页面都要判断这样做的目的是防止用户在禁用浏览器的js以后出现错误

这里我要说一下验证码的原理:

先使用随机函数生成一个四位的数字(字母也可以)然后存放在一个定义好的Session中(注意这里必须放在Session因为之后的登陆要判断)

验证码是使用画图类System.Drawing.Graphics 将产生的随机数生成一张图片

4. 用户注册成功以后 发送提示邮件

技术点:

这里要准备一个管理员的邮箱给所有注册了的用户发送邮件

发送邮件源码:

// 发送邮件

Mail:用户注册的邮箱 UserName:用户注册的名字

protected void SendMail(string Mail, string UserName)

{

MailMessage mailMsg = new MailMessage();//两个类,别混了,要引入System.Net这个Assembly

mailMsg.From = new MailAddress("459338001@qq.com", "管理员:宋方舟");//源邮件地址 (发件人地址)

mailMsg.To.Add(new MailAddress(Mail, UserName));//目的邮件地址(收件人地址)。可以有多个收件人

mailMsg.Subject = "恭喜注册成功!";//发送邮件的标题

mailMsg.Body = "欢迎您成为我们的会员。。。;//发送邮件的内容

SmtpClient client = new SmtpClient("smtp.qq.com");//smtp.163.com,smtp.qq.com;指定发送邮件服务器(Smtp服务器,根据发件人所使用的邮箱进行配置)

client.Credentials = new NetworkCredential(MailUserName, MailPassWord);//指定发件人的邮箱的密码MailPassWord与用户名MailUserName (网站管理员。)

client.Send(mailMsg);// 发送

}


推荐阅读
  • 本指南详细介绍了在Linux环境中高效连接MySQL数据库的方法。用户可以通过安装并使用`mysql`客户端工具来实现本地连接,具体命令为:`mysql -u 用户名 -p 密码 -h 主机`。例如,使用管理员账户连接本地MySQL服务器的命令为:`mysql -u root -p pass`。此外,还提供了多种配置优化建议,以确保连接过程更加稳定和高效。 ... [详细]
  • 本文深入解析了通过JDBC实现ActiveMQ消息持久化的机制。JDBC能够将消息可靠地存储在多种关系型数据库中,如MySQL、SQL Server、Oracle和DB2等。采用JDBC持久化方式时,数据库会自动生成三个关键表:`activemq_msgs`、`activemq_lock`和`activemq_ACKS`,分别用于存储消息数据、锁定信息和确认状态。这种机制不仅提高了消息的可靠性,还增强了系统的可扩展性和容错能力。 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 触发器的稳态数量分析及其应用价值
    本文对数据库中的SQL触发器进行了稳态数量的详细分析,探讨了其在实际应用中的重要价值。通过研究触发器在不同场景下的表现,揭示了其在数据完整性和业务逻辑自动化方面的关键作用。此外,还介绍了如何在Ubuntu 22.04环境下配置和使用触发器,以及在Tomcat和SQLite等平台上的具体实现方法。 ... [详细]
  • Linux CentOS 7 安装PostgreSQL 9.5.17 (源码编译)
    近日需要将PostgreSQL数据库从Windows中迁移到Linux中,LinuxCentOS7安装PostgreSQL9.5.17安装过程特此记录。安装环境&#x ... [详细]
  • 本文介绍了在 Spring Boot 中使用 JPA 进行数据删除操作时遇到的 SQL 错误及其解决方法。错误表现为:删除操作失败,原因是无法打开 JPA EntityManager 以进行事务处理。 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 如何在Java中使用DButils类
    这期内容当中小编将会给大家带来有关如何在Java中使用DButils类,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。D ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • MySQL的查询执行流程涉及多个关键组件,包括连接器、查询缓存、分析器和优化器。在服务层,连接器负责建立与客户端的连接,查询缓存用于存储和检索常用查询结果,以提高性能。分析器则解析SQL语句,生成语法树,而优化器负责选择最优的查询执行计划。这一流程确保了MySQL能够高效地处理各种复杂的查询请求。 ... [详细]
  • 本文对SQL Server系统进行了基本概述,并深入解析了其核心功能。SQL Server不仅提供了强大的数据存储和管理能力,还支持复杂的查询操作和事务处理。通过MyEclipse、SQL Server和Tomcat的集成开发环境,可以高效地构建银行转账系统。在实现过程中,需要确保表单参数与后台代码中的属性值一致,同时在Servlet中处理用户登录验证,以确保系统的安全性和可靠性。 ... [详细]
  • 深入探索HTTP协议的学习与实践
    在初次访问某个网站时,由于本地没有缓存,服务器会返回一个200状态码的响应,并在响应头中设置Etag和Last-Modified等缓存控制字段。这些字段用于后续请求时验证资源是否已更新,从而提高页面加载速度和减少带宽消耗。本文将深入探讨HTTP缓存机制及其在实际应用中的优化策略,帮助读者更好地理解和运用HTTP协议。 ... [详细]
  • 本文探讨了如何在C#应用程序中通过选择ComboBox项从MySQL数据库中检索数据值。具体介绍了在事件处理方法 `comboBox2_SelectedIndexChanged` 中可能出现的常见错误,并提供了详细的解决方案和优化建议,以确保数据能够正确且高效地从数据库中读取并显示在界面上。此外,还讨论了连接字符串的配置、SQL查询语句的编写以及异常处理的最佳实践,帮助开发者避免常见的陷阱并提高代码的健壮性。 ... [详细]
author-avatar
mobiledu2502871653
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有