一引言1.1编写目的通过学习,深入了解电子商务系统的开发内容和运行过程。将所学的网络开发技术Asp.net2.0运用到企业项目中去,后台使用数据库sqlserver2005。电子商务的迅速发展为人们提供了更快捷方便的购物渠道。本文介绍了基于Asp.net2.0的网络购书管理系统,该系统采用Asp.net2.0技术,访问sqlserver2005数据库,实现了注册与登录、图书查找、选购图书、生成订单、用户管理、图书管理、订单管理和读者论谈等功能,顾客也可以通过系统所提供的分类查找来快速搜寻自己所想要找的书籍。本说明是对网上购书系统的各模块、页面、脚本分别进行了实现层面上的要求和说明。软件开发小组的产品实现成员应该阅读和参考本说明进行代码的编写、测试。1.2研究背景据最新统计,中国大陆已经注册的网上书店大约有100多家,有网站的有50多家,但已经投入运营能够买到书的只有十来家。最近据一家媒体的调查,能够买到书且服务到位的也只有大洋网、旌旗席殊等几家。很多人看到了书这种商品网上销售的诸多好处:方便购买、金额小、风险小、用户容易决定;讯息的完整性以及很少出现质量问题和退货现象等。尽管全球最大的网上书城亚马逊股票惨跌,尽管各家书店都承认目前的亏本经营状况,但这并未阻挡投资者对网上书店“钱”景的期待。最早的网上书店是由上海图书城投资50万元於1998年底成立的上海网上书城,该网站经理李列群坦言告诉记者,运营一年多,业绩很不理想,现在网上书城的交易额还不到整个上海图书城交易额的千分之一。据他分析,除了传统购书习惯的因素,频宽不够,上网的速度很慢,也影响了人们上网购书。由IDG、日本软银(Softbank和中国科文公司投资的当当一直号称是全球最大的网上中文书店,其市场总监阎光称当当每个月的访问量有7.5万人次,下单订购率为3%,交易额达12万元。阎光特别强调,在当当的顾客中,有20%来自海外。建立了配送网络的大洋网上书城成为华南中心城市广州的IT热点,从3月改版40多天,已有4万人注册为会员。书城目前拥有图书近5万种,并以每天200本的速度录入新书、充实旧书的内容,书城日销量突破500单,日成交额2.5-2.7万元。大洋网总裁董宝青说,大洋网网上书店在全国有优势,该店与全国150多家出版社合作,可保证售书7.5折不亏本;另外有150多连锁书店,配送队伍专业到位、服务到家,近期开通北京及珠三角主要城市的直接配送,建立网上书店是现有资源的自然延伸。但由於投资较大,网上书店真正盈利估计要在两年后。以目前的经营状况来看,绝大数网上书店都是亏本经营,最近又传来全球最大的网上书店亚马逊股票大跌的消息。不过行内人认为这是件好事,“是时候该挤挤网络的泡沫了。”在众多网上书店中,很多都是有国外VC的背景。大把烧钱,然后到Nasdaq上市成为网站是理想的经营方式。而旌旗席殊融资所得3000万元,在很多人眼里是个小数目,其经营者却认为对於现在来说已经够了。对于目前一些网上书店的花钱做秀法行内人士多持不赞赏态度,大洋网上书城负责人认为,自己的书城没有把主要精力放在做秀上,而是提倡务实精神,以读者为本,扎扎实实地为他们提供服务,收到的效果一样很好。“究竟谁是为了网民而做网络,谁是为了泡沫做网络,人们试一试就知道了。网上书店最终要归于现实。”1.3开发网上书店系统的意义电子商务模式是目前互联网人士思考较多的一个话题,在有了B-C,B-B等模式之后,一些网站最近又在尝试一种全新的概念——B-B-C模式,而且看来这一模式已经被许多的网上书店所接受。在解释B-B-C模式时,书生科技公司总裁王东临先生认为:“该模式的意思是中间的B直接面对客户,把订单交给第一个B来执行。这种模式看起来好象只是传统的渠道销售的翻版,在互联网时代根本不可行,因为互联网经济的一大特征就是压扁渠道,Amazon等大行其道的原因也正是基于这种“中间商死亡”的论调,他们抢占的正是原来中间商的利润。因此,B-B-C模式长期以来被认为是一种不可能成立的模式。其实,如果中间的B能够提供一种独特的服务,把消费者都吸引到它那里去,并通过它下订单,则该模式就是可行的。网上书店将致力于一个专业的售书平台,同时将B2C,与C2C融于一体,将Internet与Wap相结合,并提供独到的物流系统,以保证用户能够更快更节省的买到自己心仪的图书。1.4定义开发工具:MicrosoftVisualStudio2005开发语言:C#开发框架:ASP.NET2.0数据库:MicrosoftSQLServer2005DevelopmentEdition(或2000系统运行环境:Windowsserver2003、WindowsXPProfessionalEditionSP2、IIS6、.NetFramework2.01.5参考资料[1]李玉林、王岩著,ASP.NET2.0网络编程从入门到精通清华大学出版社2006.9[2]郝刚主编,袁永刚、严治国、何宇光著,ASP.NET2.0开发指南人民邮电出版、、2007.3[3]前沿科技曾顺编著精通Div+Css网页样式与布局人民邮电出版社2008.2二程序系统的结构2.1用例图2-1用例图2.2活动图(购书过程)2.2活动图(购书过程)三功能设计及业务流程3.1用户管理3-1用户管理3.2目录管理模块目录管理主要有门类管理、分类管理、商品管理、商品详情管理。其中门类管理、分类管理和商品管理有添加修改和删除功能,商品详情管理有商品详情修改功能。管理员可以创建门类,对过选择门类来创建分类,对过选择门类、分类,来创建商品目录。商品管理可以将商品关联到多个分类,也可以从某个分类中移除。3.2.1功能描述门类管理主要完成商品的一级分类,并对其进行添加、删除、修改等操作。3-2-1功能描述3.2.2目录管理的设计流程图3-2-2目录管理的设计流程图3.2.3删除目录流程图3-2-3删除目录流程图3.3商品管理模块商品管理模块实现对有关商品的所有功能,不要包括商品的搜索、获取指定目录下的商品及商品信息的增加、删除、修改等功能。3-3商品管理模块1.商品管理a添加商品b修改信息(包括分类关联)c删除商品2.商品详情管理3.4搜索搜索只有一种方式,搜索完成在名称搜索和时间搜索。3.5购物车系统提供两种购物车的实现,一种普通的购物车,一种AJAX购物车。使得用户可以多选择。用户通过点击添加商品到购物车,当用户下定单定时,用户的临时购物车就会与用户的账户关联,由于临时购物车也可以工作,因此即使在开发了顾客账户管理系统后,用户在结账之前仍然无需提供任何额外信息,如用户登录或者创建一个新的用户。目前或许保存购物车的最好方法可能是为每个购物车生成一个唯一的ID,采用全局唯一标识符(GUID)来实现,然后以cookie和session数据的形式保存在用户的计算机中,这种方法的好处是即使用户的浏览器是禁用cookie的,系统程序也能够基于session数据正常工作。3-5-1添加商品到购物车3-5-2管理购物车:用户直接添加,删除3.6订单管理订单管理模块实现对用户所下订单的管理。不要包括订单接收地址的设置、商品接收地走红的设置、订单的处理和猎取订单中的商品信息等功能。如图所示:3-6订单管理1实现定单系统定单采用邮件通知用户。当用户下定单成功后,会给用户发送一封确认邮件。等到发货后由发货单位给用户再次发送发货通知邮件。2处理定单Ⅰ.显示已有定单管理员通过输入相应的查询参数(如根据日期、定单号、状态、用户名等),系统返回对应的定单,以及定单的状态。定单管理员根据得到的通知改相应的定单状态。Ⅱ.订单详情管理四利用SQLSever2005设计数据库4.1创建数据库:sqlBookshop4.2创建表表4-2-1pinglun表4-2-2tblBook表4-2-3tblorder表4-2-4tblorderBook表4-2-5tblType表4-2-6序号123列名UserIDUserNameUserPwd数据类型intnvarcharnvarchar5050长度000tbluser标识√主键√允许空默认值说明小数位五5.1概述数据库安全性基于项目特点,项目的安全控制主要由程序代码控制。SQLServer端没有特殊地设定安全设置和检查。项目的用户身份验证、用户授权管理都由应用程序代码实现。5.2数据库验证方式应用程序端连接数据库时使用的数据库验证方式为SQLServer验证。数据库连接串将使用CAPICOM技术加密存储在系统配置文件中。六6.1概述数据库管理和设置本节内容与数据库功能无关,将从系统的数据库运行角度出发,对本数据库的属性设置和备份恢复策略提出指导性说明。6.2数据库属性设置为了保障数据的安全和可用性,建议将数据库的故障还原模块设定为“完全”,这也是SQLServer的默认设置,具体操作步骤如下:1展开“数据库”,右击HBSTPDB,单击“属性”。2选择“HBSTPDB属性”对话框中的“选项”选项卡。3在“模型”下拉框中选中“完全”。116.3数据库备份恢复策略数据库的大小和数据修改的频率决定了采用何种数据库备份恢复策略。如果数据库较小或修改的频度非常低,则可以只实施完全数据库备份,不过此时要定期清理数据库的事务日志,防止数据库的事务日志被填满。其他情况则需要使用差异备份。由于本案例教学涉及的数据库规模较小,建议每周做一次完全备份,中间间隔两天做一次差异备份。6.4数据库运行日常维护SQLServer的一个优势就是对日常维护的要求比较低,但为了追求更高的可用性和安全性,建议每周做备份,同时注意将备份放在不同的备份媒体中,如多个硬盘。七课程设计(综合实验)总结或结论进行本实验的设计之前,我访问了各大网络书店网站:卓越亚马逊、当当网、China-Pub、蔚蓝书店等。对网站的排版、图书的分类、图书的搜索、购物过程等进行的深入的了解。同时参考了微软的PetShop4.0,它采用了三层架构和数据工厂的先进技术对12以后从事大型项目的开发很有帮助;还有《Asp.net2.0电子商务高级编程》这本书,本系统参考了它的开发流程还有其他的细节技术(如使用Sqlserver2005的代理服务器处理废弃购物车);当然我也阅读还有很多从网上下载的电子商务网站的源码。由于时间限制和本人技术水平的限制,未能完整的实现所有的功能模块(如购物帮助、广告管理等),还有对电子商务的付款的安全性了解不是很多,有待提高。13