今天看了个社区,了解了一下该产品的架构设计,做一下分享。

内容来源:http://www.jinhusns.com/Document/FrameworkDocument/?type=cc

一、 架构使用说明 > 引言 >


l   所有菜单用[…]->[…]表示,例如[设置]->[外观]表示菜单“设置”的子级菜单项“外观”。

l   所有按钮或超链接用“…”表示,如“确定”按钮。

l   注意事项用“注意:” 表示,给出一些容易忽略的但是在某个地方比较重要的因素,例如:

注意:

1.TabPanel的TargetID属性需要关联到某个<div>的id;

2.TabPanel的HeaderText属性指定标签页的头部文字;

3.可以设置TabPanel的Href属性,使Tab页的内容从另一个页面获取;

l   提示用“提示:”来表示:

提示:

  1. 1.         提示信息提示信息提示信息提示信息提示信息提示信息提示信息提示信息提示信息提示信息
  2. 2.         提示信息提示信息提示信息提示信息提示信息提示信息提示信息提示信息提示信息提示信息

l   警告用“警告:”来表示:

警告:

  1. 1.   警告信息警告信息警告信息警告信息警告信息警告信息警告信息警告信息;
  2. 2.         警告信息警告信息警告信息警告信息警告信息警告信息警告信息警告信息警告信息;

l   提示事项用“提示:…”表示,用于给出简明短小的建议或窍门。

l   提示事项用“警告:…”表示,用于提醒用户重视程序可能带来的潜在问题、不正确的结果以及要避免的错误。

l   类成员说明示例:

方法名称

成员修饰

说明

备注

Insert(TEntity entity) : void

public virtual

把实体entity添加到数据库

l   代码块表示为:

/// <summary>

/// 处理访客计数的任务

/// </summary>

public class UserVisitsTask : TaskBase

{

/// <summary>

/// TaskBase方法

/// </summary>

public override void ExecuteTask(XElement node)

{

UserVisits.SaveQueue();

}

……

}

二、 架构使用说明 > 整体说明 >


图表1分层设计说明

  1. 1.         各层职责:

职责

说明

表现层

负责向用户显示信息和处理用户指令。(这里的用户也可能是其他计算机系统,不一定是使用用户界面的人)

可能包括asp.net mvc、winform、移动客户端程序

应用层

定义软件要完成的任务,并且指挥领域层来解决问题。应用层要尽量简单,不包含业务规则或者知识,而只为领域层协调任务,分配工作,使它们互相协作。

一般包括Web Service、WCF、REST。

在我们目前的架构中应用层占的比重非常小,通常可以忽略。

领域层

负责表达业务概念,业务状态信息以及业务规则。尽管具体存取业务状态技术细节由基础设施层实现的,但是反映业务情况的状态是由本层控制和使用的。

领域层是业务软件的核心,一般包括:实体、值对象、领域层Service。

基础设施层

为以上各层提供通用的技术能力:为应用层传递消息,为领域层提供持久化机制,为用户界面提供呈现控件等。

  1. 2.         从上向下,层中元素仅依赖本层或其下层的元素,而不能依赖上层。
  2. 3.         各层在产品中的对应:

1)         基础设施层对应于Tunynet.Platform中的Infrastructure、MvcExtensions;

2)         领域层主要存在于Tunynet.Platform中的BusinessComponents、E2的Enterprise以及各应用模块项目中;

3)         应用层很少用到,如果有则存在于Tunynet.Platform中的BusinessComponents、E2的Enterprise及Common、Spacebuilder的Common、各应用模块项目;

4)         表现层对应于E2的Common、Spacebuilder的Common、各应用模块项目;

  1. 4.         项目内的目录组织

1)         在BusinessComponents等项目中由于业务构件众多,而每个构件的文件数并不多,建议以构件名称来作为目录组织,例如:Tag、PrivateMessage;

2)         在各应用模块项目中建议采用类的类型来作为目录组织,例如:Models、Repositories、Services;

  1. 5.         命名约定:

1)         Repository命名::=实体名称+Repository

2)         Service命名::=实体名称+Service

三、架构使用说明 > 运行环境 > 使用说明 >


四、 架构使用说明 > 数据访问 > 使用说明 >


类图

功能介绍


IEntity:Entity接口,所有实体都应该实现该接口;

IRepository<TEntity>:用于处理Entity持久化操作;

PagingDataSet:用于分页数据封装;

PagingEntityIdCollection:封装用于分页的实体Id;

Repository<TEntity>:数据仓储实现类,所有自定义数据仓储类都从此类派生;

常用方法介绍


Repository<TEntity>:

方法名称

成员修饰

说明

备注

Insert(TEntity entity) : void

Public virtual

把实体entity添加到数据库

Update(TEntity entity) : void

public virtual

把实体entiy更新到数据库

Delete(TEntity entity) : int

public virtual

从数据库删除实体

DeleteByEntityId(object entityId) : int

public virtual

从数据库删除实体(by 主键)

Exists(object entityId) : bool

public virtual

依据主键检查实体是否存在于数据库

Get(object entityId) : TEntity

public virtual

依据主键获取单个实体

GetAll() : IEnumerable<IEntity>

public virtual

获取所有实体(仅用于数据量少的情况)

自动对进行缓存(缓存策略与实体配置的缓存策略相同)

GetAll(string orderBy) : IEnumerable<IEntity>

public virtual

获取所有实体(仅用于数据量少的情况)

可设置排序字段(多个排序字段用逗号分隔)

自动对进行缓存(缓存策略与实体配置的缓存策略相同)

sns社区架构设计案例分享的更多相关文章

  1. sns社区架构设计案例分享(二)

    源码下载地址:http://www.jinhusns.com/Products/Download/?type=xcj 五. 架构使用说明 > 缓存 > 使用说明 > (一)基础类库介 ...

  2. web架构设计经验分享(转)

    本人作为一位web工程师,着眼最多之处莫过于 性能与架构,本次幸得参与sd2.0大会,得以与同行广泛交流,于此二方面,有些心得,不敢独享,与众博友分享,本文是这次参会与众同撩交流的心得,有兴趣者可以查 ...

  3. 一套海量在线用户的移动端IM架构设计实践分享(含详细图文)(转)

    1.写在前面 1.1.引言 如果在没有太多经验可借鉴的情况下,要设计一套完整可用的移动端IM架构,难度是相当大的.原因在于,IM系统(尤其是移动端IM系统)是多种技术和领域知识的横向应用综合体:网络编 ...

  4. SOA架构设计经验分享—架构、职责、数据一致性

    阅读目录: 1.背景介绍 2.SOA的架构层次 2.1.应用服务(原子服务) 2.2.组合服务 2.3.业务服务(编排服务) 3.SOA化的重构 3.1.保留服务空间,为了将来服务的组合 4.运用DD ...

  5. [转]SOA架构设计经验分享—架构、职责、数据一致性

    阅读目录: 1.背景介绍 2.SOA的架构层次 2.1.应用服务(原子服务) 2.2.组合服务 2.3.业务服务(编排服务) 3.SOA化的重构 3.1.保留服务空间,为了将来服务的组合 4.运用DD ...

  6. 【转】SOA架构设计经验分享—架构、职责、数据一致性

      1.背景介绍       最近一段时间都在做系统分析和设计工作,面对的业务是典型的重量级企业应用方向.突然发现很多以往觉得很简单的问题变得没有想象的那么容易,最大的问题就 是职责如何分配.论系统架 ...

  7. 新年春节EDM邮件内容设计案例分享

    春节自古以来都是中国最重要的节日.随着中国的发展,中国的春节在世界上都已受到越来越多人的关注,有许多国家和地区都将春节定为法定假日.与此同时,许多品牌营销商也选择在这个时候为中国客户发送马年新年邮件, ...

  8. SOA架构设计案例分析

    转载自:https://www.jdon.com/soa.html 首先Martin Fowler提出SOA歧义Service Oriented Ambiguity,认为"什么是SOA&qu ...

  9. EDM设计案例分享:6款引人入胜的夏日邮件营销模板分享

    夏日酷暑,清凉如风.在这个假期,旅游行业.酒店.服饰等都推出不少的假期活动,吸引游者的到来.假日期间,让我们看看一些旅游业.品牌服装店和酒店是怎么做好电子邮件广告的.在此,Focussend精心为大家 ...

随机推荐

  1. ABP理论学习之验证DTO

    返回总目录 本篇目录 验证介绍 使用数据注解 自定义验证 标准化 验证介绍 首先应该验证应用的输入.用户或者其它应用都可以向该应用发送输入.在一个web应用中,验证通常要实现两次:在客户端和服务器端. ...

  2. Javascript基础回顾 之(三) 面向对象

    本来是要继续由浅入深表达式系列最后一篇的,但是最近团队突然就忙起来了,从来没有过的忙!不过喜欢表达式的朋友请放心,已经在写了:) 在工作当中发现大家对Javascript的一些基本原理普遍存在这里或者 ...

  3. Python黑帽编程 3.1 ARP欺骗

    Python灰帽编程 3.1 ARP欺骗 ARP欺骗是一种在局域网中常用的攻击手段,目的是让局域网中指定的(或全部)的目标机器的数据包都通过攻击者主机进行转发,是实现中间人攻击的常用手段,从而实现数据 ...

  4. Log4net入门使用

    简介 几乎所有的大型应用都会有自己的用于跟踪调试的API.因为一旦程序被部署以后,就不太可能再利用专门的调试工具了.然而一个管理员可能需要有一套强大的日志系统来诊断和修复配置上的问题. 经验表明,日志 ...

  5. GitHub的使用记录

    前言: 该贴为笔者在使用GItHub中的一些使用注意,及Git的基本命令,会一直记录笔者在使用GitHub中可能产生的错误及解决方法(会一直更新中),待一些Git初使用者参考,如果有说明不详细或不对的 ...

  6. Atitit 设计模式与算法,与流程的关系

    Atitit 设计模式与算法,与流程的关系 1.1. 设计模式就是算法 就是流程,不同的方面看法不同,抽象方法不同而造成的假象. 软件就是由设计模式累积成的.也可以说算法累计成的.. ,而可以用Vis ...

  7. 携程App的网络性能优化实践

    首先介绍一下携程App的网络服务架构.由于携程业务众多,开发资源导致无法全部使用Native来实现业务逻辑,因此有相当一部分频道基于Hybrid实现.网络通讯属于基础&业务框架层中基础设施的一 ...

  8. Java_IO流_File类配合使用(其中用到了递归)

    第一:Java File类的功能非常强大,利用Java基本上可以对文件进行所有的操作.以下对Java File文件操作以及常用方法进行简单介绍 案例1:遍历出指定目录下的文件夹,并输出文件名 stat ...

  9. jquery插件编写模版

    jquery插件是什么??这里以讨论实力方法为主,比如 $("div").pluginname({}); 他的最简单形势应该是 $.prototype.plugin = funct ...

  10. java中动态代理实现机制

    前言: 代理模式是常用的java设计模式,它的特征是代理类与委托类有同样的接口,代理类主要负责为委托类预处理消息.过滤消息.把消息转发给委托类,以及事后处理消息等.代理类与委托类之间通常会存在关联关系 ...